Re: [PATCH 02/26] pkt-line: introduce struct packet_reader
From: Brandon Williams <hidden>
Date: 2018-01-09 19:19:11
On 01/09, Jonathan Tan wrote:
On Tue, 2 Jan 2018 16:18:04 -0800 Brandon Williams [off-list ref] wrote:quoted
diff --git a/pkt-line.h b/pkt-line.h index 06c468927..c446e886a 100644 --- a/pkt-line.h +++ b/pkt-line.h@@ -111,6 +111,63 @@ char *packet_read_line_buf(char **src_buf, size_t *src_len, int *size); */ ssize_t read_packetized_to_strbuf(int fd_in, struct strbuf *sb_out); +struct packet_reader { + /* source file descriptor */ + int fd; + + /* source buffer and its size */ + char *src_buffer; + size_t src_len; + + /* buffer that pkt-lines are read into and its size */ + char *buffer; + unsigned buffer_size;Is the intention to support different buffers in the future?
Potentially at some point.
[snip]quoted
+/* + * Peek the next packet line without consuming it and return the status. + * The next call to 'packet_reader_read()' will perform a read of the same line + * that was peeked, consuming the line. + * + * Only a single line can be peeked at a time.It is logical to me that if you peeked at a line, and then peeked at it again, you will get the same line - I would phrase this not as a restriction ("only a single line") but just as a statement of fact (e.g. "Peeking at the same line multiple times without an intervening packet_reader_read will return the same result").
Fair enough, i'll change the wording.
quoted
+ */ +extern enum packet_read_status packet_reader_peek(struct packet_reader *reader); + #define DEFAULT_PACKET_MAX 1000 #define LARGE_PACKET_MAX 65520 #define LARGE_PACKET_DATA_MAX (LARGE_PACKET_MAX - 4)
-- Brandon Williams