-
-
Notifications
You must be signed in to change notification settings - Fork 661
Haxe haxec haxelib plan
(This is a preliminary plan for implementing a better libary versioning and resolution system.)
There are three executables, each with separate versioning.
haxe
haxec
haxelib
The new default exectuable becomes haxe
, replacing the functionality of Haxeshim. It is fairly simple and takes care of:
- Scope management. It understands the scope convention (see below), using it to resolve compiler versions and library versions. Scope can be overridden with
--lock-file
. - HXML parsing and normalisation. It can parse HXML files.
--next
and--each
are parsed and result in separate calls tohaxec
.-lib
is parsed and resolves to-D
+-cp
(+ optionally extra arguments) based on the scope convention. All paths are resolved to absolute paths.${haxelib}
paths are resolved. - Resolving the default
haxec
version, when one is not specified in the scope. - Allows the new scoping convention and CLI arguments to be used with older versions of
haxe
andhaxelib
.
It does NOT:
- Take care of installing, downloading, or upgrading libraries or compiler versions.
The front end is also usable as a library, to allow embedding the logic of scope resolution into tools like vshaxe.
- Reads
haxelib-lock.json
(if exists). - Reads
<file>
(if called with--lock-file <file>
) which will partially overridehaxelib-lock.json
. - Takes arguments (HXML files and regular arguments).
- Expand HXML files to their actual content (resolve imports, parse out
--next
and--each
). - Resolve
-lib <name>
into-cp <path> -D <name>=<version>
using library resolution below. - Resolve
haxec
binary usinghaxec
resolution. - Calls
haxec
with the expanded arguments.
Here's the format of the lock file as written by the package manager:
{
"mylib": {
"version": "1.5.3",
"path": "${haxelib}/mylib/1.5.3"
"dependencies": ["otherlib"]
}
}
When -lib mylib
is found, the front end will replace it with -D mylib=1.5.3 -cp /path/to/haxelib/mylib/1.5.3
(+ additional arguments from extraArguments.hxml
, if present).
Environment variables can be used in the path
field and are resolved according to the system environment variables. There is a special path for the haxelib
variable: if defined, HAXELIB_LIBRARY_PATH
is used instead, otherwise reads the content of the file ${HOME}/.haxelib
(or its equivalent on other OS).
When there is no haxelib-lock.json
(or override file), libraries are resolved differently:
- if defined,
HAXELIB_LIBRARY_PATH
is used, otherwise read${haxelib}/mylib/.current
- set default path to
${haxelib}/mylib/<current>
The first successful match is used, in order:
-
haxec
library in the overriding--lock-file
-
haxec
library in the defaulthaxelib-lock.json
-
HAXEC_PATH
environment variable -
haxec
in systemPATH
- resolve
haxec
as a haxelib (see library resolution)
The compiler itself is renamed to haxec
. It behaves like the current compiler except that the following CLI arguments are deprecated:
-lib
--each
--next
--cwd
The package manager still has the general functionality of the old manager when running in a directory without a scope (a warning may be emitted when installing globally?). It has the new command haxelib scope init
.
It can also download, install, and select compiler versions (reserved haxelib package haxe
?)
Haxelibs with a dev version haxelib dev lib ...
take priority over any scope-resolved libraries.
The convention is a haxelib-lock.json
file in a project directory. It contains the required field dependencies
, listing library names along with their exact version, which may be:
- haxelib semver
- github/svn URL + commit
- relative path, possibly with environment variables
Both haxe
and haxelib
can be asked to use a different scope with the --lock-file
argument. In this case, the path provided overrides haxelib-lock.json
.
With new versions of haxe
, haxec
, and haxelib
, and assuming a local scope haxelib-lock.json
exists, running haxe build.hxml
will:
- Read the local scope. Normalise
build.hxml
into separate compiler invocations and a list of compiler version + library versions. - Invoke
haxelib
to obtain the path to the required compiler version. - Invoke
haxelib
to obtain the paths and parameters of the required libraries. - Invoke (the correct version of)
haxec
with resolved, absolute paths.
Without a local haxelib-lock.json
the behaviour is the similar, but a global default is used for haxec
, and library versions are determined by referencing the haxelib library path directly (<haxelib library path>/<library name>/.current
).
Learn Haxe: Introduction | Manual | API | Try Haxe | Haxe Library Manager | Code Cookbook
Connect: GitHub | Stack Overflow | Forum | Discord | Gitter | Twitter | Facebook