diff options
author | gennyble <gen@nyble.dev> | 2023-12-30 01:31:33 -0600 |
---|---|---|
committer | gennyble <gen@nyble.dev> | 2023-12-30 01:31:33 -0600 |
commit | aea63e598fb9cfd02f9397b1db0deaea968a21b9 (patch) | |
tree | 1363ff471119fd6ca27b0f4f3593566b44758319 /src | |
parent | 3d84fcbfc6044d726e95117d9fe80cedc791124a (diff) | |
download | cutie-aea63e598fb9cfd02f9397b1db0deaea968a21b9.tar.gz cutie-aea63e598fb9cfd02f9397b1db0deaea968a21b9.zip |
no more query
Diffstat (limited to 'src')
-rw-r--r-- | src/lib.rs | 81 |
1 files changed, 1 insertions, 80 deletions
diff --git a/src/lib.rs b/src/lib.rs index 18836d0..3077220 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1,8 +1,7 @@ use core::fmt; -use query::{parse_query, QueryComponent, QueryElement, QueryParseError}; use tag::Tag; -mod query; +//mod query; mod tag; pub struct Html { @@ -26,84 +25,6 @@ impl Html { } } - pub fn query<S: AsRef<str>>(&self, query: S) -> Result<Option<&Node>, QueryParseError> { - let query = parse_query(query.as_ref())?; - - let mut working: Vec<&Node> = self.nodes.iter().collect(); - - for component in &query { - let component_working: Vec<&Node> = std::mem::take(&mut working); - for node in component_working { - match component { - QueryComponent::DirectElement(direct) => { - if Self::node_matches(node, direct) { - working.push(node); - } - } - QueryComponent::Element(element) => { - // GENNY: - // you were working on the query system. This one needs to recur, - // checking the current component against the entire depth of - // children of the node. I'm worried about lifetimes here. For - // immutable we might be alright but what happens when we're - // muteable and we want to return a parent and it's child because - // they both match? - // - // Don't get discouraged; it's a hard problem. Perhaps we write an - // iterator so we don't have to keep references around? Sticking - // everything in an Rc or whatever structure I'd need feels icky. - // - // Perhaps it's the way I'm searching. I could recur through the - // current node, from self.nodes, until match failure. It fits - // the funciton signature, returning one Node, but perhaps doesn't - // fit the purpose. - // - // But the purpose is to easily insert parsed text into HTML - // without templating it, so maybe it is fit for purpose. That - // only needs to find one element at a time perhaps. - // - // All goes sour maybe I can return IDs to nodes? Keep a counter - // in HTML where each node gets an increasing ID. Pass the ID to - // a funtion in HTML for modification. Or maybe have IDs, - // NodeHandles let's call them, contain an Rc<RefCell<Html>>. - // - // That is by far enough thinking for the night. It's time to - // head to bed. <3 i love you - todo!() - } - } - } - } - - todo!() - } - - fn node_matches(node: &Node, component: &QueryElement) -> bool { - if let Node::Tag(tag) = node { - if let Some(comp_name) = component.tag.as_deref() { - if comp_name != tag.name { - return false; - } - } - - match (tag.id(), component.id.as_deref()) { - (None, Some(_)) => return false, - (Some(tag_id), Some(comp_id)) if tag_id != comp_id => return false, - _ => (), - } - - if let Some(comp_class) = component.class.as_deref() { - if !tag.has_class(comp_class) { - return false; - } - } - - true - } else { - false - } - } - fn parse_node(raw: &str) -> Consumed { match Self::is_tag(raw) { Some(_) => { |