SourceKittenDaemon
Swift Auto Completion Helper
This is a simple daemon that can read Xcode Swift projects and offers auto completion for Swift files and more over a built-in webserver. Effectively, this allows any kind of editor like Vim, Emacs, Sublime, or Atom to support Swift, Auto Completion, and Xcode projects.
It includes an example, very simple, Xcode like, editor (see SwiftCode folder) which explains how to use / embedd the actual SourceKittenDaemon.
Here's a video showing the example editor in action:
Features
- Get completions for current position in document
- Get completions for edited, unsaved files (via temporary files)
- Return files in project
- Parse Xcode project and understand compiler arguments, targets, etc
- Communication over http for easy integration in various editors
SourceKit
This app uses the fantastic SourceKitten framework without which none of this would be possible. SourceKittenDaemon is really just a small wrapper that keeps an Xcode Project indexer running and offers a nice way to query Xcode Project properties and completions via a comfortable interface.
Using It
Have a look at the Protocol.org file, which explains how to start and use the daemon.
Building / Installation
PKG
You'll find an installable package under the releases tab
Homebrew
(Coming Soon)
Source
- Clone the repository
- Install via
make install
SwiftCode Example Editor
You'll find a zip file under the releases tab
Using it in an editor
Have a look at the SwiftCode example project, or at the existing editor integrations (below). Alternatively, the communication protocol is outlined in the Protocol.org file in this repository.
Editor Integrations
Emacs
SourceKittenDaemon is used in the company-sourcekit Emacs Swift plugin:
Atom
autocomplete-swift is a working Atom plugin offering Swift auto completion support via SourceKittenDaemon.
TextMate
There's a working implementation for TextMate here.
SwiftCode
This is a very simple, featureless reference implementation to see how to embed SourceKittenDaemon into an editor. It offers:
- Reading Xcode Projects
- Selecting / Editing / Saving files
- Getting completions for files either when you enter a "." or when you hit the ESC key.
This is a very simple editor and no sane person should try to write code with it. It is only meant to show how to embed the daemon.
Linux
Linux support is currently in development. If you're interested in helping out, here're the steps to run it on Linux:
- Install docker
- Install the Swift Dockerfile (i.e.
docker pull ibmcom/swift-ubuntu
) - Run
make linuxtest
Troubleshooting
Byte offset vs character offset
The X-Offset
header takes a byte offset as opposed to a character
offset. For most characters this will make no difference. However special
characters such as ยฉ
are counted as two bytes is
UTF8. See this issue for more details.
Thanks
- A lot of thanks go to Nathan Kot who wrote most parts of this.
- Tomoya Kose for updating the project so it works with Homebrew again