From: 宋文武 <iyzsong@gmail.com>
To: Mark H Weaver <mhw@netris.org>
Cc: guix-devel@gnu.org
Subject: Re: [PATCH] gnu: Add nss.
Date: Thu, 08 Jan 2015 21:00:41 +0800 [thread overview]
Message-ID: <87lhldmnpi.fsf@gmail.com> (raw)
In-Reply-To: <87387m1qo2.fsf@netris.org>
[-- Attachment #1: Type: text/plain, Size: 12526 bytes --]
Mark H Weaver <mhw@netris.org> writes:
> 宋文武 <iyzsong@gmail.com> writes:
>
>> * gnu/packages/patches/nss.patch: New file.
>> * gnu-system.scm (dist_patch_DATA): Add it.
>> * gnu/packages/polkit.scm (nss): New variable.
>
> polkit.scm seems like the wrong place for 'nss', although admittedly
> it's not obvious where it should go.
Maybe move it and nspr gnuzilla.scm? Since they are both from mozilla.
>
>> ---
>> gnu-system.am | 1 +
>> gnu/packages/patches/nss.patch | 241 +++++++++++++++++++++++++++++++++++++++++
>> gnu/packages/polkit.scm | 84 ++++++++++++++
>> 3 files changed, 326 insertions(+)
>> create mode 100644 gnu/packages/patches/nss.patch
>>
>> diff --git a/gnu-system.am b/gnu-system.am
>> index 4086067..046ded5 100644
>> --- a/gnu-system.am
>> +++ b/gnu-system.am
>> @@ -422,6 +422,7 @@ dist_patch_DATA = \
>> gnu/packages/patches/mupdf-buildsystem-fix.patch \
>> gnu/packages/patches/mutt-CVE-2014-9116.patch \
>> gnu/packages/patches/net-tools-bitrot.patch \
>> + gnu/packages/patches/nss.patch \
>> gnu/packages/patches/nvi-assume-preserve-path.patch \
>> gnu/packages/patches/orpheus-cast-errors-and-includes.patch \
>> gnu/packages/patches/ots-no-include-missing-file.patch \
>> diff --git a/gnu/packages/patches/nss.patch b/gnu/packages/patches/nss.patch
>> new file mode 100644
>> index 0000000..356ff0d
>> --- /dev/null
>> +++ b/gnu/packages/patches/nss.patch
>> @@ -0,0 +1,241 @@
>> +--- nss-3.17.1/nss/config/Makefile
>> ++++ nss-3.17.1/nss/config/Makefile
>> +@@ -0,0 +1,40 @@
>> ++CORE_DEPTH = ..
>> ++DEPTH = ..
>> ++
>> ++include $(CORE_DEPTH)/coreconf/config.mk
>> ++
>> ++NSS_MAJOR_VERSION = `grep "NSS_VMAJOR" ../lib/nss/nss.h | awk '{print $$3}'`
>> ++NSS_MINOR_VERSION = `grep "NSS_VMINOR" ../lib/nss/nss.h | awk '{print $$3}'`
>> ++NSS_PATCH_VERSION = `grep "NSS_VPATCH" ../lib/nss/nss.h | awk '{print $$3}'`
>> ++PREFIX = /usr
>> ++
>> ++all: export libs
>> ++
>> ++export:
>> ++ # Create the nss.pc file
>> ++ mkdir -p $(DIST)/lib/pkgconfig
>> ++ sed -e "s,@prefix@,$(PREFIX)," \
>> ++ -e "s,@exec_prefix@,\$${prefix}," \
>> ++ -e "s,@libdir@,\$${prefix}/lib," \
>> ++ -e "s,@includedir@,\$${prefix}/include/nss," \
>> ++ -e "s,@NSS_MAJOR_VERSION@,$(NSS_MAJOR_VERSION),g" \
>> ++ -e "s,@NSS_MINOR_VERSION@,$(NSS_MINOR_VERSION)," \
>> ++ -e "s,@NSS_PATCH_VERSION@,$(NSS_PATCH_VERSION)," \
>> ++ nss.pc.in > nss.pc
>> ++ chmod 0644 nss.pc
>> ++ cp nss.pc $(DIST)/lib/pkgconfig
>> ++
>> ++ # Create the nss-config script
>> ++ mkdir -p $(DIST)/bin
>> ++ sed -e "s,@prefix@,$(PREFIX)," \
>> ++ -e "s,@NSS_MAJOR_VERSION@,$(NSS_MAJOR_VERSION)," \
>> ++ -e "s,@NSS_MINOR_VERSION@,$(NSS_MINOR_VERSION)," \
>> ++ -e "s,@NSS_PATCH_VERSION@,$(NSS_PATCH_VERSION)," \
>> ++ nss-config.in > nss-config
>> ++ chmod 0755 nss-config
>> ++ cp nss-config $(DIST)/bin
>> ++
>> ++libs:
>> ++
>> ++dummy: all export libs
>> ++
>> +--- nss-3.17.1/nss/config/nss-config.in
>> ++++ nss-3.17.1/nss/config/nss-config.in
>> +@@ -0,0 +1,145 @@
>> ++#!/bin/sh
>> ++
>> ++prefix=@prefix@
>> ++
>> ++major_version=@NSS_MAJOR_VERSION@
>> ++minor_version=@NSS_MINOR_VERSION@
>> ++patch_version=@NSS_PATCH_VERSION@
>> ++
>> ++usage()
>> ++{
>> ++ cat <<EOF
>> ++Usage: nss-config [OPTIONS] [LIBRARIES]
>> ++Options:
>> ++ [--prefix[=DIR]]
>> ++ [--exec-prefix[=DIR]]
>> ++ [--includedir[=DIR]]
>> ++ [--libdir[=DIR]]
>> ++ [--version]
>> ++ [--libs]
>> ++ [--cflags]
>> ++Dynamic Libraries:
>> ++ nss
>> ++ ssl
>> ++ smime
>> ++ nssutil
>> ++EOF
>> ++ exit $1
>> ++}
>> ++
>> ++if test $# -eq 0; then
>> ++ usage 1 1>&2
>> ++fi
>> ++
>> ++lib_ssl=yes
>> ++lib_smime=yes
>> ++lib_nss=yes
>> ++lib_nssutil=yes
>> ++
>> ++while test $# -gt 0; do
>> ++ case "$1" in
>> ++ -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;;
>> ++ *) optarg= ;;
>> ++ esac
>> ++
>> ++ case $1 in
>> ++ --prefix=*)
>> ++ prefix=$optarg
>> ++ ;;
>> ++ --prefix)
>> ++ echo_prefix=yes
>> ++ ;;
>> ++ --exec-prefix=*)
>> ++ exec_prefix=$optarg
>> ++ ;;
>> ++ --exec-prefix)
>> ++ echo_exec_prefix=yes
>> ++ ;;
>> ++ --includedir=*)
>> ++ includedir=$optarg
>> ++ ;;
>> ++ --includedir)
>> ++ echo_includedir=yes
>> ++ ;;
>> ++ --libdir=*)
>> ++ libdir=$optarg
>> ++ ;;
>> ++ --libdir)
>> ++ echo_libdir=yes
>> ++ ;;
>> ++ --version)
>> ++ echo ${major_version}.${minor_version}.${patch_version}
>> ++ ;;
>> ++ --cflags)
>> ++ echo_cflags=yes
>> ++ ;;
>> ++ --libs)
>> ++ echo_libs=yes
>> ++ ;;
>> ++ ssl)
>> ++ lib_ssl=yes
>> ++ ;;
>> ++ smime)
>> ++ lib_smime=yes
>> ++ ;;
>> ++ nss)
>> ++ lib_nss=yes
>> ++ ;;
>> ++ nssutil)
>> ++ lib_nssutil=yes
>> ++ ;;
>> ++ *)
>> ++ usage 1 1>&2
>> ++ ;;
>> ++ esac
>> ++ shift
>> ++done
>> ++
>> ++# Set variables that may be dependent upon other variables
>> ++if test -z "$exec_prefix"; then
>> ++ exec_prefix=`pkg-config --variable=exec_prefix nss`
>> ++fi
>> ++if test -z "$includedir"; then
>> ++ includedir=`pkg-config --variable=includedir nss`
>> ++fi
>> ++if test -z "$libdir"; then
>> ++ libdir=`pkg-config --variable=libdir nss`
>> ++fi
>> ++
>> ++if test "$echo_prefix" = "yes"; then
>> ++ echo $prefix
>> ++fi
>> ++
>> ++if test "$echo_exec_prefix" = "yes"; then
>> ++ echo $exec_prefix
>> ++fi
>> ++
>> ++if test "$echo_includedir" = "yes"; then
>> ++ echo $includedir
>> ++fi
>> ++
>> ++if test "$echo_libdir" = "yes"; then
>> ++ echo $libdir
>> ++fi
>> ++
>> ++if test "$echo_cflags" = "yes"; then
>> ++ echo -I$includedir
>> ++fi
>> ++
>> ++if test "$echo_libs" = "yes"; then
>> ++ libdirs=""
>> ++ if test -n "$lib_ssl"; then
>> ++ libdirs="$libdirs -lssl${major_version}"
>> ++ fi
>> ++ if test -n "$lib_smime"; then
>> ++ libdirs="$libdirs -lsmime${major_version}"
>> ++ fi
>> ++ if test -n "$lib_nss"; then
>> ++ libdirs="$libdirs -lnss${major_version}"
>> ++ fi
>> ++ if test -n "$lib_nssutil"; then
>> ++ libdirs="$libdirs -lnssutil${major_version}"
>> ++ fi
>> ++ echo $libdirs
>> ++fi
>> ++
>> +--- nss-3.17.1/nss/config/nss.pc.in
>> ++++ nss-3.17.1/nss/config/nss.pc.in
>> +@@ -0,0 +1,12 @@
>> ++prefix=@prefix@
>> ++exec_prefix=@exec_prefix@
>> ++libdir=@libdir@
>> ++includedir=@includedir@
>> ++
>> ++Name: NSS
>> ++Description: Network Security Services
>> ++Version: @NSS_MAJOR_VERSION@.@NSS_MINOR_VERSION@.@NSS_PATCH_VERSION@
>> ++Requires: nspr >= 4.8
>> ++Libs: -lssl3 -lsmime3 -lnss3 -lnssutil3
>> ++Cflags: -I${includedir}
>> ++
>> +--- nss-3.17.1/nss/Makefile
>> ++++ nss-3.17.1/nss/Makefile
>> +@@ -44,7 +44,7 @@
>> + # (7) Execute "local" rules. (OPTIONAL). #
>> + #######################################################################
>> +
>> +-nss_build_all: build_nspr all
>> ++nss_build_all: all
>> +
>> + nss_clean_all: clobber_nspr clobber
>> +
>> +@@ -109,12 +109,6 @@
>> + --with-dist-prefix='$(NSPR_PREFIX)' \
>> + --with-dist-includedir='$(NSPR_PREFIX)/include'
>> +
>> +-build_nspr: $(NSPR_CONFIG_STATUS)
>> +- $(MAKE) -C $(CORE_DEPTH)/../nspr/$(OBJDIR_NAME)
>> +-
>> +-clobber_nspr: $(NSPR_CONFIG_STATUS)
>> +- $(MAKE) -C $(CORE_DEPTH)/../nspr/$(OBJDIR_NAME) clobber
>> +-
>> + build_docs:
>> + $(MAKE) -C $(CORE_DEPTH)/doc
>> +
>> +--- nss-3.17.1/nss/manifest.mn
>> ++++ nss-3.17.1/nss/manifest.mn
>> +@@ -10,7 +10,7 @@
>> +
>> + RELEASE = nss
>> +
>> +-DIRS = coreconf lib cmd
>> ++DIRS = coreconf lib cmd config
>> +
>> + ifdef NSS_BUILD_GTESTS
>> + DIRS += external_tests
>
> Why is this patch needed? I find it surprising how much stuff you had
> to add in order to get this to build. Where did it all come from?
It's to install nss.pc and nss-config, from nixpkgs (from gentoo).
>
> Some explanation will be needed at the top of the patch, and also the
> patch should have a more descriptive name than "nss.patch".
OK.
>
>> diff --git a/gnu/packages/polkit.scm b/gnu/packages/polkit.scm
>> index 2be1d0b..8a6fa7c 100644
>> --- a/gnu/packages/polkit.scm
>> +++ b/gnu/packages/polkit.scm
>> @@ -1,5 +1,6 @@
>> ;;; GNU Guix --- Functional package management for GNU
>> ;;; Copyright © 2014 Andreas Enge <andreas@enge.fr>
>> +;;; Copyright © 2015 Sou Bunnbu <iyzsong@gmail.com>
>> ;;;
>> ;;; This file is part of GNU Guix.
>> ;;;
>> @@ -23,6 +24,8 @@
>> #:use-module (guix build-system cmake)
>> #:use-module (guix build-system gnu)
>> #:use-module (gnu packages)
>> + #:use-module (gnu packages compression)
>> + #:use-module (gnu packages databases)
>> #:use-module (gnu packages glib)
>> #:use-module (gnu packages linux)
>> #:use-module (gnu packages perl)
>> @@ -103,6 +106,87 @@ platform-neutral API for system level and libc-like functions. It is used
>> in the Mozilla clients.")
>> (license mpl2.0)))
>>
>> +(define-public nss
>> + (package
>> + (name "nss")
>> + (version "3.17.3")
>> + (source (origin
>> + (method url-fetch)
>> + (uri (string-append
>> + "ftp://ftp.mozilla.org/pub/mozilla.org/security/nss/"
>> + "releases/NSS_3_17_3_RTM/src/nss-3.17.3.tar.gz"))
>> + (sha256
>> + (base32
>> + "1m91z80x4zh1mxgf53bl33lp43gn1wxxx0y26mgz511gb81ykmgl"))
>> + (patches (list (search-patch "nss.patch")))))
>> + (build-system gnu-build-system)
>> + (outputs '("out" "bin"))
>> + (arguments
>> + '(#:parallel-build? #f ; failed
>> + #:make-flags
>> + (let* ((out (assoc-ref %outputs "out"))
>> + (nspr (string-append (assoc-ref %build-inputs "nspr")))
>> + (rpath (string-append "-Wl,-rpath=" out "/lib")))
>> + (list "-C" "nss" (string-append "PREFIX=" out)
>> + "NSDISTMODE=copy"
>> + "NSS_USE_SYSTEM_SQLITE=1"
>> + (string-append "NSPR_INCLUDE_DIR=" nspr "/include/nspr")
>> + ;; Add $out/lib to RPATH.
>> + (string-append "RPATH=" rpath)
>> + (string-append "LDFLAGS=" rpath)))
>> + #:modules ((guix build gnu-build-system)
>> + (guix build utils)
>> + (ice-9 ftw)
>> + (srfi srfi-26))
>> + #:imported-modules ((guix build gnu-build-system)
>> + (guix build utils))
>> + #:phases
>> + (alist-replace
>> + 'configure
>> + (lambda* (#:key system inputs #:allow-other-keys)
>> + (when (string-prefix? "x86_64" system)
>> + (setenv "USE_64" "1")))
>> + (alist-replace
>> + 'check
>> + (lambda _
>> + (setenv "DOMSUF" "(none)")
>> + (setenv "USE_IP" "TRUE")
>> + (setenv "IP_ADDRESS" "127.0.0.1")
>> + (system "./nss/tests/all.sh"))
>
> This last expression should be (zero? (system "./nss/tests/all.sh")), to
> signal an error if ./nss/tests/all.sh returns a non-zero status code.
OK.
>
>> + (alist-replace
>> + 'install
>> + (lambda* (#:key outputs #:allow-other-keys)
>> + (let* ((out (assoc-ref outputs "out"))
>> + (bin (string-append (assoc-ref outputs "bin") "/bin"))
>> + (inc (string-append out "/include/nss"))
>> + (lib (string-append out "/lib"))
>> + (obj (car (scandir "dist" (cut string-suffix?
>> "OBJ" <>))))
NSS contains many static libraries which I think will not mostly used
by other. How about split them to a 'static-lib' (or a better name).
>
> This looks potentially non-deterministic, if that 'scandir' call might
> return more than one element. If you expect only one, how about this
> instead:
>
> (obj (match (scandir "dist" (cut string-suffix? "OBJ" <>))
> ((obj) obj)))
>
> That way, if there's more than one, an error will be reported. You'll
> need to add (ice-9 match) to #:modules.
Adjusted.
>
> Mark
Updated patch:
[-- Attachment #2: 0001-gnu-Add-nss.patch --]
[-- Type: text/x-patch, Size: 11714 bytes --]
From f56c7ef06f8eb697e9b0e0eac2e6c8117520d5d0 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?=E5=AE=8B=E6=96=87=E6=AD=A6?= <iyzsong@gmail.com>
Date: Tue, 6 Jan 2015 23:57:31 +0800
Subject: [PATCH] gnu: Add nss.
* gnu/packages/patches/nss-pkgconfig.patch: New file.
* gnu-system.scm (dist_patch_DATA): Add it.
* gnu/packages/polkit.scm (nss): New variable.
---
gnu-system.am | 1 +
gnu/packages/patches/nss-pkgconfig.patch | 220 +++++++++++++++++++++++++++++++
gnu/packages/polkit.scm | 93 +++++++++++++
3 files changed, 314 insertions(+)
create mode 100644 gnu/packages/patches/nss-pkgconfig.patch
diff --git a/gnu-system.am b/gnu-system.am
index dc881bb..33d870c 100644
--- a/gnu-system.am
+++ b/gnu-system.am
@@ -422,6 +422,7 @@ dist_patch_DATA = \
gnu/packages/patches/mupdf-buildsystem-fix.patch \
gnu/packages/patches/mutt-CVE-2014-9116.patch \
gnu/packages/patches/net-tools-bitrot.patch \
+ gnu/packages/patches/nss-pkgconfig.patch \
gnu/packages/patches/nvi-assume-preserve-path.patch \
gnu/packages/patches/orpheus-cast-errors-and-includes.patch \
gnu/packages/patches/ots-no-include-missing-file.patch \
diff --git a/gnu/packages/patches/nss-pkgconfig.patch b/gnu/packages/patches/nss-pkgconfig.patch
new file mode 100644
index 0000000..3832dc3
--- /dev/null
+++ b/gnu/packages/patches/nss-pkgconfig.patch
@@ -0,0 +1,220 @@
+Install nss.pc and nss-config.
+Based on nss-3.17-gentoo-fixups.patch from nixpkgs.
+
+--- nss-3.17.1/nss/config/Makefile
++++ nss-3.17.1/nss/config/Makefile
+@@ -0,0 +1,40 @@
++CORE_DEPTH = ..
++DEPTH = ..
++
++include $(CORE_DEPTH)/coreconf/config.mk
++
++NSS_MAJOR_VERSION = `grep "NSS_VMAJOR" ../lib/nss/nss.h | awk '{print $$3}'`
++NSS_MINOR_VERSION = `grep "NSS_VMINOR" ../lib/nss/nss.h | awk '{print $$3}'`
++NSS_PATCH_VERSION = `grep "NSS_VPATCH" ../lib/nss/nss.h | awk '{print $$3}'`
++PREFIX = /usr
++
++all: export libs
++
++export:
++ # Create the nss.pc file
++ mkdir -p $(DIST)/lib/pkgconfig
++ sed -e "s,@prefix@,$(PREFIX)," \
++ -e "s,@exec_prefix@,\$${prefix}," \
++ -e "s,@libdir@,\$${prefix}/lib/nss," \
++ -e "s,@includedir@,\$${prefix}/include/nss," \
++ -e "s,@NSS_MAJOR_VERSION@,$(NSS_MAJOR_VERSION),g" \
++ -e "s,@NSS_MINOR_VERSION@,$(NSS_MINOR_VERSION)," \
++ -e "s,@NSS_PATCH_VERSION@,$(NSS_PATCH_VERSION)," \
++ nss.pc.in > nss.pc
++ chmod 0644 nss.pc
++ cp nss.pc $(DIST)/lib/pkgconfig
++
++ # Create the nss-config script
++ mkdir -p $(DIST)/bin
++ sed -e "s,@prefix@,$(PREFIX)," \
++ -e "s,@NSS_MAJOR_VERSION@,$(NSS_MAJOR_VERSION)," \
++ -e "s,@NSS_MINOR_VERSION@,$(NSS_MINOR_VERSION)," \
++ -e "s,@NSS_PATCH_VERSION@,$(NSS_PATCH_VERSION)," \
++ nss-config.in > nss-config
++ chmod 0755 nss-config
++ cp nss-config $(DIST)/bin
++
++libs:
++
++dummy: all export libs
++
+--- nss-3.17.1/nss/config/nss-config.in
++++ nss-3.17.1/nss/config/nss-config.in
+@@ -0,0 +1,145 @@
++#!/bin/sh
++
++prefix=@prefix@
++
++major_version=@NSS_MAJOR_VERSION@
++minor_version=@NSS_MINOR_VERSION@
++patch_version=@NSS_PATCH_VERSION@
++
++usage()
++{
++ cat <<EOF
++Usage: nss-config [OPTIONS] [LIBRARIES]
++Options:
++ [--prefix[=DIR]]
++ [--exec-prefix[=DIR]]
++ [--includedir[=DIR]]
++ [--libdir[=DIR]]
++ [--version]
++ [--libs]
++ [--cflags]
++Dynamic Libraries:
++ nss
++ ssl
++ smime
++ nssutil
++EOF
++ exit $1
++}
++
++if test $# -eq 0; then
++ usage 1 1>&2
++fi
++
++lib_ssl=yes
++lib_smime=yes
++lib_nss=yes
++lib_nssutil=yes
++
++while test $# -gt 0; do
++ case "$1" in
++ -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;;
++ *) optarg= ;;
++ esac
++
++ case $1 in
++ --prefix=*)
++ prefix=$optarg
++ ;;
++ --prefix)
++ echo_prefix=yes
++ ;;
++ --exec-prefix=*)
++ exec_prefix=$optarg
++ ;;
++ --exec-prefix)
++ echo_exec_prefix=yes
++ ;;
++ --includedir=*)
++ includedir=$optarg
++ ;;
++ --includedir)
++ echo_includedir=yes
++ ;;
++ --libdir=*)
++ libdir=$optarg
++ ;;
++ --libdir)
++ echo_libdir=yes
++ ;;
++ --version)
++ echo ${major_version}.${minor_version}.${patch_version}
++ ;;
++ --cflags)
++ echo_cflags=yes
++ ;;
++ --libs)
++ echo_libs=yes
++ ;;
++ ssl)
++ lib_ssl=yes
++ ;;
++ smime)
++ lib_smime=yes
++ ;;
++ nss)
++ lib_nss=yes
++ ;;
++ nssutil)
++ lib_nssutil=yes
++ ;;
++ *)
++ usage 1 1>&2
++ ;;
++ esac
++ shift
++done
++
++# Set variables that may be dependent upon other variables
++if test -z "$exec_prefix"; then
++ exec_prefix=`pkg-config --variable=exec_prefix nss`
++fi
++if test -z "$includedir"; then
++ includedir=`pkg-config --variable=includedir nss`
++fi
++if test -z "$libdir"; then
++ libdir=`pkg-config --variable=libdir nss`
++fi
++
++if test "$echo_prefix" = "yes"; then
++ echo $prefix
++fi
++
++if test "$echo_exec_prefix" = "yes"; then
++ echo $exec_prefix
++fi
++
++if test "$echo_includedir" = "yes"; then
++ echo $includedir
++fi
++
++if test "$echo_libdir" = "yes"; then
++ echo $libdir
++fi
++
++if test "$echo_cflags" = "yes"; then
++ echo -I$includedir
++fi
++
++if test "$echo_libs" = "yes"; then
++ libdirs=""
++ if test -n "$lib_ssl"; then
++ libdirs="$libdirs -lssl${major_version}"
++ fi
++ if test -n "$lib_smime"; then
++ libdirs="$libdirs -lsmime${major_version}"
++ fi
++ if test -n "$lib_nss"; then
++ libdirs="$libdirs -lnss${major_version}"
++ fi
++ if test -n "$lib_nssutil"; then
++ libdirs="$libdirs -lnssutil${major_version}"
++ fi
++ echo $libdirs
++fi
++
+--- nss-3.17.1/nss/config/nss.pc.in
++++ nss-3.17.1/nss/config/nss.pc.in
+@@ -0,0 +1,12 @@
++prefix=@prefix@
++exec_prefix=@exec_prefix@
++libdir=@libdir@
++includedir=@includedir@
++
++Name: NSS
++Description: Network Security Services
++Version: @NSS_MAJOR_VERSION@.@NSS_MINOR_VERSION@.@NSS_PATCH_VERSION@
++Requires: nspr >= 4.8
++Libs: -L${libdir} -lssl3 -lsmime3 -lnss3 -lnssutil3
++Cflags: -I${includedir}
++
+--- nss-3.17.1/nss/manifest.mn
++++ nss-3.17.1/nss/manifest.mn
+@@ -10,7 +10,7 @@
+
+ RELEASE = nss
+
+-DIRS = coreconf lib cmd
++DIRS = coreconf lib cmd config
+
+ ifdef NSS_BUILD_GTESTS
+ DIRS += external_tests
diff --git a/gnu/packages/polkit.scm b/gnu/packages/polkit.scm
index 2be1d0b..f54c0a3 100644
--- a/gnu/packages/polkit.scm
+++ b/gnu/packages/polkit.scm
@@ -1,5 +1,6 @@
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2014 Andreas Enge <andreas@enge.fr>
+;;; Copyright © 2015 Sou Bunnbu <iyzsong@gmail.com>
;;;
;;; This file is part of GNU Guix.
;;;
@@ -23,6 +24,8 @@
#:use-module (guix build-system cmake)
#:use-module (guix build-system gnu)
#:use-module (gnu packages)
+ #:use-module (gnu packages compression)
+ #:use-module (gnu packages databases)
#:use-module (gnu packages glib)
#:use-module (gnu packages linux)
#:use-module (gnu packages perl)
@@ -103,6 +106,96 @@ platform-neutral API for system level and libc-like functions. It is used
in the Mozilla clients.")
(license mpl2.0)))
+(define-public nss
+ (package
+ (name "nss")
+ (version "3.17.3")
+ (source (origin
+ (method url-fetch)
+ (uri (string-append
+ "ftp://ftp.mozilla.org/pub/mozilla.org/security/nss/"
+ "releases/NSS_3_17_3_RTM/src/nss-3.17.3.tar.gz"))
+ (sha256
+ (base32
+ "1m91z80x4zh1mxgf53bl33lp43gn1wxxx0y26mgz511gb81ykmgl"))
+ ;; Install nss.pc and nss-config.
+ (patches (list (search-patch "nss-pkgconfig.patch")))))
+ (build-system gnu-build-system)
+ (outputs '("out" "bin"))
+ (arguments
+ '(#:parallel-build? #f ; failed
+ #:make-flags
+ (let* ((out (assoc-ref %outputs "out"))
+ (nspr (string-append (assoc-ref %build-inputs "nspr")))
+ (rpath (string-append "-Wl,-rpath=" out "/lib/nss")))
+ (list "-C" "nss" (string-append "PREFIX=" out)
+ "NSDISTMODE=copy"
+ "NSS_USE_SYSTEM_SQLITE=1"
+ (string-append "NSPR_INCLUDE_DIR=" nspr "/include/nspr")
+ ;; Add $out/lib/nss to RPATH.
+ (string-append "RPATH=" rpath)
+ (string-append "LDFLAGS=" rpath)))
+ #:modules ((guix build gnu-build-system)
+ (guix build utils)
+ (ice-9 ftw)
+ (ice-9 match)
+ (srfi srfi-26))
+ #:imported-modules ((guix build gnu-build-system)
+ (guix build utils))
+ #:phases
+ (alist-replace
+ 'configure
+ (lambda* (#:key system inputs #:allow-other-keys)
+ (when (string-prefix? "x86_64" system)
+ (setenv "USE_64" "1")))
+ (alist-replace
+ 'check
+ (lambda _
+ (setenv "DOMSUF" "(none)")
+ (setenv "USE_IP" "TRUE")
+ (setenv "IP_ADDRESS" "127.0.0.1")
+ (zero? (system "./nss/tests/all.sh")))
+ (alist-replace
+ 'install
+ (lambda* (#:key outputs #:allow-other-keys)
+ (let* ((out (assoc-ref outputs "out"))
+ (bin (string-append (assoc-ref outputs "bin") "/bin"))
+ (inc (string-append out "/include/nss"))
+ (lib (string-append out "/lib/nss"))
+ (obj (match (scandir "dist" (cut string-suffix? "OBJ" <>))
+ ((obj) (string-append "dist/" obj)))))
+ ;; Install nss-config to $out/bin.
+ (mkdir-p (string-append out "/bin"))
+ (copy-file (string-append obj "/bin/nss-config")
+ (string-append out "/bin/nss-config"))
+ (delete-file (string-append obj "/bin/nss-config"))
+ ;; Install nss.pc to $out/lib/pkgconfig.
+ (mkdir-p (string-append out "/lib/pkgconfig"))
+ (copy-file (string-append obj "/lib/pkgconfig/nss.pc")
+ (string-append out "/lib/pkgconfig/nss.pc"))
+ (delete-file (string-append obj "/lib/pkgconfig/nss.pc"))
+ (rmdir (string-append obj "/lib/pkgconfig"))
+ ;; Install other files.
+ (copy-recursively "dist/public/nss" inc)
+ (copy-recursively (string-append obj "/bin") bin)
+ (copy-recursively (string-append obj "/lib") lib)))
+ %standard-phases)))))
+ (inputs
+ `(("sqlite" ,sqlite)
+ ("zlib" ,zlib)))
+ (propagated-inputs `(("nspr" ,nspr))) ; required by nss.pc.
+ (native-inputs `(("perl" ,perl)))
+ (home-page
+ "https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS")
+ (synopsis "Network Security Services")
+ (description
+ "Network Security Services (NSS) is a set of libraries designed to support
+cross-platform development of security-enabled client and server applications.
+Applications built with NSS can support SSL v2 and v3, TLS, PKCS #5, PKCS #7,
+PKCS #11, PKCS #12, S/MIME, X.509 v3 certificates, and other security
+standards.")
+ (license mpl2.0)))
+
(define-public polkit
(package
(name "polkit")
--
2.1.2
next prev parent reply other threads:[~2015-01-08 13:01 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-01-07 11:29 [PATCH] gnu: Add nss 宋文武
2015-01-07 16:50 ` Mark H Weaver
2015-01-08 13:00 ` 宋文武 [this message]
2015-01-10 21:06 ` Ludovic Courtès
2015-01-11 2:25 ` 宋文武
2015-01-11 10:52 ` Ludovic Courtès
2015-01-11 7:30 ` John Darrington
2015-01-11 7:51 ` 宋文武
2015-01-11 8:28 ` John Darrington
2015-01-11 11:03 ` wip-libreoffice status? Ludovic Courtès
2015-01-11 12:12 ` John Darrington
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87lhldmnpi.fsf@gmail.com \
--to=iyzsong@gmail.com \
--cc=guix-devel@gnu.org \
--cc=mhw@netris.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/guix.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.