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.
michael@13 | 1 | .\" Automatically generated by Pod::Man v1.37, Pod::Parser v1.32 |
michael@13 | 2 | .\" |
michael@13 | 3 | .\" Standard preamble: |
michael@13 | 4 | .\" ======================================================================== |
michael@13 | 5 | .de Sh \" Subsection heading |
michael@13 | 6 | .br |
michael@13 | 7 | .if t .Sp |
michael@13 | 8 | .ne 5 |
michael@13 | 9 | .PP |
michael@13 | 10 | \fB\\$1\fR |
michael@13 | 11 | .PP |
michael@13 | 12 | .. |
michael@13 | 13 | .de Sp \" Vertical space (when we can't use .PP) |
michael@13 | 14 | .if t .sp .5v |
michael@13 | 15 | .if n .sp |
michael@13 | 16 | .. |
michael@13 | 17 | .de Vb \" Begin verbatim text |
michael@13 | 18 | .ft CW |
michael@13 | 19 | .nf |
michael@13 | 20 | .ne \\$1 |
michael@13 | 21 | .. |
michael@13 | 22 | .de Ve \" End verbatim text |
michael@13 | 23 | .ft R |
michael@13 | 24 | .fi |
michael@13 | 25 | .. |
michael@13 | 26 | .\" Set up some character translations and predefined strings. \*(-- will |
michael@13 | 27 | .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left |
michael@13 | 28 | .\" double quote, and \*(R" will give a right double quote. | will give a |
michael@13 | 29 | .\" real vertical bar. \*(C+ will give a nicer C++. Capital omega is used to |
michael@13 | 30 | .\" do unbreakable dashes and therefore won't be available. \*(C` and \*(C' |
michael@13 | 31 | .\" expand to `' in nroff, nothing in troff, for use with C<>. |
michael@13 | 32 | .tr \(*W-|\(bv\*(Tr |
michael@13 | 33 | .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' |
michael@13 | 34 | .ie n \{\ |
michael@13 | 35 | . ds -- \(*W- |
michael@13 | 36 | . ds PI pi |
michael@13 | 37 | . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch |
michael@13 | 38 | . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch |
michael@13 | 39 | . ds L" "" |
michael@13 | 40 | . ds R" "" |
michael@13 | 41 | . ds C` |
michael@13 | 42 | . ds C' |
michael@13 | 43 | 'br\} |
michael@13 | 44 | .el\{\ |
michael@13 | 45 | . ds -- \|\(em\| |
michael@13 | 46 | . ds PI \(*p |
michael@13 | 47 | . ds L" `` |
michael@13 | 48 | . ds R" '' |
michael@13 | 49 | 'br\} |
michael@13 | 50 | .\" |
michael@13 | 51 | .\" If the F register is turned on, we'll generate index entries on stderr for |
michael@13 | 52 | .\" titles (.TH), headers (.SH), subsections (.Sh), items (.Ip), and index |
michael@13 | 53 | .\" entries marked with X<> in POD. Of course, you'll have to process the |
michael@13 | 54 | .\" output yourself in some meaningful fashion. |
michael@13 | 55 | .if \nF \{\ |
michael@13 | 56 | . de IX |
michael@13 | 57 | . tm Index:\\$1\t\\n%\t"\\$2" |
michael@13 | 58 | .. |
michael@13 | 59 | . nr % 0 |
michael@13 | 60 | . rr F |
michael@13 | 61 | .\} |
michael@13 | 62 | .\" |
michael@13 | 63 | .\" For nroff, turn off justification. Always turn off hyphenation; it makes |
michael@13 | 64 | .\" way too many mistakes in technical documents. |
michael@13 | 65 | .hy 0 |
michael@13 | 66 | .if n .na |
michael@13 | 67 | .\" |
michael@13 | 68 | .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). |
michael@13 | 69 | .\" Fear. Run. Save yourself. No user-serviceable parts. |
michael@13 | 70 | . \" fudge factors for nroff and troff |
michael@13 | 71 | .if n \{\ |
michael@13 | 72 | . ds #H 0 |
michael@13 | 73 | . ds #V .8m |
michael@13 | 74 | . ds #F .3m |
michael@13 | 75 | . ds #[ \f1 |
michael@13 | 76 | . ds #] \fP |
michael@13 | 77 | .\} |
michael@13 | 78 | .if t \{\ |
michael@13 | 79 | . ds #H ((1u-(\\\\n(.fu%2u))*.13m) |
michael@13 | 80 | . ds #V .6m |
michael@13 | 81 | . ds #F 0 |
michael@13 | 82 | . ds #[ \& |
michael@13 | 83 | . ds #] \& |
michael@13 | 84 | .\} |
michael@13 | 85 | . \" simple accents for nroff and troff |
michael@13 | 86 | .if n \{\ |
michael@13 | 87 | . ds ' \& |
michael@13 | 88 | . ds ` \& |
michael@13 | 89 | . ds ^ \& |
michael@13 | 90 | . ds , \& |
michael@13 | 91 | . ds ~ ~ |
michael@13 | 92 | . ds / |
michael@13 | 93 | .\} |
michael@13 | 94 | .if t \{\ |
michael@13 | 95 | . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" |
michael@13 | 96 | . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' |
michael@13 | 97 | . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' |
michael@13 | 98 | . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' |
michael@13 | 99 | . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' |
michael@13 | 100 | . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' |
michael@13 | 101 | .\} |
michael@13 | 102 | . \" troff and (daisy-wheel) nroff accents |
michael@13 | 103 | .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V' |
michael@13 | 104 | .ds 8 \h'\*(#H'\(*b\h'-\*(#H' |
michael@13 | 105 | .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#] |
michael@13 | 106 | .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H' |
michael@13 | 107 | .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u' |
michael@13 | 108 | .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#] |
michael@13 | 109 | .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#] |
michael@13 | 110 | .ds ae a\h'-(\w'a'u*4/10)'e |
michael@13 | 111 | .ds Ae A\h'-(\w'A'u*4/10)'E |
michael@13 | 112 | . \" corrections for vroff |
michael@13 | 113 | .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u' |
michael@13 | 114 | .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u' |
michael@13 | 115 | . \" for low resolution devices (crt and lpr) |
michael@13 | 116 | .if \n(.H>23 .if \n(.V>19 \ |
michael@13 | 117 | \{\ |
michael@13 | 118 | . ds : e |
michael@13 | 119 | . ds 8 ss |
michael@13 | 120 | . ds o a |
michael@13 | 121 | . ds d- d\h'-1'\(ga |
michael@13 | 122 | . ds D- D\h'-1'\(hy |
michael@13 | 123 | . ds th \o'bp' |
michael@13 | 124 | . ds Th \o'LP' |
michael@13 | 125 | . ds ae ae |
michael@13 | 126 | . ds Ae AE |
michael@13 | 127 | .\} |
michael@13 | 128 | .rm #[ #] #H #V #F C |
michael@13 | 129 | .\" ======================================================================== |
michael@13 | 130 | .\" |
michael@13 | 131 | .IX Title "UUID 8" |
michael@13 | 132 | .TH UUID 8 "OpenPKG" "UUID(8)" "OpenPKG" |
michael@13 | 133 | .SH "NAME" |
michael@13 | 134 | \&\fBopenpkg uuid\fR \- OpenPKG UUID Update Utility |
michael@13 | 135 | .SH "SYNOPSIS" |
michael@13 | 136 | .IX Header "SYNOPSIS" |
michael@13 | 137 | \&\fBopenpkg uuid\fR [\fB\-\-verbose\fR] [\fB\-\-multicast\fR] \fBreset\fR|\fBupdate\fR|\fBinfo\fR |
michael@13 | 138 | .SH "DESCRIPTION" |
michael@13 | 139 | .IX Header "DESCRIPTION" |
michael@13 | 140 | The \fBopenpkg uuid\fR command is the maintenance utility for the \s-1DCE\s0 1.1 |
michael@13 | 141 | and \s-1ISO/IEC\s0 11578:1996 compliant \fIUniversally Unique Identifiers\fR |
michael@13 | 142 | (\s-1UUID\s0) of an \fBOpenPKG\fR instance. It is internally based on \fB\s-1OSSP\s0 |
michael@13 | 143 | uuid\fR. |
michael@13 | 144 | .PP |
michael@13 | 145 | UUIDs are 128 bit numbers which are intended to have a high likelihood |
michael@13 | 146 | of uniqueness over space and time and are computationally difficult |
michael@13 | 147 | to guess. They are globally unique identifiers which can be locally |
michael@13 | 148 | generated without contacting a global registration authority. UUIDs are |
michael@13 | 149 | intended as unique identifiers for both mass tagging objects with an |
michael@13 | 150 | extremely short lifetime and to reliably identifying very persistent |
michael@13 | 151 | objects across a network. The three classical \s-1UUID\s0 variants are \s-1DCE\s0 1.1 |
michael@13 | 152 | UUIDs of version 1 (time and node based), version 3 (name based) and |
michael@13 | 153 | version 4 (random number based). |
michael@13 | 154 | .PP |
michael@13 | 155 | For an \fBOpenPKG\fR instance, three different UUIDs are used: |
michael@13 | 156 | .ie n .IP "1. \fBOpenPKG Registry\fR (\*(C`UUID_REGISTRY\*(C')" 3 |
michael@13 | 157 | .el .IP "1. \fBOpenPKG Registry\fR (\f(CW\*(C`UUID_REGISTRY\*(C'\fR)" 3 |
michael@13 | 158 | .IX Item "1. OpenPKG Registry (UUID_REGISTRY)" |
michael@13 | 159 | This is a version 1 \s-1UUID\s0 which uniquely identifiers the \fBOpenPKG\fR |
michael@13 | 160 | instance for global registration purposes. It is generated just once in |
michael@13 | 161 | the lifetime of the \fBOpenPKG\fR instance. The value of this \s-1UUID\s0 cannot |
michael@13 | 162 | be recalculated deterministically. |
michael@13 | 163 | .ie n .IP "2. \fBOpenPKG Instance\fR (\*(C`UUID_INSTANCE\*(C')" 3 |
michael@13 | 164 | .el .IP "2. \fBOpenPKG Instance\fR (\f(CW\*(C`UUID_INSTANCE\*(C'\fR)" 3 |
michael@13 | 165 | .IX Item "2. OpenPKG Instance (UUID_INSTANCE)" |
michael@13 | 166 | This is a version 3 \s-1UUID\s0 which summarizes the \fBOpenPKG\fR |
michael@13 | 167 | instance parameters. Currently the values of the following |
michael@13 | 168 | particular OpenPKG \s-1RPM\s0 macros are uses as input: |
michael@13 | 169 | .Sp |
michael@13 | 170 | .Vb 5 |
michael@13 | 171 | \& %{l_openpkg_release} %{l_prefix} |
michael@13 | 172 | \& %{l_susr} %{l_suid} %{l_sgrp} %{l_sgid} |
michael@13 | 173 | \& %{l_musr} %{l_muid} %{l_mgrp} %{l_mgid} |
michael@13 | 174 | \& %{l_rusr} %{l_ruid} %{l_rgrp} %{l_rgid} |
michael@13 | 175 | \& %{l_nusr} %{l_nuid} %{l_ngrp} %{l_ngid} |
michael@13 | 176 | .Ve |
michael@13 | 177 | .Sp |
michael@13 | 178 | The value of this \s-1UUID\s0 can be recalculated deterministically and will |
michael@13 | 179 | not chance as long as none of the values of the above macro do not |
michael@13 | 180 | change. This \s-1UUID\s0 can be used for detecting OpenPKG release upgrades, |
michael@13 | 181 | accidentally changed UIDs or GIDs, etc. Notice that version 3 UUIDs are |
michael@13 | 182 | message digests (actually \s-1MD5\s0 based) and so are one-way functions which do |
michael@13 | 183 | not allow one to recalculate the input values from the \s-1UUID\s0. |
michael@13 | 184 | .ie n .IP "3. \fBOpenPKG Platform\fR (\*(C`UUID_PLATFORM\*(C')" 3 |
michael@13 | 185 | .el .IP "3. \fBOpenPKG Platform\fR (\f(CW\*(C`UUID_PLATFORM\*(C'\fR)" 3 |
michael@13 | 186 | .IX Item "3. OpenPKG Platform (UUID_PLATFORM)" |
michael@13 | 187 | This is a version 3 \s-1UUID\s0 which summarizes the \fBOpenPKG\fR platform |
michael@13 | 188 | parameters. Currently the OpenPKG \s-1RPM\s0 platform id plus the \s-1FQDN\s0 and \s-1IP\s0 |
michael@13 | 189 | address of the underlying host are used as input. This \s-1UUID\s0 can be used |
michael@13 | 190 | for detecting operating system and host changes. Notice that version |
michael@13 | 191 | 3 UUIDs are message digests (actually \s-1MD5\s0 based) and so are one-way |
michael@13 | 192 | functions which do not allow one to recalculate the input values from |
michael@13 | 193 | the \s-1UUID\s0. |
michael@13 | 194 | .SH "OPTIONS" |
michael@13 | 195 | .IX Header "OPTIONS" |
michael@13 | 196 | .IP "\fB\-\-verbose\fR" 4 |
michael@13 | 197 | .IX Item "--verbose" |
michael@13 | 198 | Print verbose messages during operation. |
michael@13 | 199 | .IP "\fB\-\-multicast\fR" 4 |
michael@13 | 200 | .IX Item "--multicast" |
michael@13 | 201 | Generate a random multicast \s-1MAC\s0 address instead of using the real \s-1IEEE\s0 |
michael@13 | 202 | 802 \s-1MAC\s0 address of the underlying host when generating the version 1 |
michael@13 | 203 | \&\s-1UUID\s0 \f(CW\*(C`UUID_REGISTRY\*(C'\fR. |
michael@13 | 204 | .SH "COMMANDS" |
michael@13 | 205 | .IX Header "COMMANDS" |
michael@13 | 206 | .IP "\fBreset\fR" 4 |
michael@13 | 207 | .IX Item "reset" |
michael@13 | 208 | This resets the three UUIDs \f(CW\*(C`UUID_REGISTRY\*(C'\fR, \f(CW\*(C`UUID_INSTANCE\*(C'\fR and |
michael@13 | 209 | \&\f(CW\*(C`UUID_PLATFORM\*(C'\fR to the \*(L"Nil \s-1UUID\s0\*(R". They are then automatically |
michael@13 | 210 | regenerated within one day if already done explicitly afterward with |
michael@13 | 211 | "\f(CW\*(C`openpkg uuid update\*(C'\fR". |
michael@13 | 212 | .IP "\fBupdate\fR" 4 |
michael@13 | 213 | .IX Item "update" |
michael@13 | 214 | This updates the three UUIDs \f(CW\*(C`UUID_REGISTRY\*(C'\fR, \f(CW\*(C`UUID_INSTANCE\*(C'\fR and |
michael@13 | 215 | \&\f(CW\*(C`UUID_PLATFORM\*(C'\fR to the \*(L"Nil \s-1UUID\s0\*(R". \f(CW\*(C`UUID_REGISTRY\*(C'\fR is kept unless it |
michael@13 | 216 | is the \*(L"Nil \s-1UUID\s0\*(R" (see "\f(CW\*(C`openpkg uuid reset\*(C'\fR" command above). The UUIDs |
michael@13 | 217 | \&\f(CW\*(C`UUID_INSTANCE\*(C'\fR and \f(CW\*(C`UUID_PLATFORM\*(C'\fR are updated only if their input |
michael@13 | 218 | values (and this way the resulting UUIDs) have changed. This operation |
michael@13 | 219 | is performed daily automatically. |
michael@13 | 220 | .IP "\fBinfo\fR" 4 |
michael@13 | 221 | .IX Item "info" |
michael@13 | 222 | This print summary page of identification information, including all |
michael@13 | 223 | UUIDs and all of their calculation inputs. |
michael@13 | 224 | .SH "FILES" |
michael@13 | 225 | .IX Header "FILES" |
michael@13 | 226 | The three UUIDs of the \fBOpenPKG\fR instance are stored in the file |
michael@13 | 227 | \&\f(CW\*(C`@l_prefix@/etc/openpkg/uuid\*(C'\fR in Bourne-Shell syntax. An example |
michael@13 | 228 | content is: |
michael@13 | 229 | .PP |
michael@13 | 230 | .Vb 3 |
michael@13 | 231 | \& UUID_REGISTRY="81eca44e-4d18-11d8-a837-0090272ff725" |
michael@13 | 232 | \& UUID_INSTANCE="c55a8d2d-31bb-3ae0-9edb-68337af61acc" |
michael@13 | 233 | \& UUID_PLATFORM="05ec2532-9e3f-37dc-a7ed-b291c2c463ed" |
michael@13 | 234 | .Ve |
michael@13 | 235 | .SH "CAVEATS" |
michael@13 | 236 | .IX Header "CAVEATS" |
michael@13 | 237 | By default and in full compliance with \s-1DCE\s0 1.1 and \s-1ISO/IEC\s0 11578:1996, |
michael@13 | 238 | the OpenPKG Registry \s-1UUID\s0 (\f(CW\*(C`UUID_REGISTRY\*(C'\fR) contains the \s-1IEEE\s0 802 \s-1MAC\s0 |
michael@13 | 239 | address of the underlying host. If this is not acceptable by local |
michael@13 | 240 | security policies you can easily at any time generate a new OpenPKG |
michael@13 | 241 | Registry \s-1UUID\s0 with a random multicast \s-1MAC\s0 address instead by running: |
michael@13 | 242 | .PP |
michael@13 | 243 | .Vb 2 |
michael@13 | 244 | \& $ openpkg uuid reset |
michael@13 | 245 | \& $ openpkg uuid --multicast update |
michael@13 | 246 | .Ve |
michael@13 | 247 | .SH "SEE ALSO" |
michael@13 | 248 | .IX Header "SEE ALSO" |
michael@13 | 249 | \&\fB\s-1OSSP\s0 uuid\fR <http://www.ossp.org/pkg/lib/uuid/>. |
michael@13 | 250 | .SH "HISTORY" |
michael@13 | 251 | .IX Header "HISTORY" |
michael@13 | 252 | The \fBopenpkg uuid\fR command first appeared in \fBOpenPKG 2.0\fR. |