Skip to content

Commit

Permalink
Implement boot bindings support.
Browse files Browse the repository at this point in the history
Now commands can depend on `{boot.bindings.<binding name>}` placeholders
which are satisfied by boot bindings commands that are run exactly once.

This is used in the Python example to produce a scie-pants Pants binary
that prepares a fully pre-compiled Pants venv that runs at the full
speed of a native Pants venv. The boot binding command that creates the
venv also uses a private PEX_ROOT and cleans this up in addition to the
Pants PEX used to build the venv. The result is an ~/.nce with just the
CPython interpreter and a venv that symlinks to it. There is no wasted
speed or space as compared to a traditional Pants Python venv (save for
the size of the scie binary itself which may be addressed by a-scie#9 or a-scie#19).

Closes a-scie#7
Closes a-scie#20
  • Loading branch information
jsirois committed Nov 9, 2022
1 parent 0e359df commit 0cf93b0
Show file tree
Hide file tree
Showing 14 changed files with 455 additions and 260 deletions.
8 changes: 5 additions & 3 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -60,11 +60,13 @@ jobs:
set -x
examples/prepare.sh python
dist/scie-jump* examples/python/lift.${{ matrix.arch }}.json
time RUST_LOG=trace ./pants --no-pantsd -V
time ./pants --no-pantsd -V
touch BUILDROOT
time RUST_LOG=trace ./scie-pants --no-pantsd -V
time RUST_LOG=debug ./scie-pants --no-pantsd -V
# Use the built-in BusyBox functionality via env var.
SCIE_BOOT=inspect ./pants interpreter --verbose --indent 2
SCIE_BOOT=repl ./scie-pants -c 'from pants.util import strutil; print(strutil.__file__)'
- name: Java Example (Coursier)
if: contains(matrix.examples, 'java')
run: |
Expand Down
17 changes: 17 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

37 changes: 26 additions & 11 deletions examples/python/lift.linux-x86_64.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"scie": {
"lift": {
"name": "pants",
"name": "scie-pants",
"description": "The ergonomic build system.",
"boot": {
"commands": {
Expand All @@ -10,34 +10,49 @@
"env": {
"=PATH": "{cpython}/python/bin:{scie.env.PATH}"
},
"exe": "{cpython}/python/bin/python3.9",
"exe": "{scie.bindings.venv}/venv/bin/python3.9",
"args": [
"{pants.2.14.0.pex}"
"{scie.bindings.venv}/venv/pex"
]
},
"inspect": {
"description": "PEX tools for Pants.",
"repl": {
"description": "A Python repl with Pants (minus plugins) available for inspection.",
"env": {
"=PATH": "{cpython}/python/bin:{scie.env.PATH}",
"PEX_TOOLS": "1"
},
"exe": "{scie.bindings.venv}/venv/bin/python3.9"
}
},
"bindings": {
"venv": {
"description": "Installs Pants in a venv and pre-compiles .pyc.",
"env": {
"=PATH": "{cpython}/python/bin:{scie.env.PATH}",
"PEX_TOOLS": "1",
"PEX_ROOT": "{scie.bindings}/pex_root"
},
"exe": "{cpython}/python/bin/python3.9",
"args": [
"{pants.2.14.0.pex}"
"{pants.2.14.0.pex}",
"venv",
"--bin-path",
"prepend",
"--compile",
"--rm",
"all",
"{scie.bindings}/venv"
]
}
}
},
"files": [
{
"name": "cpython-3.9.14+20221002-x86_64-unknown-linux-gnu-install_only.tar.gz",
"key": "cpython",
"hash": "e63d0c00a499e0202ba7a0f53ce69fca6d30237af39af9bc3c76bce6c7bf14d7",
"size": 26761725
"key": "cpython"
},
{
"name": "pants.2.14.0.pex",
"type": "zip"
"name": "pants.2.14.0.pex"
}
]
}
Expand Down
30 changes: 24 additions & 6 deletions examples/python/lift.macos-x86_64.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"scie": {
"lift": {
"name": "pants",
"name": "scie-pants",
"description": "The ergonomic build system.",
"boot": {
"commands": {
Expand All @@ -10,20 +10,38 @@
"env": {
"=PATH": "{cpython}/python/bin:{scie.env.PATH}"
},
"exe": "{cpython}/python/bin/python3.9",
"exe": "{scie.bindings.venv}/venv/bin/python3.9",
"args": [
"{pants.2.14.0.pex}"
"{scie.bindings.venv}/venv/pex"
]
},
"inspect": {
"description": "PEX tools for Pants.",
"repl": {
"description": "A Python repl with Pants (minus plugins) available for inspection.",
"env": {
"=PATH": "{cpython}/python/bin:{scie.env.PATH}",
"PEX_TOOLS": "1"
},
"exe": "{scie.bindings.venv}/venv/bin/python3.9"
}
},
"bindings": {
"venv": {
"description": "Installs Pants in a venv and pre-compiles .pyc.",
"env": {
"=PATH": "{cpython}/python/bin:{scie.env.PATH}",
"PEX_TOOLS": "1",
"PEX_ROOT": "{scie.bindings}/pex_root"
},
"exe": "{cpython}/python/bin/python3.9",
"args": [
"{pants.2.14.0.pex}"
"{pants.2.14.0.pex}",
"venv",
"--bin-path",
"prepend",
"--compile",
"--rm",
"all",
"{scie.bindings}/venv"
]
}
}
Expand Down
1 change: 1 addition & 0 deletions jump/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ bzip2 = "0.4"
dirs = "4.0"
fd-lock = "3.0"
flate2 = "1.0" # For gz support.
indexmap = "1.9"
itertools = "0.10"
log = { workspace = true }
logging_timer = { workspace = true }
Expand Down
15 changes: 12 additions & 3 deletions jump/src/atomic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,14 +10,14 @@ use serde::Serializer;
#[derive(Copy, Clone, Eq, PartialEq)]
pub(crate) enum Target {
Directory,
_File, // TODO(John Sirois): Use for run-once boot bindings.
File, // TODO(John Sirois): Use for run-once boot bindings.
}

impl Display for Target {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
match self {
Target::Directory => f.serialize_str("directory"),
Target::_File => f.serialize_str("file"),
Target::File => f.serialize_str("file"),
}
}
}
Expand All @@ -32,7 +32,7 @@ impl Target {
return Ok(false);
}
}
Target::_File => {
Target::File => {
if target.is_file() {
return Ok(true);
} else if !target.exists() {
Expand Down Expand Up @@ -67,6 +67,10 @@ where

// First check.
if target_type.check_exists(target)? {
debug!(
"The atomic {target_type} at {path} has already been established.",
path = target.display()
);
return Ok(());
}

Expand Down Expand Up @@ -102,6 +106,11 @@ where

// Second check.
if target_type.check_exists(target)? {
debug!(
"The atomic {target_type} at {path} has already been established \
(lost double-check race).",
path = target.display()
);
return Ok(());
}

Expand Down
4 changes: 2 additions & 2 deletions jump/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -216,7 +216,7 @@ pub struct Jump {
pub version: String,
}

#[derive(Debug, Serialize, Deserialize)]
#[derive(Clone, Debug, Serialize, Deserialize)]
#[serde(deny_unknown_fields)]
pub struct Boot {
pub commands: BTreeMap<String, Cmd>,
Expand Down Expand Up @@ -287,7 +287,7 @@ impl Default for Fmt {
}
}

#[derive(Debug, Serialize, Deserialize)]
#[derive(Clone, Debug, Serialize, Deserialize)]
pub struct Other {
#[serde(flatten)]
other: BTreeMap<String, Value>,
Expand Down
Loading

0 comments on commit 0cf93b0

Please sign in to comment.