* Add dual licensing (AGPL + commercial) Add commercial license option for organizations that cannot comply with AGPL. Contact founders@manaflow.com for details. Updates LICENSE preamble, all README translations, and CONTRIBUTING.md. * Fix AGPL identifier and strengthen contributor license grant - Use AGPL-3.0-or-later (not AGPL-3.0) in all READMEs to match LICENSE - Replace weak "retains the right" clause in CONTRIBUTING.md with explicit contributor license grant for commercial sublicensing --------- Co-authored-by: Lawrence Chen <lawrencecchen@users.noreply.github.com>
3 KiB
3 KiB
Contributing to cmux
Prerequisites
- macOS 14+
- Xcode 15+
- Zig (install via
brew install zig)
Getting Started
-
Clone the repository with submodules:
git clone --recursive https://github.com/manaflow-ai/cmux.git cd cmux -
Run the setup script:
./scripts/setup.shThis will:
- Initialize git submodules (ghostty, homebrew-cmux)
- Build the GhosttyKit.xcframework from source
- Create the necessary symlinks
-
Build and run the debug app:
./scripts/reload.sh
Development Scripts
| Script | Description |
|---|---|
./scripts/setup.sh |
One-time setup (submodules + xcframework) |
./scripts/reload.sh |
Build and launch Debug app |
./scripts/reloadp.sh |
Build and launch Release app |
./scripts/reload2.sh |
Reload both Debug and Release |
./scripts/rebuild.sh |
Clean rebuild |
Rebuilding GhosttyKit
If you make changes to the ghostty submodule, rebuild the xcframework:
cd ghostty
zig build -Demit-xcframework=true -Doptimize=ReleaseFast
Running Tests
Basic tests (run on VM)
ssh cmux-vm 'cd /Users/cmux/GhosttyTabs && xcodebuild -project GhosttyTabs.xcodeproj -scheme cmux -configuration Debug -destination "platform=macOS" build && pkill -x "cmux DEV" || true && APP=$(find /Users/cmux/Library/Developer/Xcode/DerivedData -path "*/Build/Products/Debug/cmux DEV.app" -print -quit) && open "$APP" && for i in {1..20}; do [ -S /tmp/cmux.sock ] && break; sleep 0.5; done && python3 tests/test_update_timing.py && python3 tests/test_signals_auto.py && python3 tests/test_ctrl_socket.py && python3 tests/test_notifications.py'
UI tests (run on VM)
ssh cmux-vm 'cd /Users/cmux/GhosttyTabs && xcodebuild -project GhosttyTabs.xcodeproj -scheme cmux -configuration Debug -destination "platform=macOS" -only-testing:cmuxUITests test'
Ghostty Submodule
The ghostty submodule points to manaflow-ai/ghostty, a fork of the upstream Ghostty project.
Making changes to ghostty
cd ghostty
git checkout -b my-feature
# make changes
git add .
git commit -m "Description of changes"
git push manaflow my-feature
Keeping the fork updated
cd ghostty
git fetch origin
git checkout main
git merge origin/main
git push manaflow main
Then update the parent repo:
cd ..
git add ghostty
git commit -m "Update ghostty submodule"
See docs/ghostty-fork.md for details on fork changes and conflict notes.
License
By contributing to this repository, you agree that:
- Your contributions are licensed under the project's GNU Affero General Public License v3.0 or later (
AGPL-3.0-or-later). - You grant Manaflow, Inc. a perpetual, worldwide, non-exclusive, royalty-free, irrevocable license to use, reproduce, modify, sublicense, and distribute your contributions under any license, including a commercial license offered to third parties.