Commit a2931805 authored by Thomas Van Lenten's avatar Thomas Van Lenten

Merge pull request #1378 from thomasvl/manual_stream_parsing_helpers

Add -position and -isAtEnd for use when manually parsing input streams.
parents 099ff1ea 331cee50
...@@ -109,6 +109,15 @@ NS_ASSUME_NONNULL_BEGIN ...@@ -109,6 +109,15 @@ NS_ASSUME_NONNULL_BEGIN
/// or until an endgroup tag, whichever comes first. /// or until an endgroup tag, whichever comes first.
- (void)skipMessage; - (void)skipMessage;
/// Check to see if the logical end of the stream has been reached.
///
/// This can return NO when there is no more data, but the current parsing
/// expected more data.
- (BOOL)isAtEnd;
/// The offset into the stream.
- (size_t)position;
/// Verifies that the last call to @c -readTag returned the given tag value. /// Verifies that the last call to @c -readTag returned the given tag value.
/// This is used to verify that a nested group ended with the correct end tag. /// This is used to verify that a nested group ended with the correct end tag.
/// Throws @c NSParseErrorException if value does not match the last tag. /// Throws @c NSParseErrorException if value does not match the last tag.
......
...@@ -359,6 +359,14 @@ void GPBCodedInputStreamCheckLastTagWas(GPBCodedInputStreamState *state, ...@@ -359,6 +359,14 @@ void GPBCodedInputStreamCheckLastTagWas(GPBCodedInputStreamState *state,
} }
} }
- (BOOL)isAtEnd {
return GPBCodedInputStreamIsAtEnd(&state_);
}
- (size_t)position {
return state_.bufferPos;
}
- (double)readDouble { - (double)readDouble {
return GPBCodedInputStreamReadDouble(&state_); return GPBCodedInputStreamReadDouble(&state_);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment