2022-07-14 12:49:19 +00:00
|
|
|
{ lib, stdenv, fetchurl, zlib, readline, ncurses
|
|
|
|
|
|
|
|
# for tests
|
2022-12-17 10:02:37 +00:00
|
|
|
, python3Packages, sqldiff, sqlite-analyzer, tracker
|
2022-07-14 12:49:19 +00:00
|
|
|
|
|
|
|
# uses readline & ncurses for a better interactive experience if set to true
|
|
|
|
, interactive ? false
|
|
|
|
# TODO: can be removed since 3.36 since it is the default now.
|
2021-09-18 10:52:07 +00:00
|
|
|
, enableDeserialize ? false
|
2021-02-05 17:12:51 +00:00
|
|
|
}:
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
let
|
2021-02-05 17:12:51 +00:00
|
|
|
archiveVersion = import ./archive-version.nix lib;
|
2020-04-24 23:36:52 +00:00
|
|
|
in
|
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
2023-02-02 18:25:31 +00:00
|
|
|
pname = "sqlite${lib.optionalString interactive "-interactive"}";
|
2023-01-20 10:41:00 +00:00
|
|
|
version = "3.40.1";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2022-01-26 04:04:25 +00:00
|
|
|
# nixpkgs-update: no auto update
|
2020-09-25 04:45:31 +00:00
|
|
|
# NB! Make sure to update ./tools.nix src (in the same directory).
|
2020-04-24 23:36:52 +00:00
|
|
|
src = fetchurl {
|
2022-01-26 04:04:25 +00:00
|
|
|
url = "https://sqlite.org/2022/sqlite-autoconf-${archiveVersion version}.tar.gz";
|
2023-01-20 10:41:00 +00:00
|
|
|
sha256 = "sha256-LF3qIH+lCNdlrx72ILY33LBlcq+m8B8IFb1bv4ZLM9k=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
outputs = [ "bin" "dev" "out" ];
|
|
|
|
separateDebugInfo = stdenv.isLinux;
|
|
|
|
|
2023-02-02 18:25:31 +00:00
|
|
|
buildInputs = [ zlib ] ++ lib.optionals interactive [ readline ncurses ];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2021-06-28 23:13:55 +00:00
|
|
|
# required for aarch64 but applied for all arches for simplicity
|
|
|
|
preConfigure = ''
|
|
|
|
patchShebangs configure
|
|
|
|
'';
|
|
|
|
|
2023-02-02 18:25:31 +00:00
|
|
|
configureFlags = [ "--enable-threadsafe" ] ++ lib.optional interactive "--enable-readline";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2021-09-18 10:52:07 +00:00
|
|
|
NIX_CFLAGS_COMPILE = toString ([
|
2020-04-24 23:36:52 +00:00
|
|
|
"-DSQLITE_ENABLE_COLUMN_METADATA"
|
|
|
|
"-DSQLITE_ENABLE_DBSTAT_VTAB"
|
|
|
|
"-DSQLITE_ENABLE_JSON1"
|
|
|
|
"-DSQLITE_ENABLE_FTS3"
|
|
|
|
"-DSQLITE_ENABLE_FTS3_PARENTHESIS"
|
|
|
|
"-DSQLITE_ENABLE_FTS3_TOKENIZER"
|
|
|
|
"-DSQLITE_ENABLE_FTS4"
|
|
|
|
"-DSQLITE_ENABLE_FTS5"
|
|
|
|
"-DSQLITE_ENABLE_RTREE"
|
|
|
|
"-DSQLITE_ENABLE_STMT_SCANSTATUS"
|
|
|
|
"-DSQLITE_ENABLE_UNLOCK_NOTIFY"
|
|
|
|
"-DSQLITE_SOUNDEX"
|
|
|
|
"-DSQLITE_SECURE_DELETE"
|
|
|
|
"-DSQLITE_MAX_VARIABLE_NUMBER=250000"
|
|
|
|
"-DSQLITE_MAX_EXPR_DEPTH=10000"
|
2021-09-18 10:52:07 +00:00
|
|
|
] ++ lib.optionals enableDeserialize [
|
|
|
|
# Can be removed in v3.36+, as this will become the default
|
|
|
|
"-DSQLITE_ENABLE_DESERIALIZE"
|
|
|
|
]);
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# Test for features which may not be available at compile time
|
|
|
|
preBuild = ''
|
|
|
|
# Use pread(), pread64(), pwrite(), pwrite64() functions for better performance if they are available.
|
|
|
|
if cc -Werror=implicit-function-declaration -x c - -o "$TMPDIR/pread_pwrite_test" <<< \
|
|
|
|
''$'#include <unistd.h>\nint main()\n{\n pread(0, NULL, 0, 0);\n pwrite(0, NULL, 0, 0);\n return 0;\n}'; then
|
|
|
|
export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -DUSE_PREAD"
|
|
|
|
fi
|
|
|
|
if cc -Werror=implicit-function-declaration -x c - -o "$TMPDIR/pread64_pwrite64_test" <<< \
|
|
|
|
''$'#include <unistd.h>\nint main()\n{\n pread64(0, NULL, 0, 0);\n pwrite64(0, NULL, 0, 0);\n return 0;\n}'; then
|
|
|
|
export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -DUSE_PREAD64"
|
|
|
|
elif cc -D_LARGEFILE64_SOURCE -Werror=implicit-function-declaration -x c - -o "$TMPDIR/pread64_pwrite64_test" <<< \
|
|
|
|
''$'#include <unistd.h>\nint main()\n{\n pread64(0, NULL, 0, 0);\n pwrite64(0, NULL, 0, 0);\n return 0;\n}'; then
|
|
|
|
export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -DUSE_PREAD64 -D_LARGEFILE64_SOURCE"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Necessary for FTS5 on Linux
|
|
|
|
export NIX_LDFLAGS="$NIX_LDFLAGS -lm"
|
|
|
|
|
|
|
|
echo ""
|
|
|
|
echo "NIX_CFLAGS_COMPILE = $NIX_CFLAGS_COMPILE"
|
|
|
|
echo ""
|
|
|
|
'';
|
|
|
|
|
|
|
|
postInstall = ''
|
|
|
|
# Do not contaminate dependent libtool-based projects with sqlite dependencies.
|
|
|
|
sed -i $out/lib/libsqlite3.la -e "s/dependency_libs=.*/dependency_libs='''/"
|
|
|
|
'';
|
|
|
|
|
|
|
|
doCheck = false; # fails to link against tcl
|
|
|
|
|
2021-02-05 17:12:51 +00:00
|
|
|
passthru.tests = {
|
|
|
|
inherit (python3Packages) sqlalchemy;
|
2022-12-17 10:02:37 +00:00
|
|
|
inherit sqldiff sqlite-analyzer tracker;
|
2021-02-05 17:12:51 +00:00
|
|
|
};
|
|
|
|
|
2023-02-02 18:25:31 +00:00
|
|
|
meta = with lib; {
|
2020-04-24 23:36:52 +00:00
|
|
|
description = "A self-contained, serverless, zero-configuration, transactional SQL database engine";
|
|
|
|
downloadPage = "https://sqlite.org/download.html";
|
|
|
|
homepage = "https://www.sqlite.org/";
|
|
|
|
license = licenses.publicDomain;
|
2021-12-06 16:07:01 +00:00
|
|
|
mainProgram = "sqlite3";
|
2020-04-24 23:36:52 +00:00
|
|
|
maintainers = with maintainers; [ eelco np ];
|
|
|
|
platforms = platforms.unix ++ platforms.windows;
|
|
|
|
};
|
|
|
|
}
|