aboutsummaryrefslogtreecommitdiff
path: root/src/server_dev/parser.rs
diff options
context:
space:
mode:
authorFuwn <[email protected]>2021-04-26 13:26:53 -0700
committerFuwn <[email protected]>2021-04-26 13:26:53 -0700
commit7318396b45a64ed1336d50a5694303e849e0bfd4 (patch)
tree362223bfc517989590918a1ff5b32e1f02ab4165 /src/server_dev/parser.rs
parentetc: Prepend license identifier to *most* files (diff)
downloadwhirl-7318396b45a64ed1336d50a5694303e849e0bfd4.tar.xz
whirl-7318396b45a64ed1336d50a5694303e849e0bfd4.zip
etc: Remove legacy server module
Diffstat (limited to 'src/server_dev/parser.rs')
-rw-r--r--src/server_dev/parser.rs35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/server_dev/parser.rs b/src/server_dev/parser.rs
new file mode 100644
index 0000000..f856650
--- /dev/null
+++ b/src/server_dev/parser.rs
@@ -0,0 +1,35 @@
+use bytes::BytesMut;
+
+/// Read all commands from the given buffer.
+///
+/// # Process
+/// 1. Get a command from `buffer` based on first byte.
+/// 2. Push command to `commands`.
+/// 3. Remove command from `buffer`.
+/// 4. Iterate and do this for all commands within `buffer`.
+pub fn get_commands_from_buffer(mut buffer: BytesMut) -> Vec<BytesMut> {
+ let mut commands: Vec<BytesMut> = Vec::new();
+ trace!("initial buffer: {:?}, length: {}", buffer, buffer.len());
+
+ let data_length = buffer.get(0).unwrap().to_owned() as usize;
+ if buffer.len() > data_length {
+ loop {
+ trace!("loop: {:?}, length: {}", buffer, buffer.len());
+ let command_length = buffer.get(0).unwrap().to_owned() as usize;
+ commands.push(BytesMut::from(buffer.get(0..command_length).unwrap()));
+
+ // Remove command from buffer
+ buffer = buffer.split_off(command_length);
+
+ // Check if any more commands are present
+ if buffer.is_empty() {
+ break;
+ }
+ }
+ } else {
+ // There will always be at least one command, push it.
+ commands.push(BytesMut::from(buffer.get(0..data_length).unwrap()));
+ }
+
+ commands // Return command (s)
+}