feat(Profpatsch/writers): add rustSimple writers

A bunch of writer functions wrapping the `buildRustCrate`
functionality of nixpkgs. Can be used to write inline rust code, or
rust code read from files with `builtins.readFile`.

Change-Id: I9d74e9381b858b485925e4dc3fbb7fc392877c0a
Reviewed-on: https://cl.tvl.fyi/c/depot/+/2318
Reviewed-by: tazjin <mail@tazj.in>
Reviewed-by: Profpatsch <mail@profpatsch.de>
Tested-by: BuildkiteCI
This commit is contained in:
Profpatsch 2021-01-02 14:54:39 +01:00
parent e219c13328
commit 1261616bff
4 changed files with 110 additions and 10 deletions

View file

@ -135,6 +135,7 @@ let
runCommandNoCC runCommandNoCC
rustPlatform rustPlatform
rustc rustc
buildRustCrate
s6-portable-utils s6-portable-utils
sbcl sbcl
shellcheck shellcheck

View file

@ -7,7 +7,8 @@ let
; ;
}; };
python-netstring-test = imports.writers.python3 "python-netstring" { python-netstring-test = imports.writers.python3 {
name = "python-netstring";
libraries = p: [ libraries = p: [
python-netstring python-netstring
]; ];

View file

@ -1,6 +1,6 @@
{ depot, pkgs, lib, ... }: { depot, pkgs, lib, ... }:
let let
bins = depot.nix.getBins pkgs.coreutils ["printf" "mkdir" "cat"]; bins = depot.nix.getBins pkgs.coreutils ["printf" "mkdir" "cat" "ln"];
inherit (depot.nix.yants) defun struct restrict attrs list string drv any; inherit (depot.nix.yants) defun struct restrict attrs list string drv any;
@ -11,7 +11,9 @@ let
[ "E" "W" ]) [ "E" "W" ])
string; string;
Libraries = defun [ (attrs any) (list drv) ]; Libraries = defun [ (attrs any) (list drv) ];
python3 = name: {
python3 = {
name,
libraries ? (_: []), libraries ? (_: []),
flakeIgnore ? [] flakeIgnore ? []
}: pkgs.writers.writePython3 name { }: pkgs.writers.writePython3 name {
@ -62,12 +64,61 @@ let
doCheck = false; doCheck = false;
}; };
rustSimple = args@{name, ...}: src:
linkTo name "${rustSimpleBin args src}/bin/${name}";
linkTo = name: path: depot.nix.runExecline.local name {} [
"importas" "out" "out"
bins.ln "-sT" path "$out"
];
rustSimpleBin = {
name,
dependencies ? [],
...
}@args: src: pkgs.buildRustCrate ({
pname = name;
version = "1.0.0";
crateName = name;
crateBin = [ name ];
dependencies = dependencies;
src = pkgs.runCommandLocal "write-main.rs" {
src = src;
passAsFile = [ "src" ];
} ''
mkdir -p $out/src/bin
cp "$srcPath" $out/src/bin/${name}.rs
find $out
'';
} // args);
rustSimpleLib = {
name,
dependencies ? [],
...
}@args: src: pkgs.buildRustCrate ({
pname = name;
version = "1.0.0";
crateName = name;
dependencies = dependencies;
src = pkgs.runCommandLocal "write-lib.rs" {
src = src;
passAsFile = [ "src" ];
} ''
mkdir -p $out/src
cp "$srcPath" $out/src/lib.rs
find $out
'';
} // args);
tests = import ./tests.nix { tests = import ./tests.nix {
inherit inherit
depot depot
pkgs pkgs
python3 python3
python3Lib python3Lib
rustSimpleLib
rustSimple
; ;
}; };
@ -75,6 +126,9 @@ in {
inherit inherit
python3 python3
python3Lib python3Lib
rustSimple
rustSimpleBin
rustSimpleLib
tests tests
; ;
} }

View file

@ -1,31 +1,75 @@
{ depot, pkgs, python3, python3Lib }: { depot, pkgs, python3, python3Lib, rustSimpleLib, rustSimple }:
let let
transitiveLib = python3Lib { run = drv: depot.nix.runExecline.local "run-${drv.name}" {} [
"if" [ drv ]
"importas" "out" "out"
"${pkgs.coreutils}/bin/touch" "$out"
];
pythonTransitiveLib = python3Lib {
name = "transitive"; name = "transitive";
} '' } ''
def transitive(s): def transitive(s):
return s + " 1 2 3" return s + " 1 2 3"
''; '';
testLib = python3Lib { pythonTestLib = python3Lib {
name = "test_lib"; name = "test_lib";
libraries = _: [ transitiveLib ]; libraries = _: [ pythonTransitiveLib ];
} '' } ''
import transitive import transitive
def test(): def test():
return transitive.transitive("test") return transitive.transitive("test")
''; '';
pythonWithLib = python3 "python-with-lib" { pythonWithLib = run (python3 {
libraries = _: [ testLib ]; name = "python-with-lib";
libraries = _: [ pythonTestLib ];
} '' } ''
import test_lib import test_lib
assert(test_lib.test() == "test 1 2 3") assert(test_lib.test() == "test 1 2 3")
'');
rustTransitiveLib = rustSimpleLib {
name = "transitive";
} ''
pub fn transitive(s: &str) -> String {
let mut new = s.to_string();
new.push_str(" 1 2 3");
new
}
''; '';
rustTestLib = rustSimpleLib {
name = "test_lib";
dependencies = [ rustTransitiveLib ];
} ''
extern crate transitive;
use transitive::{transitive};
pub fn test() -> String {
transitive("test")
}
'';
rustWithLib = run (rustSimple {
name = "rust-with-lib";
dependencies = [ rustTestLib ];
} ''
extern crate test_lib;
fn main() {
assert_eq!(test_lib::test(), String::from("test 1 2 3"));
}
'');
in { in {
inherit inherit
pythonWithLib; pythonWithLib
rustTransitiveLib
rustWithLib
;
} }