From 977fc5fcebcfffbe20ee66300f5485ecefa43bce Mon Sep 17 00:00:00 2001 From: "adria0.eth" <5526331+adria0@users.noreply.github.com> Date: Tue, 24 Sep 2024 07:29:43 +0200 Subject: [PATCH] feat: typos check in CI (#362) --- .github/workflows/ci.yml | 44 +++++++---- README.md | 2 +- book/src/user/experimental-features.md | 4 +- halo2_backend/src/plonk.rs | 2 +- halo2_backend/src/plonk/evaluation.rs | 6 +- halo2_backend/src/plonk/prover.rs | 73 ++++++++++--------- halo2_frontend/src/dev.rs | 6 +- halo2_frontend/src/dev/cost_model.rs | 4 +- .../src/plonk/circuit/constraint_system.rs | 4 +- halo2_middleware/src/zal.rs | 2 +- halo2_proofs/CHANGELOG.md | 2 +- halo2_proofs/tests/frontend_backend_split.rs | 2 +- p3_frontend/src/fwrap.rs | 2 +- p3_frontend/src/lib.rs | 2 +- typos.toml | 7 ++ 15 files changed, 93 insertions(+), 69 deletions(-) create mode 100644 typos.toml diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 5d92f02ffb..8d99826362 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -8,6 +8,36 @@ on: - main jobs: + + fmt: + name: Rustfmt + timeout-minutes: 30 + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - uses: actions-rs/toolchain@v1 + with: + override: false + - run: rustup component add rustfmt + - uses: actions-rs/cargo@v1 + with: + command: fmt + args: --all -- --check + + typos-check: + needs: [skip_check] + if: | + github.event.pull_request.draft == false && + (github.event.action == 'ready_for_review' || needs.skip_check.outputs.should_skip != 'true') + name: TyposCheck + timeout-minutes: 5 + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: crate-ci/typos@v1.22.7 + with: + config: ./typos.toml + isolated: true test: name: Test on ${{ matrix.os }} with ${{ matrix.feature_set }} features runs-on: ${{ matrix.os }} @@ -101,18 +131,4 @@ jobs: command: doc args: --all --document-private-items - fmt: - name: Rustfmt - timeout-minutes: 30 - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - uses: actions-rs/toolchain@v1 - with: - override: false - - run: rustup component add rustfmt - - uses: actions-rs/cargo@v1 - with: - command: fmt - args: --all -- --check diff --git a/README.md b/README.md index 432b986072..da609a1395 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ This repository contains the [halo2](https://github.com/zcash/halo2) fork from PSE and includes contributions from the community. We use the `main` branch for development, which means it may contain -unstable/unfinished features. For end-users we recomend using the tag releases +unstable/unfinished features. For end-users we recommend using the tag releases which can be seen as curated checkpoints with some level of guarantee of stability. diff --git a/book/src/user/experimental-features.md b/book/src/user/experimental-features.md index 5677fd38b9..b64b9cbc2c 100644 --- a/book/src/user/experimental-features.md +++ b/book/src/user/experimental-features.md @@ -24,11 +24,11 @@ When using `create_proof` and `verify_proof`, we need to specify the commitment create_proof, ProverIPA<_>, _, _, _, _> verify_proof, ProverIPA<_>, _, _, _> -// Using KZG with GWC19 mutli-open strategy +// Using KZG with GWC19 multi-open strategy create_proof, ProverGWC<_>, _, _, _, _> verify_proof, ProverGWC<_>, _, _, _> -// Using KZG with BDFG20 mutli-open strategy +// Using KZG with BDFG20 multi-open strategy create_proof, ProverSHPLONK<_>, _, _, _, _> verify_proof, ProverSHPLONK<_>, _, _, _> ``` diff --git a/halo2_backend/src/plonk.rs b/halo2_backend/src/plonk.rs index ee34d50e3d..b4039421d7 100644 --- a/halo2_backend/src/plonk.rs +++ b/halo2_backend/src/plonk.rs @@ -117,7 +117,7 @@ where return Err(io::Error::new( io::ErrorKind::InvalidData, format!( - "circuit size value (k): {} exceeds maxium: {}", + "circuit size value (k): {} exceeds maximum: {}", k, C::Scalar::S ), diff --git a/halo2_backend/src/plonk/evaluation.rs b/halo2_backend/src/plonk/evaluation.rs index 09d8b452d3..f22f6542b7 100644 --- a/halo2_backend/src/plonk/evaluation.rs +++ b/halo2_backend/src/plonk/evaluation.rs @@ -174,11 +174,11 @@ impl Calculation { /// Evaluator #[derive(Clone, Default, Debug)] pub(crate) struct Evaluator { - /// Custom gates evalution + /// Custom gates evaluation custom_gates: GraphEvaluator, - /// Lookups evalution + /// Lookups evaluation lookups: Vec>, - /// Shuffle evalution + /// Shuffle evaluation shuffles: Vec>, } diff --git a/halo2_backend/src/plonk/prover.rs b/halo2_backend/src/plonk/prover.rs index af72d863d8..81bf3cd010 100644 --- a/halo2_backend/src/plonk/prover.rs +++ b/halo2_backend/src/plonk/prover.rs @@ -489,10 +489,10 @@ impl< /// Finalizes the proof creation. /// The following steps are performed: - /// - 1. Generate commited lookup polys - /// - 2. Generate commited permutation polys - /// - 3. Generate commited lookup polys - /// - 4. Generate commited shuffle polys + /// - 1. Generate committed lookup polys + /// - 2. Generate committed permutation polys + /// - 3. Generate committed lookup polys + /// - 4. Generate committed shuffle polys /// - 5. Commit to the vanishing argument's random polynomial /// - 6. Generate the advice polys /// - 7. Evaluate the h(X) polynomial @@ -523,7 +523,7 @@ impl< .map(|index| challenges.remove(&index).unwrap()) .collect::>(); - // 1. Generate commited ( added to transcript ) lookup polys --------------------------------------- + // 1. Generate committed ( added to transcript ) lookup polys --------------------------------------- // Sample theta challenge for keeping lookup columns linearly independent // [TRANSCRIPT-5] @@ -574,9 +574,9 @@ impl< // [TRANSCRIPT-8] let gamma: ChallengeGamma<_> = self.transcript.squeeze_challenge_scalar(); - // 2. Generate commited permutation polys ----------------------------------------- + // 2. Generate committed permutation polys ----------------------------------------- // [TRANSCRIPT-9] - let permutations_commited: Vec> = instances + let permutations_committed: Vec> = instances .iter() .zip(advices.iter()) .map(|(instance, advice)| { @@ -597,34 +597,35 @@ impl< }) .collect::, _>>()?; - // 3. Generate commited lookup polys ---------------------------------------------------------- + // 3. Generate committed lookup polys ---------------------------------------------------------- // [TRANSCRIPT-10] - let lookups_commited: Vec>> = permuted_lookups - .into_iter() - .map(|lookups| -> Result, _> { - // Construct and commit to products for each lookup - lookups - .into_iter() - .map(|lookup| { - lookup.commit_product( - &self.engine, - pk, - params, - beta, - gamma, - &mut rng, - self.transcript, - ) - }) - .collect::, _>>() - }) - .collect::, _>>()?; + let lookups_committed: Vec>> = + permuted_lookups + .into_iter() + .map(|lookups| -> Result, _> { + // Construct and commit to products for each lookup + lookups + .into_iter() + .map(|lookup| { + lookup.commit_product( + &self.engine, + pk, + params, + beta, + gamma, + &mut rng, + self.transcript, + ) + }) + .collect::, _>>() + }) + .collect::, _>>()?; - // 4. Generate commited shuffle polys ------------------------------------------------------- + // 4. Generate committed shuffle polys ------------------------------------------------------- // [TRANSCRIPT-11] - let shuffles_commited: Vec>> = instances + let shuffles_committed: Vec>> = instances .iter() .zip(advices.iter()) .map(|(instance, advice)| -> Result, _> { @@ -703,9 +704,9 @@ impl< *beta, *gamma, *theta, - &lookups_commited, - &shuffles_commited, - &permutations_commited, + &lookups_committed, + &shuffles_committed, + &permutations_committed, ); // 8. Construct the vanishing argument's h(X) commitments -------------------------------------- @@ -796,7 +797,7 @@ impl< // Evaluate the permutations, if any, at omega^i x. // [TRANSCRIPT-21] let permutations_evaluated: Vec> = - permutations_commited + permutations_committed .into_iter() .map(|permutation| -> Result<_, _> { permutation.evaluate(pk, x, self.transcript) }) .collect::, _>>()?; @@ -804,7 +805,7 @@ impl< // Evaluate the lookups, if any, at omega^i x. // [TRANSCRIPT-22] let lookups_evaluated: Vec>> = - lookups_commited + lookups_committed .into_iter() .map(|lookups| -> Result, _> { lookups @@ -817,7 +818,7 @@ impl< // Evaluate the shuffles, if any, at omega^i x. // [TRANSCRIPT-23] let shuffles_evaluated: Vec>> = - shuffles_commited + shuffles_committed .into_iter() .map(|shuffles| -> Result, _> { shuffles diff --git a/halo2_frontend/src/dev.rs b/halo2_frontend/src/dev.rs index e08690d267..98657d2919 100644 --- a/halo2_frontend/src/dev.rs +++ b/halo2_frontend/src/dev.rs @@ -1514,7 +1514,7 @@ mod tests { #[cfg(feature = "lookup-any-sanity-checks")] #[test] #[should_panic( - expected = "pair of tagging expressions(query of the tag columns or mutiple query combinations) should be included" + expected = "pair of tagging expressions(query of the tag columns or multiple query combinations) should be included" )] fn bad_lookup_any_not_add_tagging_pairs() { const K: u32 = 4; @@ -2007,7 +2007,7 @@ mod tests { } #[test] - fn contraint_unsatisfied() { + fn constraint_unsatisfied() { const K: u32 = 4; #[derive(Clone)] @@ -2250,7 +2250,7 @@ mod tests { instance[0] = InstanceValue::Assigned(Fp::from(11)); assert_eq!(prover.verify(), Err(vec![err2.clone()])); - // then we modify the witness -> the contraint `squared` will fail + // then we modify the witness -> the constraint `squared` will fail let advice0 = prover.advice_mut(0); advice0[2] = CellValue::Assigned(Fp::from(10)); assert_eq!(prover.verify(), Err(vec![err1, err2])); diff --git a/halo2_frontend/src/dev/cost_model.rs b/halo2_frontend/src/dev/cost_model.rs index 86ce03800a..49bec78197 100644 --- a/halo2_frontend/src/dev/cost_model.rs +++ b/halo2_frontend/src/dev/cost_model.rs @@ -16,9 +16,9 @@ use super::MockProver; pub enum CommitmentScheme { /// Inner Product Argument commitment scheme IPA, - /// KZG with GWC19 mutli-open strategy + /// KZG with GWC19 multi-open strategy KZGGWC, - /// KZG with BDFG20 mutli-open strategy + /// KZG with BDFG20 multi-open strategy KZGSHPLONK, } diff --git a/halo2_frontend/src/plonk/circuit/constraint_system.rs b/halo2_frontend/src/plonk/circuit/constraint_system.rs index b5b6a42912..ad09077a7b 100644 --- a/halo2_frontend/src/plonk/circuit/constraint_system.rs +++ b/halo2_frontend/src/plonk/circuit/constraint_system.rs @@ -445,7 +445,7 @@ impl ConstraintSystem { panic!("all table expressions need selector/fixed query for tagging"); } if !is_tagging_exprs_pair_exists { - panic!("pair of tagging expressions(query of the tag columns or mutiple query combinations) should be included"); + panic!("pair of tagging expressions(query of the tag columns or multiple query combinations) should be included"); } } @@ -953,7 +953,7 @@ impl ConstraintSystem { tmp } - /// Helper funciotn to assert phase exists, to make sure phase-aware resources + /// Helper function to assert phase exists, to make sure phase-aware resources /// are allocated in order, and to avoid any phase to be skipped accidentally /// to cause unexpected issue in the future. fn assert_phase_exists(&self, phase: sealed::Phase, resource: &str) { diff --git a/halo2_middleware/src/zal.rs b/halo2_middleware/src/zal.rs index b6cf37229a..8ad352d79d 100644 --- a/halo2_middleware/src/zal.rs +++ b/halo2_middleware/src/zal.rs @@ -71,7 +71,7 @@ pub mod traits { // Descriptors are opaque pointers that hold the input in a format suitable for the accelerator engine. // They may be: // - Input moved on accelerator device (only once for repeated calls) - // - Endianess conversion + // - Endianness conversion // - Converting from Montgomery to Canonical form // - Input changed from Projective to Jacobian coordinates or even to a Twisted Edwards curve. // - other form of expensive preprocessing diff --git a/halo2_proofs/CHANGELOG.md b/halo2_proofs/CHANGELOG.md index a70020222b..ac6dc33c98 100644 --- a/halo2_proofs/CHANGELOG.md +++ b/halo2_proofs/CHANGELOG.md @@ -132,7 +132,7 @@ All APIs that represented witnessed values as `Option` now represent them as directly, and returns `VerificationStrategy::Output` instead of `Guard`. - `ConstraintSystem::enable_equality` and `ConstraintSystem::query_any` now take `Into>` instead of `Column` as a parameter to avoid - excesive `.into()` usage. + excessive `.into()` usage. - `Error` has been overhauled: - `Error` now implements `std::fmt::Display` and `std::error::Error`. - `Error` no longer implements `PartialEq`. Tests can check for specific diff --git a/halo2_proofs/tests/frontend_backend_split.rs b/halo2_proofs/tests/frontend_backend_split.rs index a3b461afb8..4988139910 100644 --- a/halo2_proofs/tests/frontend_backend_split.rs +++ b/halo2_proofs/tests/frontend_backend_split.rs @@ -43,7 +43,7 @@ struct MyCircuitConfig { s_lookup: Column, s_ltable: Column, - // A shuffle: s_shufle * [1, a[0]] shuffle_of s_stable * [1, b[0]] + // A shuffle: s_shuffle * [1, a[0]] shuffle_of s_stable * [1, b[0]] s_shuffle: Column, s_stable: Column, diff --git a/p3_frontend/src/fwrap.rs b/p3_frontend/src/fwrap.rs index 4106027da3..fd71f39c69 100644 --- a/p3_frontend/src/fwrap.rs +++ b/p3_frontend/src/fwrap.rs @@ -239,7 +239,7 @@ impl p3PrimeField for FWrap { } // HACK: In general an `FWrap` will need more than 64 bits. This trait is only implemented in -// order to use `FWrap` with witness generation from plonky3 that requries this trait but doesn't +// order to use `FWrap` with witness generation from plonky3 that requires this trait but doesn't // use the order. Do not use an `ff::PrimeField` on a circuit that requires a 64 bit prime field // (i.e. relies on the `ORDER_U64` value), only use it on circuits that always assign less than 64 // bit values on the field elements. diff --git a/p3_frontend/src/lib.rs b/p3_frontend/src/lib.rs index 947b9bb832..01789918c9 100644 --- a/p3_frontend/src/lib.rs +++ b/p3_frontend/src/lib.rs @@ -144,7 +144,7 @@ where } // Check if the constraint is an equality against a public input and extract the copy constraint as -// `(advice_column_index, Location)` and `public_index`. If there's no copy constriant, return +// `(advice_column_index, Location)` and `public_index`. If there's no copy constraint, return // None. fn extract_copy_public( e: &SymbolicExpression>, diff --git a/typos.toml b/typos.toml new file mode 100644 index 0000000000..1561732dd3 --- /dev/null +++ b/typos.toml @@ -0,0 +1,7 @@ +[default] +extend-ignore-re=[ + "master-thm", + "[aA]dvices", + "projectives" +] +check-filename = true