This commit is contained in:
Laurenz 2023-04-18 19:10:55 +02:00
parent 35302d2004
commit d10b53df0b
11 changed files with 29 additions and 25 deletions

View File

@ -8,6 +8,7 @@ jobs:
- uses: actions/checkout@v3 - uses: actions/checkout@v3
- uses: dtolnay/rust-toolchain@stable - uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2 - uses: Swatinem/rust-cache@v2
- run: cargo fmt --check - run: cargo fmt --check --all
- run: cargo clippy --workspace --all-targets
- run: cargo build --workspace - run: cargo build --workspace
- run: cargo test --workspace --no-fail-fast - run: cargo test --workspace --no-fail-fast

View File

@ -33,7 +33,7 @@ impl Html {
pub fn markdown(resolver: &dyn Resolver, md: &str) -> Self { pub fn markdown(resolver: &dyn Resolver, md: &str) -> Self {
let mut text = md; let mut text = md;
let mut description = None; let mut description = None;
let document = YamlFrontMatter::parse::<Metadata>(&md); let document = YamlFrontMatter::parse::<Metadata>(md);
if let Ok(document) = &document { if let Ok(document) = &document {
text = &document.content; text = &document.content;
description = Some(document.metadata.description.clone()) description = Some(document.metadata.description.clone())
@ -43,7 +43,7 @@ impl Html {
let mut handler = Handler::new(resolver); let mut handler = Handler::new(resolver);
let iter = md::Parser::new_ext(text, options) let iter = md::Parser::new_ext(text, options)
.filter_map(|mut event| handler.handle(&mut event).then(|| event)); .filter_map(|mut event| handler.handle(&mut event).then_some(event));
let mut raw = String::new(); let mut raw = String::new();
md::html::push_html(&mut raw, iter); md::html::push_html(&mut raw, iter);
@ -169,7 +169,7 @@ impl<'a> Handler<'a> {
fn handle_image(&self, link: &str) -> String { fn handle_image(&self, link: &str) -> String {
if let Some(file) = FILES.get_file(link) { if let Some(file) = FILES.get_file(link) {
self.resolver.image(&link, file.contents()).into() self.resolver.image(link, file.contents())
} else if let Some(url) = self.resolver.link(link) { } else if let Some(url) = self.resolver.link(link) {
url url
} else { } else {

View File

@ -229,7 +229,7 @@ fn category_page(resolver: &dyn Resolver, category: &str) -> PageModel {
for group in grouped { for group in grouped {
let mut functions = vec![]; let mut functions = vec![];
for name in &group.functions { for name in &group.functions {
let value = focus.get(&name).unwrap(); let value = focus.get(name).unwrap();
let Value::Func(func) = value else { panic!("not a function") }; let Value::Func(func) = value else { panic!("not a function") };
let info = func.info().unwrap(); let info = func.info().unwrap();
functions.push(func_model(resolver, func, info)); functions.push(func_model(resolver, func, info));
@ -335,7 +335,7 @@ fn func_model(resolver: &dyn Resolver, func: &Func, info: &FuncInfo) -> FuncMode
let mut s = unscanny::Scanner::new(info.docs); let mut s = unscanny::Scanner::new(info.docs);
let docs = s.eat_until("\n## Methods").trim(); let docs = s.eat_until("\n## Methods").trim();
FuncModel { FuncModel {
name: info.name.into(), name: info.name,
display: info.display, display: info.display,
oneliner: oneliner(docs), oneliner: oneliner(docs),
showable: func.element().is_some(), showable: func.element().is_some(),
@ -721,7 +721,7 @@ pub fn urlify(title: &str) -> String {
/// Extract the first line of documentation. /// Extract the first line of documentation.
fn oneliner(docs: &str) -> &str { fn oneliner(docs: &str) -> &str {
docs.lines().next().unwrap_or_default().into() docs.lines().next().unwrap_or_default()
} }
/// The order of types in the documentation. /// The order of types in the documentation.

View File

@ -1,6 +1,7 @@
//! Typst's standard library.
#![allow(clippy::wildcard_in_or_patterns)] #![allow(clippy::wildcard_in_or_patterns)]
#![allow(clippy::comparison_chain)] #![allow(clippy::comparison_chain)]
//! Typst's standard library.
pub mod compute; pub mod compute;
pub mod layout; pub mod layout;

View File

@ -17,8 +17,8 @@ use crate::syntax::{SourceId, Span, SyntaxNode};
use crate::World; use crate::World;
/// An evaluatable function. /// An evaluatable function.
#[allow(clippy::derived_hash_with_manual_eq)]
#[derive(Clone, Hash)] #[derive(Clone, Hash)]
#[allow(clippy::derived_hash_with_manual_eq)]
pub struct Func { pub struct Func {
/// The internal representation. /// The internal representation.
repr: Repr, repr: Repr,
@ -278,8 +278,8 @@ pub enum Param {
impl Closure { impl Closure {
/// Call the function in the context with the arguments. /// Call the function in the context with the arguments.
#[allow(clippy::too_many_arguments)]
#[comemo::memoize] #[comemo::memoize]
#[allow(clippy::too_many_arguments)]
fn call( fn call(
this: &Func, this: &Func,
world: Tracked<dyn World>, world: Tracked<dyn World>,

View File

@ -7,8 +7,8 @@ use super::{Content, Scope, Value};
use crate::diag::StrResult; use crate::diag::StrResult;
/// An evaluated module, ready for importing or typesetting. /// An evaluated module, ready for importing or typesetting.
#[allow(clippy::derived_hash_with_manual_eq)]
#[derive(Clone, Hash)] #[derive(Clone, Hash)]
#[allow(clippy::derived_hash_with_manual_eq)]
pub struct Module(Arc<Repr>); pub struct Module(Arc<Repr>);
/// The internal representation. /// The internal representation.

View File

@ -241,8 +241,8 @@ impl Hash for Value {
} }
/// A dynamic value. /// A dynamic value.
#[allow(clippy::derived_hash_with_manual_eq)]
#[derive(Clone, Hash)] #[derive(Clone, Hash)]
#[allow(clippy::derived_hash_with_manual_eq)]
pub struct Dynamic(Arc<dyn Bounds>); pub struct Dynamic(Arc<dyn Bounds>);
impl Dynamic { impl Dynamic {
@ -426,7 +426,7 @@ mod tests {
test(Value::None, "none"); test(Value::None, "none");
test(false, "false"); test(false, "false");
test(12i64, "12"); test(12i64, "12");
test(3.14, "3.14"); test(3.24, "3.24");
test(Abs::pt(5.5), "5.5pt"); test(Abs::pt(5.5), "5.5pt");
test(Angle::deg(90.0), "90deg"); test(Angle::deg(90.0), "90deg");
test(Ratio::one() / 2.0, "50%"); test(Ratio::one() / 2.0, "50%");

View File

@ -1,4 +1,3 @@
#![allow(clippy::comparison_chain)]
//! The compiler for the _Typst_ markup language. //! The compiler for the _Typst_ markup language.
//! //!
//! # Steps //! # Steps
@ -34,6 +33,7 @@
//! [raster images]: export::render //! [raster images]: export::render
#![recursion_limit = "1000"] #![recursion_limit = "1000"]
#![allow(clippy::comparison_chain)]
extern crate self as typst; extern crate self as typst;

View File

@ -17,8 +17,8 @@ use crate::syntax::Span;
use crate::util::pretty_array_like; use crate::util::pretty_array_like;
/// Composable representation of styled content. /// Composable representation of styled content.
#[allow(clippy::derived_hash_with_manual_eq)]
#[derive(Clone, Hash)] #[derive(Clone, Hash)]
#[allow(clippy::derived_hash_with_manual_eq)]
pub struct Content { pub struct Content {
func: ElemFunc, func: ElemFunc,
attrs: EcoVec<Attr>, attrs: EcoVec<Attr>,

View File

@ -30,8 +30,8 @@ fn bench_decode(iai: &mut Iai) {
// We don't use chars().count() because that has a special // We don't use chars().count() because that has a special
// superfast implementation. // superfast implementation.
let mut count = 0; let mut count = 0;
let mut chars = black_box(TEXT).chars(); let chars = black_box(TEXT).chars();
while let Some(_) = chars.next() { for _ in chars {
count += 1; count += 1;
} }
count count
@ -42,7 +42,7 @@ fn bench_scan(iai: &mut Iai) {
iai.run(|| { iai.run(|| {
let mut count = 0; let mut count = 0;
let mut scanner = Scanner::new(black_box(TEXT)); let mut scanner = Scanner::new(black_box(TEXT));
while let Some(_) = scanner.eat() { while scanner.eat().is_some() {
count += 1; count += 1;
} }
count count

View File

@ -1,3 +1,5 @@
#![allow(clippy::comparison_chain)]
use std::cell::{RefCell, RefMut}; use std::cell::{RefCell, RefMut};
use std::collections::HashMap; use std::collections::HashMap;
use std::env; use std::env;
@ -324,10 +326,10 @@ fn read(path: &Path) -> FileResult<Vec<u8>> {
.unwrap_or_else(|_| path.into()); .unwrap_or_else(|_| path.into());
let f = |e| FileError::from_io(e, &suffix); let f = |e| FileError::from_io(e, &suffix);
if fs::metadata(&path).map_err(f)?.is_dir() { if fs::metadata(path).map_err(f)?.is_dir() {
Err(FileError::IsDirectory) Err(FileError::IsDirectory)
} else { } else {
fs::read(&path).map_err(f) fs::read(path).map_err(f)
} }
} }
@ -379,7 +381,7 @@ fn test(
if compare_ever { if compare_ever {
if let Some(pdf_path) = pdf_path { if let Some(pdf_path) = pdf_path {
let pdf_data = typst::export::pdf(&document); let pdf_data = typst::export::pdf(&document);
fs::create_dir_all(&pdf_path.parent().unwrap()).unwrap(); fs::create_dir_all(pdf_path.parent().unwrap()).unwrap();
fs::write(pdf_path, pdf_data).unwrap(); fs::write(pdf_path, pdf_data).unwrap();
} }
@ -390,7 +392,7 @@ fn test(
} }
let canvas = render(&document.pages); let canvas = render(&document.pages);
fs::create_dir_all(&png_path.parent().unwrap()).unwrap(); fs::create_dir_all(png_path.parent().unwrap()).unwrap();
canvas.save_png(png_path).unwrap(); canvas.save_png(png_path).unwrap();
if let Ok(ref_pixmap) = sk::Pixmap::load_png(ref_path) { if let Ok(ref_pixmap) = sk::Pixmap::load_png(ref_path) {
@ -438,7 +440,7 @@ fn test_part(
println!("Syntax Tree:\n{:#?}\n", source.root()) println!("Syntax Tree:\n{:#?}\n", source.root())
} }
let (local_compare_ref, mut ref_errors) = parse_metadata(&source); let (local_compare_ref, mut ref_errors) = parse_metadata(source);
let compare_ref = local_compare_ref.unwrap_or(compare_ref); let compare_ref = local_compare_ref.unwrap_or(compare_ref);
ok &= test_spans(source.root()); ok &= test_spans(source.root());
@ -482,14 +484,14 @@ fn test_part(
for error in errors.iter() { for error in errors.iter() {
if !ref_errors.contains(error) { if !ref_errors.contains(error) {
print!(" Not annotated | "); print!(" Not annotated | ");
print_error(&source, line, error); print_error(source, line, error);
} }
} }
for error in ref_errors.iter() { for error in ref_errors.iter() {
if !errors.contains(error) { if !errors.contains(error) {
print!(" Not emitted | "); print!(" Not emitted | ");
print_error(&source, line, error); print_error(source, line, error);
} }
} }
} }