Fri, 16 Jan 2009 10:58:21 +0100
Correct and improve code logic, buildconf, and packaging. In particular:
1. Use descriptive variable names <var>libs instead of just <var>.
2. Although Nokia states in all Qt builds that 'NOTE: When linking
against OpenSSL, you can override the default library names
through OPENSSL_LIBS.' and even gives an example, their own
configuration logic rejects such an attempt. Correct this by
hard coding the OpenSSL library string in the configure script.
3. Consistently use the whitespace substitution [\t ] throughout.
4. Patch the buggy INCPATH of SQL plugin Qmake project files.
5. Add the 'x11' configuration variable to the qtconfig Qmake
project using the src/gui/gui.pro file as a model. This is
needed for qtconfig although not in other tools, because
the qtconfig buildconf indirectly includes qt_x11_p.h which
is dependent on X11 headers.
6. Avoid 'ld.so: fatal: hardware capability unsupported: SSE2 AMD_3DNow'
on platforms for which the config.tests/unix/[3dnow|sse2] succeed
although unsopported at run time by testing for the x86-64
instruction set at build time and regulating hardware capabilities.
7. Correctly install the desinger plugin by explicitly building it.
8. Remove custom plugin installation logic which is unnecessary.
9. Correct removal of temporary paths from shared object files.
1 ##
2 ## cryptlib.spec -- OpenPKG RPM Package Specification
3 ## Copyright (c) 2000-2008 OpenPKG Foundation e.V. <http://openpkg.net/>
4 ##
5 ## Permission to use, copy, modify, and distribute this software for
6 ## any purpose with or without fee is hereby granted, provided that
7 ## the above copyright notice and this permission notice appear in all
8 ## copies.
9 ##
10 ## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
11 ## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
12 ## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
13 ## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
14 ## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
15 ## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
16 ## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
17 ## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
18 ## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
19 ## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
20 ## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
21 ## SUCH DAMAGE.
22 ##
24 # package version
25 %define V_full 3.3.2
26 %define V_comp 332
27 %define V_track 332
29 # package information
30 Name: cryptlib
31 Summary: Cryptography Library
32 URL: http://www.cs.auckland.ac.nz/~pgut001/cryptlib/
33 Vendor: Peter Gutmann
34 Packager: OpenPKG Foundation e.V.
35 Distribution: OpenPKG Community
36 Class: EVAL
37 Group: Cryptography
38 License: MIT-style
39 Version: %{V_full}
40 Release: 20090106
42 # list of sources
43 Source0: ftp://ftp.franken.de/pub/crypt/cryptlib/cl%{V_comp}.zip
44 Source1: ftp://ftp.franken.de/pub/crypt/cryptlib/manual.pdf
45 Source2: bn-sol.s
46 Patch0: cryptlib.patch
48 # build information
49 Prefix: %{l_prefix}
50 BuildRoot: %{l_buildroot}
51 BuildPreReq: OpenPKG, openpkg >= 20040130, make, gcc, infozip
52 PreReq: OpenPKG, openpkg >= 20040130
53 AutoReq: no
54 AutoReqProv: no
56 %description
57 CryptLib is a powerful security toolkit which allows even
58 inexperienced crypto programmers to easily add encryption and
59 authentication services to their software. The high-level interface
60 provides anyone with the ability to add strong security capabilities
61 to an application in as little as half an hour, without needing
62 to know any of the low-level details which make the encryption
63 or authentication work. Because of this, cryptlib dramatically
64 reduces the cost involved in adding security to new or existing
65 applications. CryptLib provides a standardised interface to a number
66 of popular encryption algorithms, as well as providing a high-level
67 interface which hides most of the implementation details and
68 provides an operating-system-independent encoding method which makes
69 it easy to transfer secured data from one operating environment to
70 another.
72 %track
73 prog cryptlib = {
74 version = %{V_track}
75 url = ftp://ftp.franken.de/pub/crypt/cryptlib/
76 regex = cl(__VER__)\.zip
77 transform = "s/^(\d\d)$/${1}0/, $_"
78 }
80 %prep
81 %setup -q -c -T
82 %{l_prefix}/bin/unzip -q -x %{SOURCE0}
83 cp %{SOURCE bn-sol.s} bn/
84 %patch -p0
85 %{l_shtool} subst -e 's;\r$;;' tools/*.pl tools/*.sh
86 %{l_shtool} subst -e 's;-xO3 *;;g' 's; *-O;;g' makefile
87 %{l_shtool} subst -e 's; *-O[1234];;g' 's; *-O;;g' makefile
89 %build
90 %{l_make} %{l_mflags -O} \
91 CC="%{l_cc} %{l_cflags -O}"
93 %install
94 rm -rf $RPM_BUILD_ROOT
95 %{l_shtool} mkdir -f -p -m 755 \
96 $RPM_BUILD_ROOT%{l_prefix}/include \
97 $RPM_BUILD_ROOT%{l_prefix}/lib \
98 $RPM_BUILD_ROOT%{l_prefix}/share/cryptlib
99 %{l_shtool} install -c -m 644 \
100 cryptlib.h $RPM_BUILD_ROOT%{l_prefix}/include/
101 %{l_shtool} install -c -m 644 \
102 libcl.a $RPM_BUILD_ROOT%{l_prefix}/lib/libcryptlib.a
103 %{l_shtool} install -c -m 644 \
104 %{SOURCE manual.pdf} $RPM_BUILD_ROOT%{l_prefix}/share/cryptlib/
105 %{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
106 %{l_files_std} \
107 '%doc %{l_prefix}/share/cryptlib/manual.pdf'
109 %files -f files
111 %clean
112 rm -rf $RPM_BUILD_ROOT