resetting manifest requested domain to floor
[platform/upstream/openconnect.git] / Makefile.am
1
2 SUBDIRS =
3 if BUILD_WWW
4 SUBDIRS += www
5 endif
6 if USE_NLS
7 SUBDIRS += po
8 endif
9
10 lib_LTLIBRARIES = libopenconnect.la
11 sbin_PROGRAMS = openconnect
12 man8_MANS = openconnect.8
13
14 AM_CPPFLAGS = -DLOCALEDIR="\"$(localedir)\""
15 openconnect_SOURCES = xml.c main.c dtls.c cstp.c mainloop.c tun.c
16
17 openconnect_CFLAGS = $(SSL_CFLAGS) $(DTLS_SSL_CFLAGS) $(LIBXML2_CFLAGS) $(LIBPROXY_CFLAGS) $(ZLIB_CFLAGS) $(LIBSTOKEN_CFLAGS)
18 openconnect_LDADD = libopenconnect.la $(SSL_LIBS) $(DTLS_SSL_LIBS) $(LIBXML2_LIBS) $(LIBPROXY_LIBS) $(ZLIB_LIBS) $(LIBINTL) $(LIBSTOKEN_LIBS)
19
20 library_srcs = ssl.c http.c auth.c library.c compat.c
21 lib_srcs_gnutls = gnutls.c gnutls_pkcs12.c gnutls_tpm.c
22 lib_srcs_openssl = openssl.c
23
24 POTFILES = $(openconnect_SOURCES) $(lib_srcs_openssl) $(lib_srcs_gnutls) $(library_srcs)
25
26 if OPENCONNECT_GNUTLS
27 library_srcs += $(lib_srcs_gnutls)
28 endif
29 if OPENCONNECT_OPENSSL
30 library_srcs += $(lib_srcs_openssl)
31 endif
32 libopenconnect_la_SOURCES = version.c $(library_srcs)
33 libopenconnect_la_CFLAGS = $(SSL_CFLAGS) $(LIBXML2_CFLAGS) $(LIBPROXY_CFLAGS) $(P11KIT_CFLAGS) $(TSS_CFLAGS) $(LIBSTOKEN_CFLAGS)
34 libopenconnect_la_LIBADD = $(SSL_LIBS) $(LIBXML2_LIBS) $(LIBPROXY_LIBS) $(LIBINTL) $(P11KIT_LIBS) $(TSS_LIBS) $(LIBSTOKEN_LIBS)
35 if OPENBSD_LIBTOOL
36 # OpenBSD's libtool doesn't have -version-number, but its -version-info arg
37 # does what GNU libtool's -version-number does. Which arguably is what the
38 # GNU -version-info arg ought to do too. I hate libtool.
39 LT_VER_ARG = -version-info
40 else
41 LT_VER_ARG = -version-number
42 endif
43 libopenconnect_la_LDFLAGS = $(LT_VER_ARG) @APIMAJOR@:@APIMINOR@
44 noinst_HEADERS = openconnect-internal.h openconnect.h gnutls.h
45 include_HEADERS = openconnect.h
46 if HAVE_SYMBOL_VERSIONING
47 libopenconnect_la_LDFLAGS += -Wl,@VERSION_SCRIPT_ARG@,libopenconnect.map
48 libopenconnect_la_DEPENDENCIES = libopenconnect.map
49 endif
50
51 pkgconfig_DATA = openconnect.pc
52
53 EXTRA_DIST = version.sh COPYING.LGPL $(lib_srcs_openssl) $(lib_srcs_gnutls) Android.mk
54
55 DISTCLEANFILES = $(pkgconfig_DATA)
56
57 main.o: version.c
58 version.c: $(library_srcs) $(lib_openssl_srcs) $(lib_gnutls_srcs) \
59            $(openconnect_SOURCES) Makefile.am configure.ac \
60            openconnect.h openconnect-internal.h version.sh @GITVERSIONDEPS@
61         @cd $(srcdir) && ./version.sh $(abs_builddir)/version.c
62
63 tmp-dist: uncommitted-check
64         $(MAKE) $(AM_MAKEFLAGS) VERSION=$(patsubst v%,%,$(shell git describe --tags)) DISTHOOK=0 dist
65
66 uncommitted-check:
67         @if ! git update-index --refresh --unmerged || \
68             ! git diff-index --name-only --exit-code HEAD; then \
69                 echo "*** ERROR: Uncommitted changes in above files"; exit 1; fi
70
71 DISTHOOK=1
72 dist-hook: uncommitted-check
73         @if [ $(DISTHOOK) = 1 ]; then \
74             if ! git rev-parse --verify v$(VERSION) &> /dev/null; then \
75                 echo "*** ERROR: Version v$(VERSION) is not tagged"; exit 1; fi ; \
76             if ! git diff --name-only --exit-code v$(VERSION) HEAD > /dev/null; then \
77                 echo "*** ERROR: Git checkout not at version v$(VERSION)"; exit 1; fi ; \
78         fi
79
80 sign-dist: dist
81         @for a in $(DIST_ARCHIVES); do \
82                 gpg --default-key 67E2F359 --detach-sign -a $$a ; \
83         done
84
85 tag: uncommitted-check
86         @if git rev-parse --verify v$(VERSION) &> /dev/null; then \
87                 echo "*** ERROR: Version v$(VERSION) is already tagged"; exit 1; fi
88         @sed 's/AC_INIT.*/AC_INIT(openconnect, $(VERSION))/' -i $(srcdir)/configure.ac
89         @sed 's/^v=.*/v="v$(VERSION)"/' -i $(srcdir)/version.sh
90         @( echo '1,/<!-- latest-release-start -->/p' ;\
91            echo '/<!-- latest-release-end -->/,$$p' ;\
92            echo  '/<!-- latest-release-start -->/a\' ;\
93            echo  'The latest release is <a href="ftp://ftp.infradead.org/pub/openconnect/openconnect-$(VERSION).tar.gz">OpenConnect v$(VERSION)</a>\' ;\
94            echo  '<i>(<a href="ftp://ftp.infradead.org/pub/openconnect/openconnect-$(VERSION).tar.gz.asc">PGP signature</a>)</i>,\' ;\
95            echo 'released on $(shell date +%Y-%m-%d) with the following changelog:</p>\' ;\
96            sed '0,/<b>OpenConnect HEAD/d;/<\/ul><br\/>/,$$d;s/$$/\\/' $(srcdir)/www/changelog.xml ;\
97            echo '     </ul>' ) | \
98          sed -n -f - -i $(srcdir)/www/download.xml
99         @( echo "s/Last modified: .*/Last modified: $(shell date)/" ;\
100            echo '/  <li><b>OpenConnect HEAD/a\' ;\
101            echo '     <ul>\' ;\
102            echo '       <li><i>No changelog entries yet</i></li>\';\
103            echo '     </ul><br/>\' ;  echo '  </li>\' ;\
104            echo '  <li><b><a href="ftp://ftp.infradead.org/pub/openconnect/openconnect-$(VERSION).tar.gz">OpenConnect v$(VERSION)</a></b>\' ;\
105            echo '     <i>(<a href="ftp://ftp.infradead.org/pub/openconnect/openconnect-$(VERSION).tar.gz.asc">PGP signature</a>)</i> &#8212; $(shell date +%Y-%m-%d)' ) | \
106                 sed -f - -i $(srcdir)/www/changelog.xml
107 # stupid syntax highlighting '
108         @cd $(srcdir) && git commit -s -m "Tag version $(VERSION)" configure.ac version.sh www/download.xml www/changelog.xml
109         @git tag v$(VERSION)
110         @cd $(srcdir) && ./autogen.sh
111
112 update-translations: po/$(PACKAGE).pot
113         @cd $(top_srcdir); if ! git diff-index --name-only --exit-code HEAD -- po/; then \
114                 echo "*** ERROR: Uncommitted changes in above files"; exit 1; \
115         else \
116                 for a in po/*.po; do \
117                         msgmerge -q -N -F $$a $(abs_builddir)/po/$(PACKAGE).pot | sed '0,/^#:/d' > $$a.old ; \
118                 done && \
119                 tx pull -af && \
120                 for a in po/*.po; do \
121                         msgmerge -q -N -F $$a $(abs_builddir)/po/$(PACKAGE).pot > $$a.new ; \
122                         sed '0,/^#:/d' $$a.new > $$a.new.cmp ; \
123                         if ! git ls-tree --name-only HEAD $$a | grep -q $$a; then \
124                                 echo New file $$a ; \
125                                 git add $$a ; \
126                         elif ! diff -u $$a.old $$a.new.cmp; then \
127                                 echo New changes for $$a; \
128                                 mv $$a.new $$a; \
129                         else \
130                                 git checkout -f HEAD $$a ; \
131                         fi ; \
132                         rm -f $$a.old $$a.new $$a.new.cmp ; \
133                 done && \
134                 ls po/*.po | sed 's%^po/\(.*\)\.po%\1%' > po/LINGUAS ; \
135                 if ! git update-index -q --refresh --unmerged || \
136                    ! git diff-index --name-only --exit-code HEAD -- po/ >/dev/null; then \
137                         git commit -s -m "Update translations from Transifex" -- po/ ; \
138                 else \
139                         echo No changes to commit ; \
140                 fi ; \
141         fi
142
143 upload-pot: po/$(PACKAGE).pot
144         @if [ ${abs_top_builddir} != $(abs_top_srcdir) ]; then \
145                 ln -sf ${abs_top_srcdir}/.tx .tx; fi
146         @tx push -s
147
148 po/$(PACKAGE).pot: $(POTFILES) Makefile
149         @echo "Regenerating $@" ; rm -f $@ && \
150         xgettext --directory=$(top_srcdir) --from-code=UTF-8 \
151           --add-comments --keyword=_ --keyword=N_ \
152           --package-name="@PACKAGE@" --package-version="@VERSION@" \
153           --msgid-bugs-address=openconnect-devel@lists.infradead.org \
154           -o $@ $(POTFILES)
155
156 Android.mk: Makefile.am
157         @for a in openconnect_SOURCES library_srcs lib_srcs_openssl noinst_HEADERS; do \
158                 FILES=`grep "^$$a = " $(top_srcdir)/Makefile.am`; \
159                 sed "s/^$$a = .*/$$FILES/" -i $(top_srcdir)/Android.mk;  \
160         done