Compare commits

..

No commits in common. "2647cee911d72ebaf565c73caa890d2375dcfcaa" and "40a298f3cc01f4f5fb3b357dd593d26ac717ca5b" have entirely different histories.

3 changed files with 19 additions and 24 deletions

View File

@ -329,7 +329,8 @@ impl <'a> ser::SerializeTupleVariant for &'a mut Serializer {
impl<'a> MapSerializer<'a> { impl<'a> MapSerializer<'a> {
fn finalize(self) { fn finalize(self) {
for value in self.sorted_map.values() { for (key, value) in self.sorted_map.into_iter() {
self.super_serializer.output.extend(key);
self.super_serializer.output.extend(value); self.super_serializer.output.extend(value);
} }
self.super_serializer.output.push('e' as u8); self.super_serializer.output.push('e' as u8);
@ -345,12 +346,10 @@ impl <'a> ser::SerializeMap for MapSerializer<'a> {
T: ?Sized + Serialize T: ?Sized + Serialize
{ {
key.serialize(&mut self.value_serializer)?; key.serialize(&mut self.value_serializer)?;
let insert_key_start = self.value_serializer.output.iter().position(|x| *x == b':') self.last_inserted_key = self.value_serializer.output.clone();
.ok_or(Error::Syntax("missing \":\" from just serialized byte string".to_string()))?;
self.last_inserted_key = self.value_serializer.output[insert_key_start+1..].to_vec();
let mut key_to_insert = Vec::new(); let mut key_to_insert = Vec::new();
swap(&mut self.value_serializer.output, &mut key_to_insert); swap(&mut self.value_serializer.output, &mut key_to_insert);
self.sorted_map.insert(self.last_inserted_key.clone(), key_to_insert); self.sorted_map.insert(key_to_insert, Vec::new());
Ok(()) Ok(())
} }
@ -371,7 +370,7 @@ impl <'a> ser::SerializeMap for MapSerializer<'a> {
swap(&mut self.value_serializer.output, &mut value_to_insert); swap(&mut self.value_serializer.output, &mut value_to_insert);
let Some(x) = self.sorted_map.get_mut(&self.last_inserted_key) let Some(x) = self.sorted_map.get_mut(&self.last_inserted_key)
else { unreachable!() }; else { unreachable!() };
x.extend(value_to_insert); *x = value_to_insert;
} else { } else {
self.sorted_map.remove(&self.last_inserted_key); self.sorted_map.remove(&self.last_inserted_key);
self.value_serializer.output.clear(); self.value_serializer.output.clear();
@ -405,13 +404,9 @@ impl <'a> ser::SerializeStruct for MapSerializer<'a> {
let mut val_str = Vec::new(); let mut val_str = Vec::new();
swap(&mut self.value_serializer.output, &mut val_str); swap(&mut self.value_serializer.output, &mut val_str);
key.serialize(&mut self.value_serializer)?; key.serialize(&mut self.value_serializer)?;
let insert_key_start = self.value_serializer.output.iter().position(|x| *x == b':')
.ok_or(Error::Syntax("missing \":\" from just serialized byte string".to_string()))?;
let insert_key = self.value_serializer.output[insert_key_start+1..].to_vec();
let mut key_str = Vec::new(); let mut key_str = Vec::new();
swap(&mut self.value_serializer.output, &mut key_str); swap(&mut self.value_serializer.output, &mut key_str);
key_str.extend(val_str); self.sorted_map.insert(key_str, val_str);
self.sorted_map.insert(insert_key, key_str);
Ok(()) Ok(())
} }
@ -472,15 +467,15 @@ mod test {
fn test_map() { fn test_map() {
assert_eq!(to_string(&HashMap::from([ assert_eq!(to_string(&HashMap::from([
("foo", 42), ("foo", 42),
("bare", 13), ("bar", 13),
])).unwrap(), ])).unwrap(),
"d4:barei13e3:fooi42ee" "d3:bari13e3:fooi42ee"
); );
assert_eq!(to_string(&HashMap::from([ assert_eq!(to_string(&HashMap::from([
("foo", "💩"), ("foo", "💩"),
("bare", "🙈"), ("bar", "🙈"),
])).unwrap(), ])).unwrap(),
"d4:bare4:🙈3:foo4:💩e" "d3:bar4:🙈3:foo4:💩e"
); );
assert_eq!(to_string(&HashMap::from([ assert_eq!(to_string(&HashMap::from([
("foo", Some("💩")), ("foo", Some("💩")),
@ -509,12 +504,12 @@ mod test {
l: vec![3, 7, 9], l: vec![3, 7, 9],
m: HashMap::from([ m: HashMap::from([
("foo".to_string(), 23), ("foo".to_string(), 23),
("bare".to_string(), 18), ("bar".to_string(), 18),
]), ]),
o: Some("baz".to_string()), o: Some("baz".to_string()),
o2: None, o2: None,
}).unwrap(), }).unwrap(),
"d1:lli3ei7ei9ee1:md4:barei18e3:fooi23ee1:o3:baze" "d1:lli3ei7ei9ee1:md3:bari18e3:fooi23ee1:o3:baze"
); );
#[derive(Serialize)] #[derive(Serialize)]

View File

@ -60,7 +60,7 @@ fn main() -> Result<()> {
let resp = client.get(url).send()?; let resp = client.get(url).send()?;
let status = resp.status(); let status = resp.status();
let _body = resp.text()?; let body = resp.text()?;
println!("Response: {status}"); println!("Response: {status}");
Ok(()) Ok(())

View File

@ -1,10 +1,10 @@
use crate::bencode::de::from_bytes;
use crate::bencode::ser::to_bytes;
use serde::ser::SerializeSeq;
use serde::{de, Deserialize, Deserializer, Serialize, Serializer}; use serde::{de, Deserialize, Deserializer, Serialize, Serializer};
use std::path;
use serde_bytes::ByteBuf; use serde_bytes::ByteBuf;
use sha1::{Digest, Sha1}; use sha1::{Digest, Sha1};
use std::path; use serde::ser::SerializeSeq;
use crate::bencode::de::from_bytes;
use crate::bencode::ser::to_bytes;
#[derive(Serialize, Deserialize, Debug)] #[derive(Serialize, Deserialize, Debug)]
pub struct FileInfo { pub struct FileInfo {
@ -96,9 +96,9 @@ impl Torrent {
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use crate::torrent::Torrent;
use std::path::Path;
use std::{env, fs}; use std::{env, fs};
use std::path::Path;
use crate::torrent::Torrent;
#[test] #[test]
fn check_correct_info_hash() { fn check_correct_info_hash() {