mirror of
https://github.com/apple/pkl.git
synced 2026-03-17 23:03:54 +01:00
Add support for Windows (#492)
This adds support for Windows. The in-language path separator is still `/`, to ensure Pkl programs are cross-platform. Log lines are written using CRLF endings on Windows. Modules that are combined with `--module-output-separator` uses LF endings to ensure consistent rendering across platforms. `jpkl` does not work on Windows as a direct executable. However, it can work with `java -jar jpkl`. Additional details: * Adjust git settings for Windows * Add native executable for pkl cli * Add jdk17 windows Gradle check in CI * Adjust CI test reports to be staged within Gradle rather than by shell script. * Fix: encode more characters that are not safe Windows paths * Skip running tests involving symbolic links on Windows (these require administrator privileges to run). * Introduce custom implementation of `IoUtils.relativize` * Allow Gradle to initialize ExecutableJar `Property` values * Add Gradle flag to enable remote JVM debugging Co-authored-by: Philip K.F. Hölzenspies <holzensp@gmail.com>
This commit is contained in:
@@ -2140,9 +2140,18 @@ For example, a module with URI `modulepath:/animals/birds/pigeon.pkl`
|
||||
can import `modulepath:/animals/birds/parrot.pkl`
|
||||
with `import "parrot.pkl"` or `import "/animals/birds/parrot.pkl"`.
|
||||
|
||||
NOTE: When importing a relative folder or file that starts with `@`, the import string must be prefixed with `./`.
|
||||
Otherwise, this syntax will be interpreted as dependency notation.
|
||||
[NOTE]
|
||||
.Paths on Windows
|
||||
====
|
||||
Relative paths use the `/` character as the directory separator on all platforms, including Windows.
|
||||
|
||||
Paths that contain drive letters (e.g. `C:`) must be declared as an absolute file URI, for example: `import "file:///C:/path/to/my/module.pkl"`. Otherwise, they are interpreted as a URI scheme.
|
||||
====
|
||||
|
||||
NOTE: When importing a relative directory or file that starts with `@`, the import string must be prefixed with `./`.
|
||||
Otherwise, this syntax will be interpreted as xref:dependency-notation[dependency notation].
|
||||
|
||||
[#dependency-notation]
|
||||
==== Dependency notation URIs
|
||||
|
||||
Example: `+@birds/bird.pkl+`
|
||||
|
||||
Reference in New Issue
Block a user