aboutsummaryrefslogtreecommitdiff
path: root/openssl/trunk/crypto/cast/c_enc.c
diff options
context:
space:
mode:
Diffstat (limited to 'openssl/trunk/crypto/cast/c_enc.c')
0 files changed, 0 insertions, 0 deletions
02:37:14 +0000 Turns out that all the mucking about with "ld -r" and "objcopy" wasn't' href='/sra/rpki.net/commit/pow/build.py?id=70095b82dd62f9187f4f90b047f3535a2951a03f'>70095b82
f05001f8



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53































                                                                      











                                                  
                                
                                                        

                                            
                                         



                        
"""
Hack to build our Python extension module.

In a sane world, we'd just use the excellent distutils package, which
would do all the work for us.  But we have this little problem of
sometimes needing to use a private copy of the OpenSSL libraries to
kludge around obsolete system libraries, and a further problem that
GNU ld has bizzare issues with linking static libraries into shared
objects on 64-bit platforms.

In the long term, this problem will go away, when everybody updates to
a reasonable version of OpenSSL with CMS and RFC 3779 support enabled.
When that happens, this whackiness should be replaced by a normal
setup.py using distutils.

In the meantime, we pull config information from distutils, but do the
build ourselves.

This is a minimal hack to get the job done, and probably a bit
fragile.  Much of the code is taken from python-config and the
distutils.sysconfig.customize_compiler.  If there's any real
documentation on how to do this sort of thing, I have not found it
yet.  YMMV.  Beware Of Dog.

$Id$
"""

import os, subprocess, sys

from distutils.sysconfig import (get_config_var as getvar,
                                 get_python_inc as getinc)

cmd = getvar("CC").split()
cmd.extend(("-c", "-o", "POW.o", "POW.c"))
cmd.extend(os.environ["AC_CFLAGS"].split())
cmd.append("-I%s" % getinc(plat_specific = False))
cmd.append("-I%s" % getinc(plat_specific = True))
cmd.extend(getvar("CFLAGS").split())
cmd.extend(getvar("CCSHARED").split())
print " ".join(cmd)
r = subprocess.call(cmd)
if r:
  sys.exit(r)

cmd = getvar("LDSHARED").split()
cmd.extend(("-o", "../rpkid/rpki/POW/_POW.so", "POW.o"))
cmd.extend(os.environ["AC_LDFLAGS"].split())
cmd.extend(getvar("LDFLAGS").split())
cmd.extend(os.environ["AC_LIBS"].split())
print " ".join(cmd)
r = subprocess.call(cmd)
if r:
  sys.exit(r)