]> wimlib.net Git - wimlib/blobdiff - Makefile.am
implement WIMLIB_INIT_FLAG_ASSUME_UTF8
[wimlib] / Makefile.am
index 6fab0027811f65120dcee8952f78b2eb178e0f60..24c07649cf99cc28246a923227d5fdb5ed95653a 100644 (file)
@@ -1,13 +1,12 @@
 ACLOCAL_AMFLAGS = -I m4
 
-AM_CPPFLAGS    = -I$(top_srcdir)/src
-
-AM_CFLAGS      = -std=gnu99 -D_LARGEFILE_SOURCE \
-                  -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE
+AM_CPPFLAGS    = -I$(top_srcdir)/src $(WINDOWS_CPPFLAGS) \
+                 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE
+AM_CFLAGS      = -std=gnu99 -fno-strict-aliasing
 
 lib_LTLIBRARIES = libwim.la
 
-libwim_la_LDFLAGS = -version-info 2:4:0
+libwim_la_LDFLAGS = -version-info 6:0:0 $(WINDOWS_LDFLAGS)
 
 libwim_la_SOURCES =            \
        src/add_image.c         \
@@ -52,6 +51,7 @@ libwim_la_SOURCES =           \
        src/verify.c            \
        src/wim.c               \
        src/wimlib.h            \
+       wimlib_tchar.h          \
        src/wimlib_internal.h   \
        src/write.c             \
        src/xml.c               \
@@ -82,11 +82,12 @@ libwim_la_LIBADD =          \
        $(LTLIBICONV)           \
        $(LIBCRYPTO_LDADD)      \
        $(SSSE3_SHA1_OBJ)       \
-       $(PTHREAD_LDADD)
+       $(PTHREAD_LDADD)        \
+       $(WINDOWS_LDADD)
 
 libwim_la_CFLAGS =             \
        $(AM_CFLAGS)            \
-       -fvisibility=hidden     \
+       $(VISIBILITY_CFLAGS)    \
        $(LIBXML2_CFLAGS)       \
        $(LIBFUSE_CFLAGS)       \
        $(LIBNTFS_3G_CFLAGS)    \
@@ -94,8 +95,28 @@ libwim_la_CFLAGS =           \
 
 
 bin_PROGRAMS    = imagex
-imagex_SOURCES   = programs/imagex.c
+imagex_SOURCES   = programs/imagex.c wimlib_tchar.h
 imagex_LDADD    = $(top_builddir)/libwim.la
+imagex_CFLAGS    = $(AM_CFLAGS) $(WINDOWS_CFLAGS)
+
+if WINDOWS_NATIVE_BUILD
+imagex_SOURCES += programs/imagex-win32.c      \
+                 programs/imagex-win32.h       \
+                 programs/wgetopt.c            \
+                 programs/wgetopt.h
+
+libwim_la_SOURCES += src/win32.c
+endif
+
+install-exec-hook:
+       if [ "@IMAGEX_PROGNAME@" != imagex ]; then \
+               cd $(DESTDIR)$(bindir) && mv -f imagex "@IMAGEX_PROGNAME@"; \
+       fi
+
+uninstall-hook:
+       if [ "@IMAGEX_PROGNAME@" != imagex ]; then \
+               cd $(DESTDIR)$(bindir) && rm -f "@IMAGEX_PROGNAME@"; \
+       fi
 
 dist_bin_SCRIPTS = programs/mkwinpeimg
 
@@ -106,6 +127,7 @@ EXTRA_DIST =                                        \
        archlinux                               \
        debian                                  \
        rpm                                     \
+       README.WINDOWS                          \
        programs/install.cmd                    \
        programs/wimapply.c                     \
        tests/common_tests.sh                   \
@@ -120,23 +142,26 @@ pkgconfig_DATA    = wimlib.pc
 
 $(pkgconfig_DATA): config.status
 
-man1_MANS =                    \
-       doc/imagex.1            \
-       doc/imagex-append.1     \
-       doc/imagex-apply.1      \
-       doc/imagex-capture.1    \
-       doc/imagex-delete.1     \
-       doc/imagex-dir.1        \
-       doc/imagex-export.1     \
-       doc/imagex-info.1       \
-       doc/imagex-join.1       \
-       doc/imagex-mount.1      \
-       doc/imagex-mountrw.1    \
-       doc/imagex-optimize.1   \
-       doc/imagex-split.1      \
-       doc/imagex-unmount.1    \
+wimlib_manpages =                              \
+       doc/@IMAGEX_PROGNAME@.1                 \
+       doc/@IMAGEX_PROGNAME@-append.1          \
+       doc/@IMAGEX_PROGNAME@-apply.1           \
+       doc/@IMAGEX_PROGNAME@-capture.1         \
+       doc/@IMAGEX_PROGNAME@-delete.1          \
+       doc/@IMAGEX_PROGNAME@-dir.1             \
+       doc/@IMAGEX_PROGNAME@-export.1          \
+       doc/@IMAGEX_PROGNAME@-info.1            \
+       doc/@IMAGEX_PROGNAME@-join.1            \
+       doc/@IMAGEX_PROGNAME@-mount.1           \
+       doc/@IMAGEX_PROGNAME@-mountrw.1         \
+       doc/@IMAGEX_PROGNAME@-optimize.1        \
+       doc/@IMAGEX_PROGNAME@-split.1           \
+       doc/@IMAGEX_PROGNAME@-unmount.1         \
        doc/mkwinpeimg.1
 
+man1_MANS = $(wimlib_manpages)
+DISTCLEANFILES = $(wimlib_manpages)
+
 $(man1_MANS): config.status
 
 check_PROGRAMS = tests/tree-cmp
@@ -153,5 +178,10 @@ if WITH_NTFS_3G
 dist_check_SCRIPTS += tests/test-imagex-ntfs
 endif
 
+if WINDOWS_NATIVE_BUILD
+# TODO: The tests need to be re-written for Windows builds.
+TESTS =
+else
 TESTS = $(dist_check_SCRIPTS)
+endif