Skip to content

Commit

Permalink
ff
Browse files Browse the repository at this point in the history
  • Loading branch information
wiiznokes committed Jul 17, 2024
1 parent 91fcd9b commit 1a49e41
Show file tree
Hide file tree
Showing 5 changed files with 109 additions and 8 deletions.
7 changes: 7 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ tracing-subscriber = { version = "0.3.16", features = [
tracing-journald = "0.3.0"
constcat = "0.5.0"
nucleo = "0.5.0"
tl = "0.7.8"

[dependencies.libcosmic]
git = "https://github.com/pop-os/libcosmic"
Expand Down
104 changes: 98 additions & 6 deletions src/clipboard.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ use std::{
};

use cosmic::iced::{futures::SinkExt, subscription, Subscription};
use tl::queryselector::iterable::QueryIterable;
use tokio::sync::mpsc;
use wl_clipboard_rs::{copy, paste_watch};

Expand Down Expand Up @@ -128,15 +129,34 @@ pub fn sub() -> Subscription<ClipboardMessage> {
match rx.recv().await {
Some(Some(mut res)) => {
let metadata = if res.len() == 2 {
let (mut pipe, _mimitype) = res.remove(1);
let (mut pipe, mimitype) = res.remove(0);

let mut contents = String::new();
pipe.read_to_string(&mut contents).unwrap();

// todo: use the mimetype to know if its html
// parse accordinely
eprintln!("before");
let mut metadata = Vec::new();
pipe.read_to_end(&mut metadata).unwrap();

Some(contents)

eprintln!("before");
let mut metadata = String::new();
pipe.read_to_string(&mut metadata).unwrap();

eprintln!("after");

// // #[allow(clippy::assigning_clones)]
// // if mimitype == "text/html" {
// // if let Some(alt) = find_alt(&metadata) {
// // metadata = alt.to_owned();
// // }
// // }

// let metadata = String::from_utf8(metadata).unwrap();

// find_alt3(&metadata);

// Some(metadata)
// Some(metadata)
None
} else {
None
};
Expand Down Expand Up @@ -246,3 +266,75 @@ pub fn sub2() -> Subscription<Message> {
}
*/

#[test]
fn a() {
let metadata = r#"
<meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\"><img
src=\"\"
data-deferred=\"1\" class=\"rg_i Q4LuWd\" jsname=\"Q4LuWd\" width=\"316\"
height=\"160\" alt=\"The Iterator Pattern: So Simple, It's Genius (Or So They
Say) | by Do Tran | Level Up Coding\" data-iml=\"1916\" data-atf=\"true\">
"#.to_owned();

assert_eq!(find_alt(&metadata), Some("The Iterator Pattern: So Simple, It's Genius (Or So They\nSay) | by Do Tran | Level Up Coding"))
}

fn find_alt(html: &str) -> Option<&str> {
const DEB: &str = "alt=\\\"";

if let Some(pos) = html.find(DEB) {
const OFFSET: usize = DEB.as_bytes().len();

if let Some(pos_end) = html[pos + OFFSET..].find("\\\"") {
return Some(&html[pos + OFFSET..pos + pos_end + OFFSET]);
}
}

None
}

fn find_alt2(html: &str) {
let dom = tl::parse(html, tl::ParserOptions::default()).unwrap();

let parser = dom.parser();

let element = dom
.get_element_by_id("img")
.expect("Failed to find element")
.get(parser)
.unwrap();

let a = element.inner_text(parser);

println!("{a}");
}

fn find_alt3(html: &str) {
// Parse the HTML string
let dom = tl::parse(html, tl::ParserOptions::default()).unwrap();

// Get the parser object from the DOM
let parser = dom.parser();


let e = dom.get_elements_by_class_name("img").next();

info!("{e:?}")

}

#[test]
fn b() {
let metadata = r#"
<meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\"><img
src=\"\"
data-deferred=\"1\" class=\"rg_i Q4LuWd\" jsname=\"Q4LuWd\" width=\"316\"
height=\"160\" alt=\"The Iterator Pattern: So Simple, It's Genius (Or So They
Say) | by Do Tran | Level Up Coding\" data-iml=\"1916\" data-atf=\"true\">
"#.to_owned();

find_alt3(&metadata);
}
3 changes: 2 additions & 1 deletion src/db.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ use crate::{

type TimeId = i64;

const DB_VERSION: &str = "1";
const DB_VERSION: &str = "2";
const DB_PATH: &str = constcat::concat!(APPID, "-db-", DB_VERSION, ".sqlite");

// warning: if you change somethings in here, change the db version
Expand Down Expand Up @@ -79,6 +79,7 @@ impl Debug for Entry {
.field("creation", &self.creation)
.field("mime", &self.mime)
.field("content", &self.get_content())
.field("metadata", &self.metadata)
.finish()
}
}
Expand Down
2 changes: 1 addition & 1 deletion src/view.rs
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ fn uris_entry<'a>(
return None;
}

let max = 4;
let max = 3;

let mut lines = Vec::with_capacity(min(uris.len(), max + 1));

Expand Down

0 comments on commit 1a49e41

Please sign in to comment.