-
-
Notifications
You must be signed in to change notification settings - Fork 41
Contribute to the extension
The extension is divided into two parts.
-
The entry point launched by VSCode is
src/ts/extension.ts
, written in TypeScript. This part is mainly used to launch the Java language server in a separate process. There are a few things that the language server protocol can't do, like define commands, so there is some extra stuff in there too. However, the most important part ofextension.ts
is spawning the new process. -
The part written in Java that is spawned in a separate process is the language server. When VSCode needs to do something that requires language intelligence (like completion, signature help, find references, jump to symbol, etc.), it makes requests to the language server. It uses a special socket protocol for communication, which is implemented by the Eclipse LSP4J Java library, so it's all behind the scenes. Our job is simply to write implementations for methods defined by LSP4J's interfaces. These methods will get called automatically when VSCode makes a request.
Here's what each of the Java classes do:
This is the entry point of the JAR. It sets up the socket that communicates with VSCode and instantiates the ActionScriptLanguageServer class.
This class implements the org.eclipse.lsp4j.services.LanguageServer
interface defined by LSP4J. It's purpose is mostly to tell VSCode about the language server's capabilities.
- The
initialize()
method is used to declare which feature the language server supports. -
getWorkspaceService()
returns an object that mostly delegates to theTextDocumentService
(see below), where the bulk of everything happens. This could probably be a little cleaner, but it works well enough. -
getTextDocumentService()
returnscom.nextgenactionscript.vscode.ActionScriptTextDocumentService
, an implementation ofTextDocumentService
.
This class implements the org.eclipse.lsp4j.services.TextDocumentService
interface defined by LSP4J. It's methods will be called when VSCode makes requests over the language server protocol. The purpose of methods like completion()
, signatureHelp()
, definition()
, references()
, and rename()
(among others) should be pretty obvious.
From the compiler, this class creates a Workspace
and a FlexJSProject
. It parses the asconfig.json
file to get the compiler configuration options. To get the definitions, ActionScriptTextDocumentService
creates invisible compilation units for the main class(es) in an app, and the compiler finds all of its dependencies and creates regular compilation units automatically. Everything stays in memory between requests, and VSCode tells the language server when any ActionScript files are added, removed, or changed. This results in calls to fileAdded()
, fileRemoved()
, and fileChanged()
on the Workspace
, which will update only the compilation units that have changed. Making a new Workspace
and starting fresh with every request from VSCode does not offer good enough performance for larger projects.
Implements the org.apache.flex.compiler.common.IFileSpecificationGetter
interface from the compiler. Returns an implementation of org.apache.flex.compiler.filespecs.IFileSpecification
for a specific file path. If a file is open in memory, it returns a org.apache.flex.compiler.filespecs.StringFileSpecification
, and if it's only on the file system, it's a regular org.apache.flex.compiler.filespecs.FileSpecification
. VSCode notifies the language server about files in memory with didOpen()
, didClose()
, didSave()
, and didChange()
on the ActionScriptTextDocumentService
class.
The classes in this package store data from asconfig.json
.
You will need Apache Maven, which will automatically download dependencies and build the extension. To debug the extension, you need Visual Studio Code, obviously.
Open the root folder of the repository in Visual Studio Code. Switch to the Debug view. Make sure that "Launch Extension" is selected in the drop-down. Click the green play button to start debugging in VSCode's Extension Host. VSCode will automatically build the project before launching.
To build from the command line, run the following command in the root folder of the repository:
mvn clean package
-
Open the Debug view in Visual Studio Code.
-
Select Launch Extension in the drop down.
-
Press the green play button to start debugging. You may also press the
F5
key.
When you run the extension in the Visual Studio Code debugger, you can launch the Java process with the following extra argument (requires modification to extension.ts
:
-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005
This allows remote debugging over port 5005.
In IntelliJ IDEA, you can add a new Remote configuration to your module with the following settings:
- Transport: Socket
- Debugger Mode: Attach
- Host: localhost
- Port: 5005
After launching the extension, start debugging in IntelliJ IDEA. It should attach to the running Java process.
- Adobe AIR (Mobile)
- Adobe AIR (Desktop)
- Adobe Flash Player
- Apache Royale
- HTML and JS (no framework)
- Node.js
- Feathers SDK
- Adobe Animate
- Classic Flex SDK
- Library (SWC)
- Royale Library (SWC)