rationalize-deps

Rationalize Dependencies

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "rationalize-deps" with this command: npx skills add quickwit-oss/tantivy/quickwit-oss-tantivy-rationalize-deps

Rationalize Dependencies

This skill analyzes Cargo.toml dependencies to identify and remove unused features.

Overview

Many crates enable features by default that may not be needed. This skill:

  • Identifies dependencies with default features enabled

  • Tests if default-features = false works

  • Identifies which specific features are actually needed

  • Verifies compilation after changes

Step 1: Identify the target

Ask the user which crate(s) to analyze:

  • A specific crate name (e.g., "tokio", "serde")

  • A specific workspace member (e.g., "quickwit-search")

  • "all" to scan the entire workspace

Step 2: Analyze current dependencies

For the workspace Cargo.toml (quickwit/Cargo.toml ), list dependencies that:

  • Do NOT have default-features = false

  • Have default features that might be unnecessary

Run: cargo tree -p <crate> -f "{p} {f}" --edges features to see what features are actually used.

Step 3: For each candidate dependency

3a: Check the crate's default features

Look up the crate on crates.io or check its Cargo.toml to understand:

  • What features are enabled by default

  • What each feature provides

Use: cargo metadata --format-version=1 | jq '.packages[] | select(.name == "<crate>") | .features'

3b: Try disabling default features

Modify the dependency in quickwit/Cargo.toml :

From:

some-crate = { version = "1.0" }

To:

some-crate = { version = "1.0", default-features = false }

3c: Run cargo check

Run: cargo check --workspace (or target specific packages for faster feedback)

If compilation fails:

  • Read the error messages to identify which features are needed

  • Add only the required features explicitly: some-crate = { version = "1.0", default-features = false, features = ["needed-feature"] }

  • Re-run cargo check

3d: Binary search for minimal features

If there are many default features, use binary search:

  • Start with no features

  • If it fails, add half the default features

  • Continue until you find the minimal set

Step 4: Document findings

For each dependency analyzed, report:

  • Original configuration

  • New configuration (if changed)

  • Features that were removed

  • Any features that are required

Step 5: Verify full build

After all changes, run:

cargo check --workspace --all-targets cargo test --workspace --no-run

Common Patterns

Serde

Often only needs derive :

serde = { version = "1.0", default-features = false, features = ["derive", "std"] }

Tokio

Identify which runtime features are actually used:

tokio = { version = "1.0", default-features = false, features = ["rt-multi-thread", "macros", "sync"] }

Reqwest

Often doesn't need all TLS backends:

reqwest = { version = "0.11", default-features = false, features = ["rustls-tls", "json"] }

Rollback

If changes cause issues:

git checkout quickwit/Cargo.toml cargo check --workspace

Tips

  • Start with large crates that have many default features (tokio, reqwest, hyper)

  • Use cargo bloat --crates to identify large dependencies

  • Check cargo tree -d for duplicate dependencies that might indicate feature conflicts

  • Some features are needed only for tests - consider using [dev-dependencies] features

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

simple-pr

No summary provided by upstream source.

Repository SourceNeeds Review
General

yuqing-bitable-and-label

Incrementally sync data from XiaoAi API to Feishu Bitable and optionally auto-label records with machine-based type and sentiment annotations.

Registry SourceRecently Updated
General

张律师综合套装

张律师法律AI中台 - 中国首个开源法律AI技能库,涵盖刑事辩护、民商事诉讼、合同审查全流程

Registry SourceRecently Updated