SwiftPlantUML-Xcode-Extension
SwiftPlantUML-Xcode-Extension copied to clipboard
Xcode Extension for generating class diagrams from Swift code (powered by PlantUML)
SwiftPlantUML-Xcode-Extension
Generate and view a class diagram for Swift code in Xcode with this extension.
This Source Editor Extension makes use of SwiftPlantUML Swift package. You can also use SwiftPlantUML
as a command-line tool.
Features
- [X] 📊 Create class diagram from Swift file
- [X] 🔦 Create class diagram from selected Swift code
Example
Install
Homebrew
brew install swiftplantumlapp
data:image/s3,"s3://crabby-images/aeda1/aeda14b700920f6092291fadb88d91520864a5d3" alt="Installation through Homebrew"
Alternative
- Download latest SwiftPlantUML package from the Releases.
- Copy SwiftPlantUML to your Applications folder.
Enable Extension
-
Launch SwiftPlantUML.
-
Enable extension in System Preferences > Extensions > Xcode Source Editor > select SwiftPlantUML
Configure
Optional:
data:image/s3,"s3://crabby-images/e03f5/e03f51400645953d0d1e4728b2afdd7180f351d7" alt="Preferences - Elements"
data:image/s3,"s3://crabby-images/20b20/20b200f545c27495fb2a43be2bfac87297069e52" alt="Preferences - Members"
data:image/s3,"s3://crabby-images/20b6c/20b6c7943edab03193553d2f9ad418341c859f1b" alt="Preferences - Others"
Troubleshooting
The command "Open editable diagram in browser" is still busy
Xcode Source Code Extension initialization might take up ~ 30 seconds on initial launch.
If the prompt does not appear within 60 seconds
then check for a crash report related to XPC service in Console app of your MacOS.
data:image/s3,"s3://crabby-images/a6b9b/a6b9b17bc0020b29ac81deb14d8825f010e8f602" alt="CrashReportXPCServiceExample"
If you see such crash report related to fatal error: Loading sourcekitd.framework/Versions/A/sourcekitd failed
please check the installation path of Xcode. If it's installed under /Applications/Xcode.app
, please run:
sudo xcode-select -s /Applications/Xcode.app/Contents/Developer
If it's installed elsewhere, please replace the /Applications/Xcode.app
path in the command above with the location where you've installed Xcode.
Technical Details
This Source Editor Extension makes use of XPC service to run the app sandboxed and use SwiftPlantUML
(and its dependency SourceKitten
). Source Editor Extensions using SourceKitten
(either directly or indirectly) have to either run in a non-sandboxed app (and could not be distributed via the App Store) or use XPC service to outsource the use of SourceKitten
to a different process.
Acknowledgements
These awesome blog posts helped me to dive into Xcode Source Editor Extensions and XPC services
- https://www.vadimbulavin.com/xcode-source-editor-extension-tutorial/
- https://nshipster.com/xcode-source-extensions/
- https://ilya.puchka.me/xcode-source-editor-extension-superpowered-with-sourcekitten/
- https://www.objc.io/issues/14-mac/xpc/