refactor(third_party/lisp): Use buildLisp.bundled for built-in libs

Deprecates derivations for:

* sb-bsd-sockets
* sb-posix
* sb-rotate-byte
* uiop
This commit is contained in:
Vincent Ambo 2020-01-26 23:59:07 +00:00
parent ca60eafa80
commit a41b8c70a6
14 changed files with 36 additions and 74 deletions

View file

@ -1,9 +1,10 @@
# Imported from https://github.com/didierverna/asdf-flv # Imported from https://github.com/didierverna/asdf-flv
{ pkgs, ... }: { pkgs, ... }:
pkgs.nix.buildLisp.library { with pkgs.nix;
buildLisp.library {
name = "asdf-flv"; name = "asdf-flv";
deps = with pkgs.third_party.lisp; [ asdf ]; deps = [ (buildLisp.bundled "asdf") ];
srcs = [ srcs = [
./package.lisp ./package.lisp

View file

@ -1,9 +0,0 @@
# ASDF ships with SBCL. This package just exists to force it to load.
{ pkgs, ... }:
with pkgs;
nix.buildLisp.library {
name = "asdf";
srcs = lib.singleton (builtins.toFile "asdf.lisp" "(require 'asdf)");
}

View file

@ -1,18 +1,19 @@
# CFFI purports to be the Common Foreign Function Interface. # CFFI purports to be the Common Foreign Function Interface.
{ pkgs, ... }: { pkgs, ... }:
with pkgs.nix;
let src = builtins.fetchGit { let src = builtins.fetchGit {
url = "https://github.com/cffi/cffi.git"; url = "https://github.com/cffi/cffi.git";
rev = "5e838bf46d0089c43ebd3ea014a207c403e29c61"; rev = "5e838bf46d0089c43ebd3ea014a207c403e29c61";
}; };
in pkgs.nix.buildLisp.library { in buildLisp.library {
name = "cffi"; name = "cffi";
deps = with pkgs.third_party.lisp; [ deps = with pkgs.third_party.lisp; [
alexandria alexandria
asdf
babel babel
trivial-features trivial-features
uiop (buildLisp.bundled "asdf")
(buildLisp.bundled "uiop")
]; ];
srcs = map (f: src + ("/src/" + f)) [ srcs = map (f: src + ("/src/" + f)) [

View file

@ -1,15 +1,17 @@
# Common Lisp library for decompressing deflate, zlib, gzip, and bzip2 data # Common Lisp library for decompressing deflate, zlib, gzip, and bzip2 data
{ pkgs, ... }: { pkgs, ... }:
with pkgs.nix;
let src = pkgs.third_party.fetchFromGitHub { let src = pkgs.third_party.fetchFromGitHub {
owner = "froydnj"; owner = "froydnj";
repo = "chipz"; repo = "chipz";
rev = "75dfbc660a5a28161c57f115adf74c8a926bfc4d"; rev = "75dfbc660a5a28161c57f115adf74c8a926bfc4d";
sha256 = "0plx4rs39zbs4gjk77h4a2q11zpy75fh9v8hnxrvsf8fnakajhwg"; sha256 = "0plx4rs39zbs4gjk77h4a2q11zpy75fh9v8hnxrvsf8fnakajhwg";
}; };
in pkgs.nix.buildLisp.library { in buildLisp.library {
name = "chipz"; name = "chipz";
deps = with pkgs.third_party.lisp; [ asdf ]; deps = [ (buildLisp.bundled "asdf") ];
srcs = map (f: src + ("/" + f)) [ srcs = map (f: src + ("/" + f)) [
"chipz.asd" "chipz.asd"

View file

@ -1,19 +1,21 @@
# Portable pathname library # Portable pathname library
{ pkgs, ...}: { pkgs, ...}:
with pkgs.nix;
let src = pkgs.third_party.fetchFromGitHub { let src = pkgs.third_party.fetchFromGitHub {
owner = "edicl"; owner = "edicl";
repo = "cl-fad"; repo = "cl-fad";
rev = "c13d81c4bd9ba3a172631fd05dd213ab90e7d4cb"; rev = "c13d81c4bd9ba3a172631fd05dd213ab90e7d4cb";
sha256 = "1gc8i82v6gks7g0lnm54r4prk2mklidv2flm5fvbr0a7rsys0vpa"; sha256 = "1gc8i82v6gks7g0lnm54r4prk2mklidv2flm5fvbr0a7rsys0vpa";
}; };
in pkgs.nix.buildLisp.library { in buildLisp.library {
name = "cl-fad"; name = "cl-fad";
deps = with pkgs.third_party.lisp; [ deps = with pkgs.third_party.lisp; [
alexandria alexandria
bordeaux-threads bordeaux-threads
sb-posix (buildLisp.bundled "sb-posix")
]; ];
srcs = map (f: src + ("/" + f)) [ srcs = map (f: src + ("/" + f)) [

View file

@ -1,15 +1,16 @@
# JSON encoder & decoder # JSON encoder & decoder
{ pkgs, ... }: { pkgs, ... }:
with pkgs.nix;
let src = pkgs.third_party.fetchFromGitHub { let src = pkgs.third_party.fetchFromGitHub {
owner = "hankhero"; owner = "hankhero";
repo = "cl-json"; repo = "cl-json";
rev = "6dfebb9540bfc3cc33582d0c03c9ec27cb913e79"; rev = "6dfebb9540bfc3cc33582d0c03c9ec27cb913e79";
sha256 = "0fx3m3x3s5ji950yzpazz4s0img3l6b3d6l3jrfjv0lr702496lh"; sha256 = "0fx3m3x3s5ji950yzpazz4s0img3l6b3d6l3jrfjv0lr702496lh";
}; };
in pkgs.nix.buildLisp.library { in buildLisp.library {
name = "cl-json"; name = "cl-json";
deps = [ pkgs.third_party.lisp.asdf ]; deps = [ (buildLisp.bundled "asdf") ];
srcs = [ "${src}/cl-json.asd" ] ++ srcs = [ "${src}/cl-json.asd" ] ++
(map (f: src + ("/src/" + f)) [ (map (f: src + ("/src/" + f)) [

View file

@ -1,22 +1,24 @@
# Common Lisp bindings to OpenSSL # Common Lisp bindings to OpenSSL
{ pkgs, ... }: { pkgs, ... }:
with pkgs.nix;
let src = builtins.fetchGit { let src = builtins.fetchGit {
url = "https://github.com/cl-plus-ssl/cl-plus-ssl.git"; url = "https://github.com/cl-plus-ssl/cl-plus-ssl.git";
rev = "29081992f6d7b4e3aa2c5eeece4cd92b745071f4"; rev = "29081992f6d7b4e3aa2c5eeece4cd92b745071f4";
}; };
in pkgs.nix.buildLisp.library { in buildLisp.library {
name = "cl-plus-ssl"; name = "cl-plus-ssl";
deps = with pkgs.third_party.lisp; [ deps = with pkgs.third_party.lisp; [
alexandria alexandria
bordeaux-threads bordeaux-threads
cffi cffi
flexi-streams flexi-streams
sb-posix
trivial-features trivial-features
trivial-garbage trivial-garbage
trivial-gray-streams trivial-gray-streams
uiop (buildLisp.bundled "uiop")
(buildLisp.bundled "sb-posix")
]; ];
native = [ pkgs.third_party.openssl ]; native = [ pkgs.third_party.openssl ];

View file

@ -1,16 +1,17 @@
# Drakma is an HTTP client for Common Lisp. # Drakma is an HTTP client for Common Lisp.
{ pkgs, ... }: { pkgs, ... }:
with pkgs.nix;
let src = pkgs.third_party.fetchFromGitHub { let src = pkgs.third_party.fetchFromGitHub {
owner = "edicl"; owner = "edicl";
repo = "drakma"; repo = "drakma";
rev = "87feb02bef00b11a753d5fb21a5fec526b0d0bbb"; rev = "87feb02bef00b11a753d5fb21a5fec526b0d0bbb";
sha256 = "01b80am2vrw94xmdj7f21qm7p5ys08mmpzv4nc4icql81hqr1w2m"; sha256 = "01b80am2vrw94xmdj7f21qm7p5ys08mmpzv4nc4icql81hqr1w2m";
}; };
in pkgs.nix.buildLisp.library { in buildLisp.library {
name = "drakma"; name = "drakma";
deps = with pkgs.third_party.lisp; [ deps = with pkgs.third_party.lisp; [
asdf
chipz chipz
chunga chunga
cl-base64 cl-base64
@ -19,6 +20,7 @@ in pkgs.nix.buildLisp.library {
flexi-streams flexi-streams
puri puri
usocket usocket
(buildLisp.bundled "asdf")
]; ];
srcs = map (f: src + ("/" + f)) [ srcs = map (f: src + ("/" + f)) [

View file

@ -1,18 +1,16 @@
# MD5 hash implementation # MD5 hash implementation
{ pkgs, ... }: { pkgs, ... }:
with pkgs.nix;
let src = pkgs.third_party.fetchFromGitHub { let src = pkgs.third_party.fetchFromGitHub {
owner = "pmai"; owner = "pmai";
repo = "md5"; repo = "md5";
rev = "b1412600f60d526ee34a7ba1596ec483da7894ab"; rev = "b1412600f60d526ee34a7ba1596ec483da7894ab";
sha256 = "0lzip6b6xg7gd70xl1xmqp24fvxqj6ywjnz9lmx7988zpj20nhl2"; sha256 = "0lzip6b6xg7gd70xl1xmqp24fvxqj6ywjnz9lmx7988zpj20nhl2";
}; };
in pkgs.nix.buildLisp.library { in buildLisp.library {
name = "md5"; name = "md5";
deps = [ (buildLisp.bundled "sb-rotate-byte") ];
deps = with pkgs.third_party.lisp; [
sb-rotate-byte
];
srcs = [ (src + "/md5.lisp") ]; srcs = [ (src + "/md5.lisp") ];
} }

View file

@ -1,10 +0,0 @@
# SB-BSD-SOCKETS is an SBCL component. This package just forces it to
# be loaded.
{ pkgs, ... }:
with pkgs;
nix.buildLisp.library {
name = "sb-bsd-sockets";
srcs = lib.singleton (builtins.toFile "sb-bsd-sockets.lisp" "(require 'sb-bsd-sockets)");
}

View file

@ -1,10 +0,0 @@
# SB-POSIX is an SBCL component. This package just forces it to be
# loaded.
{ pkgs, ... }:
with pkgs;
nix.buildLisp.library {
name = "sb-posix";
srcs = lib.singleton (builtins.toFile "sb-posix.lisp" "(require 'sb-posix)");
}

View file

@ -1,10 +0,0 @@
# SB-ROTATE-BYTE is an SBCL component. This package just forces it to
# be loaded.
{ pkgs, ... }:
with pkgs;
nix.buildLisp.library {
name = "sb-rotate-byte";
srcs = lib.singleton (builtins.toFile "sb-rotate-byte.lisp" "(require 'sb-rotate-byte)");
}

View file

@ -1,10 +0,0 @@
# UIOP ships with SBCL (due to ASDF). This package just exists to
# force it to load.
{ pkgs, ... }:
with pkgs;
nix.buildLisp.library {
name = "uiop";
srcs = lib.singleton (builtins.toFile "uiop.lisp" "(require 'uiop)");
}

View file

@ -1,17 +1,19 @@
# Usocket is a portable socket library # Usocket is a portable socket library
{ pkgs, ... }: { pkgs, ... }:
with pkgs.nix;
let src = pkgs.third_party.fetchFromGitHub { let src = pkgs.third_party.fetchFromGitHub {
owner = "usocket"; owner = "usocket";
repo = "usocket"; repo = "usocket";
rev = "fdf4fd1e0051ce83340ccfbbc8a43a462bb19cf2"; rev = "fdf4fd1e0051ce83340ccfbbc8a43a462bb19cf2";
sha256 = "0x746wr2324l6bn7skqzgkzcbj5kd0zp2ck0c8rldrw0rzabg826"; sha256 = "0x746wr2324l6bn7skqzgkzcbj5kd0zp2ck0c8rldrw0rzabg826";
}; };
in pkgs.nix.buildLisp.library { in buildLisp.library {
name = "usocket"; name = "usocket";
deps = with pkgs.third_party.lisp; [ deps = with pkgs.third_party.lisp; [
asdf (buildLisp.bundled "asdf")
sb-bsd-sockets (buildLisp.bundled "sb-bsd-sockets")
split-sequence split-sequence
]; ];