8.2 KiB
crates.io Naming Conflict - Midstream Crates
Date: 2025-10-27 Status: โ ๏ธ NAMING CONFLICT
๐จ Issue
The Midstream crate names are already taken on crates.io by other packages with different ownership:
| Our Crate | Existing on crates.io | Version | Owner |
|---|---|---|---|
| temporal-compare | โ Exists | 0.5.0 | Different owner |
| nanosecond-scheduler | โ Exists | 0.1.1 | Different owner |
| strange-loop | โ Exists | 0.3.0 | Different owner |
| temporal-attractor-studio | โ Unknown | - | - |
| temporal-neural-solver | โ Unknown | - | - |
| quic-multistream | โ Unknown | - | - |
๐ Discovery
Attempted publication resulted in:
error: crate temporal-compare@0.1.0 already exists on crates.io index
This means:
- Someone else owns these crate names
- We cannot publish under these names
- We need alternative names or approach
๐ Impact on AIMDS
Current Status
โ
aimds-core v0.1.0: Published successfully to crates.io
โ aimds-detection: Cannot publish (depends on temporal-compare)
โ aimds-analysis: Cannot publish (depends on multiple Midstream crates)
โ aimds-response: Cannot publish (depends on strange-loop)
Dependency Tree
aimds-core (โ
published)
โโ No Midstream deps
aimds-detection (โ blocked)
โโ aimds-core (โ
available)
โโ temporal-compare (โ name conflict)
โโ nanosecond-scheduler (โ name conflict)
aimds-analysis (โ blocked)
โโ aimds-core (โ
available)
โโ temporal-attractor-studio (โ unknown)
โโ temporal-neural-solver (โ unknown)
โโ strange-loop (โ name conflict)
aimds-response (โ blocked)
โโ aimds-core (โ
available)
โโ aimds-detection (โ blocked)
โโ aimds-analysis (โ blocked)
โโ strange-loop (โ name conflict)
๐ฏ Solution Options
Option A: Rename Midstream Crates (Recommended)
Rename with unique prefix:
temporal-compareโmidstream-temporal-compareorruv-temporal-comparenanosecond-schedulerโmidstream-schedulerorruv-schedulerstrange-loopโmidstream-strange-looporruv-strange-looptemporal-attractor-studioโmidstream-attractor-studiotemporal-neural-solverโmidstream-neural-solverquic-multistreamโmidstream-quic(might be available)
Pros:
- โ Can publish all crates independently
- โ Midstream available as standalone libraries
- โ Clear ownership and branding
- โ AIMDS can use published versions
Cons:
- โ Requires refactoring all imports
- โ Cargo.toml updates across workspace
- โ Documentation updates
- โ Time investment (~2-4 hours)
Estimated Time: 2-4 hours (rename, update, test, publish)
Option B: Keep Path Dependencies (Current Approach)
Use workspace path dependencies:
[dependencies]
temporal-compare = { path = "../../../crates/temporal-compare" }
nanosecond-scheduler = { path = "../../../crates/nanosecond-scheduler" }
Pros:
- โ No naming conflicts
- โ Fast development iteration
- โ Guaranteed compatibility
- โ Already working locally
Cons:
- โ Users must clone entire Midstream repo
- โ Cannot publish remaining AIMDS crates to crates.io
- โ Harder for users to install
- โ Not standalone packages
Installation for Users:
git clone https://github.com/ruvnet/midstream.git
cd midstream/AIMDS
cargo build --release
Option C: Vendor Dependencies (Not Recommended)
Copy Midstream code into AIMDS crates:
- Inline all temporal-compare code
- Inline all nanosecond-scheduler code
- Remove external dependencies
Pros:
- โ Can publish to crates.io
- โ Standalone AIMDS crates
Cons:
- โ Massive code duplication
- โ Loses upstream updates
- โ Harder to maintain
- โ Larger crate sizes
Not Recommended - defeats purpose of modular design
Option D: Use Different Crates (Not Recommended)
Replace Midstream deps with public alternatives:
- Replace
temporal-comparewith existing crate from crates.io (v0.5.0) - Replace
nanosecond-schedulerwith existing crate (v0.1.1) - Find alternatives for other deps
Pros:
- โ Can publish immediately
- โ Uses established crates
Cons:
- โ Different APIs and functionality
- โ Breaks integration with Midstream
- โ Loses validated performance
- โ Requires major refactoring
Not Recommended - loses core functionality
๐ Recommended Path Forward
Immediate (Current Session)
- โ Keep aimds-core published (already done)
- โ Document naming conflict (this file)
- โ Update AIMDS README with installation via git clone
- โ Test AIMDS locally with path dependencies
- โ Commit and push documentation
Short Term (Next 2-4 hours)
Option A - Rename Midstream Crates:
-
Rename all Midstream crates with
midstream-prefix:# In each Cargo.toml name = "midstream-temporal-compare" # was temporal-compare name = "midstream-scheduler" # was nanosecond-scheduler name = "midstream-strange-loop" # was strange-loop name = "midstream-attractor" # was temporal-attractor-studio name = "midstream-neural-solver" # was temporal-neural-solver name = "midstream-quic" # was quic-multistream -
Update all imports across workspace:
// BEFORE: use temporal_compare::TemporalComparator; // AFTER: use midstream_temporal_compare::TemporalComparator; -
Update AIMDS dependencies:
[dependencies] midstream-temporal-compare = "0.1" midstream-scheduler = "0.1" midstream-strange-loop = "0.1" -
Test and publish:
cargo test --workspace cargo publish (each crate)
๐ Current Workaround
For now, AIMDS works perfectly as a workspace:
# AIMDS/Cargo.toml
[workspace]
members = [
"crates/aimds-core",
"crates/aimds-detection",
"crates/aimds-analysis",
"crates/aimds-response",
]
[workspace.dependencies]
# Local path dependencies work fine
temporal-compare = { path = "../crates/temporal-compare" }
nanosecond-scheduler = { path = "../crates/nanosecond-scheduler" }
# ... etc
Users install via:
git clone https://github.com/ruvnet/midstream.git
cd midstream/AIMDS
cargo build --release
cargo test
๐ฏ Decision Required
Question for project owner: Should we:
A) Rename Midstream crates (2-4 hours investment, full crates.io publication) B) Keep path dependencies (works now, requires git clone for users) C) Hybrid approach (publish only AIMDS-specific code, keep Midstream as git submodule)
๐ Comparison Matrix
| Criteria | Option A (Rename) | Option B (Path Deps) | Option C (Vendor) |
|---|---|---|---|
| crates.io Publication | โ Full | โ ๏ธ Partial | โ Full |
| User Installation | โ Easy | โ ๏ธ Moderate | โ Easy |
| Maintainability | โ Good | โ Good | โ Poor |
| Development Speed | โ ๏ธ Slow | โ Fast | โ Very Slow |
| Code Duplication | โ None | โ None | โ High |
| Time Investment | โ ๏ธ 2-4 hours | โ 0 hours | โ 8+ hours |
| Midstream Updates | โ Easy | โ Easy | โ Manual |
| Standalone Use | โ Yes | โ No | โ Yes |
Recommendation: Option A (Rename) - One-time investment for long-term benefits
๐ Related Documentation
- aimds-core on crates.io: https://crates.io/crates/aimds-core
- Publication Status: docs/AIMDS_PUBLICATION_STATUS.md
- AIMDS README: /workspaces/midstream/AIMDS/README.md
- Midstream Platform: https://github.com/ruvnet/midstream
๐ Timeline
If choosing Option A (Rename):
- Hour 1: Rename Cargo.toml files, update package names
- Hour 2: Update all imports across codebase (find/replace)
- Hour 3: Test compilation, fix remaining issues
- Hour 4: Publish 6 Midstream crates, then 3 AIMDS crates
Total: 4 hours to complete publication
Status: Awaiting decision on path forward.
Current State: aimds-core published โ , remaining crates work via path dependencies โ
๐ค Generated with Claude Code