skorotkov commented on code in PR #11518: URL: https://github.com/apache/ignite/pull/11518#discussion_r1810831766
########## modules/core/src/main/java/org/apache/ignite/internal/binary/BinaryWriterExImpl.java: ########## @@ -1880,6 +1892,72 @@ public void writeFieldIdNoSchemaUpdate(int fieldId) { fieldCnt++; } + /** + * Write byte array from the InputStream with the specified length. + * + * @param in InputStream. + * @param len Length of data in the stream. + * @return Number of bytes written. + */ + public int writeByteArrayFromInputStream(InputStream in, int len) throws IOException { + out.unsafeEnsure(1 + 4 + len); + + return doWriteByteArrayFromInputStream(in, len); + } + + /** + * Write byte array from the InputStream with uknown length. + * + * @param in InputStream. + * @return Number of bytes written or -1 if stream contains more than {@code MAX_ARRAY_SIZE} bytes. + */ + public int writeByteArrayFromInputStream(InputStream in) throws IOException { + out.unsafeEnsure(1 + 4); + + int writtenLen = doWriteByteArrayFromInputStream(in, MAX_ARRAY_SIZE); + + if (writtenLen == MAX_ARRAY_SIZE && in.read() != -1) Review Comment: I think we can not. Since `doWriteByteArrayFromInputStream` is supposed to not read more than limit. No single byte. I can create another function which would be almost the same but allowed to (try) read more data then limit. In this function the extra read call will only be performed if actual data length is multiple of DEFAULT_BUFFER_SIZE. `doWriteByteArrayFromInputStream` will be used for case for known (declared) length New function will be used for case if length is not provided. -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: notifications-unsubscr...@ignite.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org