summarylogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--.SRCINFO10
-rw-r--r--PKGBUILD18
-rw-r--r--use-system-library.patch120
3 files changed, 138 insertions, 10 deletions
diff --git a/.SRCINFO b/.SRCINFO
index 76ffdf0fa89a..fdd187f42604 100644
--- a/.SRCINFO
+++ b/.SRCINFO
@@ -1,15 +1,17 @@
pkgbase = nitrocli
pkgdesc = Command-line interface for Nitrokey devices
pkgver = 0.2.0
- pkgrel = 2
+ pkgrel = 3
url = https://github.com/d-e-s-o/nitrocli
arch = x86_64
license = GPL3
makedepends = cargo
- depends = hidapi
+ depends = libnitrokey>=3.4.1
depends = gnupg
- source = nitrocli-0.2.0.tar.gz::https://crates.io/api/v1/crates/nitrocli/0.2.0/download
- sha512sums = aca356201c29ed670595d2d637edc2ce15df0a59a6843c68632b702fc92dd8df85cf6e17eed6d5d95e8dd2e83e1f15c3691f2e9bd1aeb0fc908c2217af7e74ae
+ source = nitrocli-0.2.0.tar.gz::https://github.com/d-e-s-o/nitrocli/archive/v0.2.0.tar.gz
+ source = use-system-library.patch
+ sha512sums = f119335e05170c7125d6ecdfdbd9ad30f0bf8fafbd694ecb97e99da25982317dfd0faa9f8b962cda2d2d565a447affefdd8f9198ba85e713fe93f1bd8f90b1ec
+ sha512sums = d53050632a6f68705d344469a040579e5ea23db6ce7e1e36ae2f7a206a543cbea409ad3f025495a9f12c46a4c488ffbfab3cc781cbed058f88a3c23f8d2667cf
pkgname = nitrocli
diff --git a/PKGBUILD b/PKGBUILD
index 49bc47ce7868..71665cbcd2b7 100644
--- a/PKGBUILD
+++ b/PKGBUILD
@@ -1,23 +1,29 @@
# Maintainer: Robin Krahl <robin.krahl@ireas.org>
pkgname=nitrocli
pkgver=0.2.0
-pkgrel=2
+pkgrel=3
pkgdesc="Command-line interface for Nitrokey devices"
arch=('x86_64')
url="https://github.com/d-e-s-o/nitrocli"
license=('GPL3')
-depends=('hidapi' 'gnupg')
+depends=('libnitrokey>=3.4.1' 'gnupg')
makedepends=('cargo')
-source=("$pkgname-$pkgver.tar.gz"::https://crates.io/api/v1/crates/$pkgname/$pkgver/download)
-sha512sums=('aca356201c29ed670595d2d637edc2ce15df0a59a6843c68632b702fc92dd8df85cf6e17eed6d5d95e8dd2e83e1f15c3691f2e9bd1aeb0fc908c2217af7e74ae')
+source=("$pkgname-$pkgver.tar.gz"::https://github.com/d-e-s-o/nitrocli/archive/v0.2.0.tar.gz "use-system-library.patch")
+sha512sums=('f119335e05170c7125d6ecdfdbd9ad30f0bf8fafbd694ecb97e99da25982317dfd0faa9f8b962cda2d2d565a447affefdd8f9198ba85e713fe93f1bd8f90b1ec'
+ 'd53050632a6f68705d344469a040579e5ea23db6ce7e1e36ae2f7a206a543cbea409ad3f025495a9f12c46a4c488ffbfab3cc781cbed058f88a3c23f8d2667cf')
-build() {
+prepare() {
cd "$pkgname-$pkgver"
+ patch -p1 -i "$srcdir/use-system-library.patch"
+}
+
+build() {
+ cd "$pkgname-$pkgver/nitrocli"
cargo build --release
}
package() {
- cd "$pkgname-$pkgver"
+ cd "$pkgname-$pkgver/nitrocli"
install -Dm755 target/release/nitrocli "$pkgdir"/usr/bin/nitrocli
install -Dm644 doc/nitrocli.1 "$pkgdir"/usr/share/man/man1/nitrocli.1
}
diff --git a/use-system-library.patch b/use-system-library.patch
new file mode 100644
index 000000000000..991c9e14e9d5
--- /dev/null
+++ b/use-system-library.patch
@@ -0,0 +1,120 @@
+Only in nitrocli-0.2.0: cc
+diff -ura nitrocli-0.2.0/nitrokey-sys/build.rs nitrocli-0.2.0.new/nitrokey-sys/build.rs
+--- nitrocli-0.2.0/nitrokey-sys/build.rs 2019-01-02 01:21:10.000000000 +0000
++++ nitrocli-0.2.0.new/nitrokey-sys/build.rs 2019-01-04 16:21:39.881258886 +0000
+@@ -1,104 +1,3 @@
+-extern crate cc;
+-
+-use std::env;
+-use std::io;
+-use std::io::{Read, Write};
+-use std::fs;
+-use std::path;
+-
+-struct Version {
+- major: String,
+- minor: String,
+- git: String,
+-}
+-
+-fn stringify(err: env::VarError) -> String {
+- format!("{}", err)
+-}
+-
+-fn extract_git_version(pre: &str) -> Result<String, String> {
+- // If a pre-release version is set, it is expected to have the format
+- // pre.v<maj>.<min>.<n>.g<hash>, where <maj> and <min> are the last major and minor version,
+- // <n> is the number of commits since this version and <hash> is the hash of the last commit.
+- let parts: Vec<&str> = pre.split('.').collect();
+- if parts.len() != 5 {
+- return Err(format!("'{}' is not a valid pre-release version", pre));
+- }
+- Ok(format!("{}.{}-{}-{}", parts[1], parts[2], parts[3], parts[4]))
+-}
+-
+-fn get_version() -> Result<Version, String> {
+- let major = env::var("CARGO_PKG_VERSION_MAJOR").map_err(stringify)?;
+- let minor = env::var("CARGO_PKG_VERSION_MINOR").map_err(stringify)?;
+- let patch = env::var("CARGO_PKG_VERSION_PATCH").map_err(stringify)?;
+- let pre = env::var("CARGO_PKG_VERSION_PRE").map_err(stringify)?;
+-
+- let git = match pre.is_empty() {
+- true => match patch.is_empty() {
+- true => format!("v{}.{}", major, minor),
+- false => format!("v{}.{}.{}", major, minor, patch),
+- },
+- false => extract_git_version(&pre)?,
+- };
+-
+- Ok(Version {
+- major,
+- minor,
+- git,
+- })
+-}
+-
+-fn prepare_version_source(
+- version: &Version,
+- out_path: &path::Path,
+- library_path: &path::Path
+-) -> io::Result<path::PathBuf> {
+- let out = out_path.join("version.cc");
+- let template = library_path.join("version.cc.in");
+-
+- let mut file = fs::File::open(template)?;
+- let mut data = String::new();
+- file.read_to_string(&mut data)?;
+- drop(file);
+-
+- let data = data
+- .replace("@PROJECT_VERSION_MAJOR@", &version.major)
+- .replace("@PROJECT_VERSION_MINOR@", &version.minor)
+- .replace("@PROJECT_VERSION_GIT@", &version.git);
+-
+- let mut file = fs::File::create(&out)?;
+- file.write_all(data.as_bytes())?;
+-
+- Ok(out)
+-}
+-
+ fn main() {
+- let out_dir = env::var("OUT_DIR").expect("Environment variable OUT_DIR is not set");
+- let out_path = path::PathBuf::from(out_dir);
+-
+- let version = get_version().expect("Could not extract library version");
+-
+- let sources = [
+- "DeviceCommunicationExceptions.cpp",
+- "NK_C_API.cc",
+- "NitrokeyManager.cc",
+- "command_id.cc",
+- "device.cc",
+- "log.cc",
+- "misc.cc",
+- ];
+- let library_dir = format!("libnitrokey-{}", version.git);
+- let library_path = path::Path::new(&library_dir);
+-
+- let version_source = prepare_version_source(&version, &out_path, &library_path)
+- .expect("Could not prepare the version source file");
+-
+- cc::Build::new()
+- .cpp(true)
+- .include(library_path.join("libnitrokey"))
+- .files(sources.iter().map(|s| library_path.join(s)))
+- .file(version_source)
+- .compile("libnitrokey.a");
+-
+- println!("cargo:rustc-link-lib=hidapi-libusb");
++ println!("cargo:rustc-link-lib=nitrokey");
+ }
+diff -ura nitrocli-0.2.0/nitrokey-sys/Cargo.toml nitrocli-0.2.0.new/nitrokey-sys/Cargo.toml
+--- nitrocli-0.2.0/nitrokey-sys/Cargo.toml 2019-01-02 01:21:10.000000000 +0000
++++ nitrocli-0.2.0.new/nitrokey-sys/Cargo.toml 2019-01-04 16:21:53.252875210 +0000
+@@ -10,6 +10,3 @@
+ links = "nitrokey"
+ build = "build.rs"
+ readme = "README.md"
+-
+-[build-dependencies]
+-cc = "1.0"