INFO: The Alchemist-Server is in Beta status and the API will most likey change until the first release. Feedback and critic are highly appreciated though.
The Alchemist-Server operates as an informant for a specific desired Elixir Mix project and serves with informations as the following:
- Completion for Modules and functions.
- Documentation lookup for Modules and functions.
- Code evaluation and quoted representation of code.
- Definition lookup of code.
- Listing of all available Mix tasks.
- Listing of all available Modules with documentation.
The server needs to be started inside an Elixir mix project, it can be started in two ways:
$ cd elixir_project
$ elixir path/to/alchemist-server/run.exs --env=dev
In this mode, when input sent to a running server process it
responds by sending information back to the STDOUT
.
A request consisting of two parts, the request type and the request arguments.
Example for a completion request:
[type] [arguments]
COMP { "def", [ context: Elixir, imports: [Enum], aliases: [{MyList, List}] ] }
$ cd elixir_project
$ elixir path/to/alchemist-server/run.exs --env=dev --listen
ok|localhost:/tmp/alchemist-server-1500797742260403000.sock
In this mode, when a client connects to the port, it responds by sending information back to the opened connection
Example for a completion request:
$ nc -U /tmp/alchemist-server-1500797742260403000.sock
COMP { "def", [ context: Elixir, imports: [Enum], aliases: [{MyList, List}] ] }
Unix domain socket is introduced since OTP 19.
Return a completion list of all the available candidates.
COMP
COMP { "def", [ context: Elixir, imports: [], aliases: [] ] }
COMP { "List.fla", [ context: Elixir, imports: [], aliases: [] ] }
Return the documentation.
DOCL { "defmodule", [ context: Elixir, imports: [], aliases: [] ] }
DOCL { "List.flatten/1", [ context: Elixir, imports: [], aliases: [] ] }
Return the evaluation result of the code from the file.
EVAL { :eval, 'path/to/file/which/holds/content/to/eval.tmp' }
Return the code from the file quoted.
EVAL { :quote, 'path/to/file/which/holds/content/to/quote.tmp' }
Return the code from the file expanded.
EVAL { :expand, 'path/to/file/which/holds/content/to/expand.tmp' }
Return the code from the file expanded once.
EVAL { :expand_once, 'path/to/file/which/holds/content/to/expand_once.tmp' }
Return the path to the source file which holds the definition.
DEFL { "List,flatten", [ context: Elixir, imports: [], aliases: [] ] }
DEFL { "nil,defmacro", [ context: Elixir, imports: [], aliases: [] ] }
DEFL { "nil,create_file", [ context: Elixir, imports: [Mix.Generator], aliases: [] ] }
DEFL { "MyList,nil", [ context: Elixir, imports: [], aliases: [{MyList, List}] ] }
Return a list of all available mix tasks.
INFO { :type, :mixtasks }
Return a list of all available modules which has documentation.
INFO { :type, :modules }
Return information about any datatype.
INFO { :type, :info, List }
Return types for a module or function/arity pair.
INFO { :type, :types, 'List' }
INFO { :type, :types, 'Enum.t' }
INFO { :type, :types, 'Agent.on_start/0' }
Return PONG as response, it can be used for purpose of debugging and checking server's availability.
PING
Each request type ends with a specific end marker tag to notify that the request is done.
An end tag looks like the following:
END-OF-<REQUEST TYPE>
For example, after the following request an end tag would look like this:
INFO { :type, :modules }
List
String
Enum
.
...
....
END-OF-INFO