-
Notifications
You must be signed in to change notification settings - Fork 0
Brackets
Brackets is an opensource code editor for web development. It is mainly developed by Adobe. It works in Mac and Windows. Linux support is working in progress.
Brackets is composed by the following parts:
-
brackets
is the set of HTML/JS/CSS that makes the editor. While there is work on going to make it run in the browser, some features rely on custom JS APIs in the namespace brackets.*. -
brackets-shell
is a native application, built using CEF3, that runsbrackets
. It exposes custom JS APIs and boots up the Node process. -
node process
is still experimental, it can run JS code with native access (as opposed to code frombrackets
), and communicated withbrackets
via websockets.
It's important to note that JS client code from brackets
run inside the web runtime (brackets-shell
), and do not have access to native features. JS node code runs in the node process
and have access to native node extensions.
brackets-shell
exposes the following APIs:
-
brackets.fs.*
: it is an API to access file system, using filepaths and reading data directly. No objects involved, the API consists in a series of functions. JS client code wraps this into a -
brackets.app.*
- Native menu creation. Command dispatching is coupled with the CommandManager JS client code.
- Live browser manipulation. Opens a browser to show updated content being edited.
brackets-shell
have C++ code to open and control a Google Chrome instance. - Quit the application
- Open a certain URL in the default browser
- Other misc functions: enabling dev tools, checking state of node server, showing OS folders, etc.
The brackets
JS client code abstracts brackets.fs into a NativeFileSystemAPI, which mimics the FileSystem API from HTML5 but provide access to the whole filesystem instead of a sandbox.
Brackets extensions are groups of files that provide extra functionality to the Brackets editor.
The basic way to make extensions is to provide code that will be loaded by brackets-shell
together with the JS client code. The extension code can interact with modules from brackets
using brackets.getModule
call, for example, one extension can use var LanguageManager = brackets.getModule('language/LanguageManager')
to register new programming language.
See more in How to write Brackets extensions
A new (experimental) ability for extensions to provide files that will run in node server. The idea is that this JS node code will be able to access native features of the platform using Node core libraries and Node extensions (that can be done in C++). And JS client code (the code that makes the editor) communicates via websockets with the JS node code.
One example: I can make a JS node code that grabs git information about files that are changed and their diff, and make this information via websocket. Then the JS client code exposes a menu item that when click, asks for that information and show a dialog with it.
One reasoning behind having a Node.js server is that it allows easy access to the whole library of extensions already existent, and provides a well known way to create C++ extensions.
Brackets Node Process: Overview for Developers and Research: Node.JS integration which explains the reasons of the integration and the technical decisions.
See also a proposal for API simplifying the way extensions work and interact with each other: https://github.com/adobe/brackets/wiki/Extensions2
Brackets brings the requirement to run custom native code. This enables them to provide whatever interface seems convenient for Brackets extensions. This rules out the Managed and Bootstrapped deployment models.
So we have the following options
-
Embedded model: Change
brackets-shell
to use Cameo WebView code. If the intent is to have a self-contained Cameo library, it will have to provide means to expose new extensions. Since the native UI elements are under application control, it can expose the way it wants. -
Bootstrapped+Native model: Provide a runtime that loads external code dynamically. The nature of the external code we want to use will define which API we expose, for example: whether we want to expose a "native window handler" to the external code.
In both cases, Cameo should provide some kind of API for exposing new native functionality to the JS client code.
- FileSystem access possibilities
- Use Cameo extension capability to provide implementation for
brackets.fs
. - Expose special ability in existing FileSystem local API for requesting a non-sandboxed filesystem.
- Use Cameo extension capability to provide implementation for
- Native menus possibilities, solution depending
- Implement in Cameo runtime a menu API to be used for applications. Chrome has one for extensions that want to add items to context menu, see chrome.contextMenus.
- Use Cameo extension capability to provide implementation. This is a requirement if we go the embedded solution.