Skip to content

RLovelett/node-sourcekit

Repository files navigation

node-sourcekit

Build Status npm npm npm License

node-sourcekit is a native C++ wrapper for the SourceKit framework that exposes the SourceKit protocol to Node.js. SourceKit is a framework in the Swift language that provides IDE type features for the Swift language. Features like indexing, syntax-coloring, code-completion. SourceKit currently only supports the Swift language.

This project was created to support vscode-swift and nuclide-swift.

Support

Ideally this project should support all of the platforms that the Swift project supports.

Operating System (or Distro) Node.js Version
macOS (>= 10.11.6) >= 4.4.6
Ubuntu (>= 14.04) >= 4.4.6

TODO

The final goal of the package is to provide 100% support for all the known SourceKit requests. The documentented requests can be found in the SourceKit docs in Protocol.md.

The list of known SourceKit requests yet to to be documented can be found in Swift Bug #2117.

Additionally I would like to provide Typescript type definitions for this project.

Usage

node-sourcekit API SourceKit Protocol
#cursorinfo source.request.cursorinfo

Cursor Info

SourceKit is capable of providing information about a specific symbol at a specific cursor position, or byte offset, in a document.

To gather documentation, SourceKit must be given the fully qualified path to a Swift source document.

Example

// sourcefile.swift
struct Foo {
    let bar: Int
}
const SourceKit = require('node-sourcekit');
let source = '/full/path/to/sourcefile.swift';
let options = {
    sourcefile: source,
    offset: 27,
    compilerargs: [
        source
    ]
};
// `cursorinfo` returns an ES6 `Promise`
SourceKit.cursorinfo(options).then(console.log);
// The output should look similar to:
// { 'key.kind': 'source.lang.swift.decl.struct',
//   'key.name': 'Foo',
//   'key.usr': 's:V7example3Foo',
//   'key.filepath': '/full/path/to/sourcefile.swift',
//   'key.offset': 27,
//   'key.length': 3,
//   'key.typename': 'Foo.Type',
//   'key.annotated_decl': '<Declaration>struct Foo</Declaration>',
//   'key.fully_annotated_decl': '<decl.struct><syntaxtype.keyword>struct</syntaxtype.keyword> <decl.name>Foo</decl.name></decl.struct>',
//   'key.typeusr': '_Tt' }

Development/Contributing

There are a set of tests that are expected to be passing before an contribution will be accepted. To run these checkout the code and then run the following:

npm install
npm test

Xcode

I found an invaluable guide How to debug node.js addons in xcode?.

If you want to be able to debug the C++ code in this project that is the best resource I have found to date.

Getting Started

After I had struggled for awhile I found this series, Getting your C++ to the Web with Node.js by Scott Frees, and I really wish I had found it to start with. It is thorough and wonderful.

The most illuminating in the series, with respect to node-sourcekit, is Part 4: Building an Asynchronous C++ Addon for Node.js using Nan.

Additionally a few other resources I've found can be found here and here.

Hope that helps!

License

MIT License

About

SourceKit bindings for Node.js

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published