pre_processor.rs — tailwindcss Source File
Architecture documentation for pre_processor.rs, a rust file in the tailwindcss codebase. 4 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR c9eebb75_dc3f_0649_0b9f_ee56e4ee9c1c["pre_processor.rs"] e4088d34_b5b4_ec51_b975_557a1536ec76["pretty_assertions::assert_eq"] c9eebb75_dc3f_0649_0b9f_ee56e4ee9c1c --> e4088d34_b5b4_ec51_b975_557a1536ec76 a1d398d5_15cf_6c95_338f_6f243e682240["crate::extractor::"] c9eebb75_dc3f_0649_0b9f_ee56e4ee9c1c --> a1d398d5_15cf_6c95_338f_6f243e682240 92a7f8f3_93b3_636d_2fcf_61d389088754["std::collections::BTreeMap"] c9eebb75_dc3f_0649_0b9f_ee56e4ee9c1c --> 92a7f8f3_93b3_636d_2fcf_61d389088754 d59be067_d25f_ee61_805b_9058dc264606["unicode_width::UnicodeWidthStr"] c9eebb75_dc3f_0649_0b9f_ee56e4ee9c1c --> d59be067_d25f_ee61_805b_9058dc264606 style c9eebb75_dc3f_0649_0b9f_ee56e4ee9c1c fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
pub trait PreProcessor: Sized + Default {
fn process(&self, content: &[u8]) -> Vec<u8>;
#[cfg(test)]
fn test(input: &str, expected: &str) {
use pretty_assertions::assert_eq;
let input = input.as_bytes();
let expected = expected.as_bytes();
let processor = Self::default();
let actual = processor.process(input);
// Convert to strings for better error messages.
let input = String::from_utf8_lossy(input);
let actual = String::from_utf8_lossy(&actual);
let expected = String::from_utf8_lossy(expected);
// The input and output should have the exact same length.
assert_eq!(input.len(), actual.len());
assert_eq!(actual.len(), expected.len());
assert_eq!(actual, expected);
}
#[cfg(test)]
fn test_extract_exact(input: &str, expected: Vec<&str>) {
use crate::extractor::{Extracted, Extractor};
let input = input.as_bytes();
let processor = Self::default();
let transformed = processor.process(input);
let extracted = Extractor::new(&transformed).extract();
// Extract all candidates and css variables.
let candidates = extracted
.iter()
.filter_map(|x| match x {
Extracted::Candidate(bytes) => std::str::from_utf8(bytes).ok(),
Extracted::CssVariable(bytes) => std::str::from_utf8(bytes).ok(),
})
.collect::<Vec<_>>();
if candidates != expected {
dbg!(&candidates, &expected);
panic!("Extracted candidates do not match expected candidates");
}
}
#[cfg(test)]
fn test_extract_contains(input: &str, expected: Vec<&str>) {
use crate::extractor::{Extracted, Extractor};
let input = input.as_bytes();
let processor = Self::default();
let transformed = processor.process(input);
// ... (127 more lines)
Domain
Subdomains
Functions
Classes
Dependencies
- crate::extractor::
- pretty_assertions::assert_eq
- std::collections::BTreeMap
- unicode_width::UnicodeWidthStr
Source
Frequently Asked Questions
What does pre_processor.rs do?
pre_processor.rs is a source file in the tailwindcss codebase, written in rust. It belongs to the OxideEngine domain, PreProcessors subdomain.
What functions are defined in pre_processor.rs?
pre_processor.rs defines 1 function(s): byte_offset_to_line_and_column.
What does pre_processor.rs depend on?
pre_processor.rs imports 4 module(s): crate::extractor::, pretty_assertions::assert_eq, std::collections::BTreeMap, unicode_width::UnicodeWidthStr.
Where is pre_processor.rs in the architecture?
pre_processor.rs is located at crates/oxide/src/extractor/pre_processors/pre_processor.rs (domain: OxideEngine, subdomain: PreProcessors, directory: crates/oxide/src/extractor/pre_processors).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free