Requirements: macOS 14.0+, Xcode 15+. Optional: SwiftLint, SwiftFormat, GitHub CLI (gh).
Fork the repo on GitHub, then:
git clone https://github.com/<your-fork>/TablePro.git && cd TablePro
scripts/download-libs.sh
touch Secrets.xcconfig
brew install swiftlint swiftformatBuild:
xcodebuild -project TablePro.xcodeproj -scheme TablePro -configuration Debug build -skipPackagePluginValidationTests:
xcodebuild -project TablePro.xcodeproj -scheme TablePro test -skipPackagePluginValidation.swiftlint.yml and .swiftformat are the source of truth. The short version:
- 4-space indent, 120-char lines
- Explicit access control (
private,internal,public) - No force unwraps (
!) or force casts (as!) String(localized:)for user-facing strings- OSLog only, no
print()
Before committing:
swiftlint lint --strict
swiftformat .Conventional Commits, single line, no body.
feat: add CSV export for query results
fix: prevent crash on empty query result
docs: update keyboard shortcuts page
Branch off main:
feat/add-cassandra-supportfix/query-editor-crashdocs/update-keyboard-shortcuts
One logical change per PR. Make sure tests pass and lint is clean.
Checklist:
- Tests added or updated
-
CHANGELOG.mdupdated under[Unreleased](skip for unreleased-only fixes) - Docs updated in
docs/if the change affects user-facing behavior - User-facing strings localized
- No SwiftLint/SwiftFormat violations
TablePro/ App source (Core/, Views/, Models/, ViewModels/, Extensions/, Theme/)
Plugins/ .tableplugin bundles + TableProPluginKit framework
Libs/ Pre-built static libraries (downloaded via script, not in git)
TableProTests/ Tests
docs/ Mintlify docs site
scripts/ Build and release scripts
Drivers are .tableplugin bundles loaded at runtime. Create a new bundle under Plugins/, implement DriverPlugin + PluginDatabaseDriver from TableProPluginKit, and add the target to the Xcode project.
Full guide: docs/development/plugin-registry
Open a GitHub issue with:
- macOS version
- TablePro version
- Reproduction steps
- Database type and version (for database-specific bugs)
Sign the Contributor License Agreement on your first PR. The CLA bot walks you through it. One-time thing.
Contributions are licensed under AGPLv3.