]> wimlib.net Git - wimlib/blobdiff - Makefile.am
Rename --including-invalid-names to --include-invalid-names
[wimlib] / Makefile.am
index b3bb69170bec67e288ec797d61080788427615d0..f18a5ce0529ebb354bbe70286d620e8588f07589 100644 (file)
 ACLOCAL_AMFLAGS = -I m4
 
-AM_CPPFLAGS    = -I$(top_srcdir)/src $(WINDOWS_CPPFLAGS) \
+AM_CPPFLAGS    = -I$(top_srcdir)/include $(WINDOWS_CPPFLAGS) \
                  -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE
-AM_CFLAGS      = -std=gnu99
+
+AM_CFLAGS      = -std=gnu99 -Wmissing-prototypes -Wstrict-prototypes   \
+                 -Werror-implicit-function-declaration                 \
+                 -fno-common -Wundef -Wno-pointer-sign
+
+if WINDOWS_NATIVE_BUILD
+# This option is needed to make packed structures work as expected
+# with gcc 4.7+ (mingw) on Windows.
+AM_CFLAGS += -mno-ms-bitfields
+endif
 
 lib_LTLIBRARIES = libwim.la
 
-libwim_la_LDFLAGS = -version-info 5:0:0 $(WINDOWS_LDFLAGS)
+libwim_la_LDFLAGS = -version-info 8:0:1 $(WINDOWS_LDFLAGS)
 
 libwim_la_SOURCES =            \
        src/add_image.c         \
-       src/buffer_io.h         \
+       src/capture_common.c    \
        src/compress.c          \
-       src/compress.h          \
        src/decompress.c        \
-       src/decompress.h        \
        src/delete_image.c      \
        src/dentry.c            \
-       src/dentry.h            \
        src/encoding.c          \
-       src/endianness.h        \
        src/export_image.c      \
-       src/extract_image.c     \
+       src/extract.c           \
+       src/file_io.c           \
        src/hardlink.c          \
        src/header.c            \
        src/integrity.c         \
        src/join.c              \
-       src/list.h              \
        src/lookup_table.c      \
-       src/lookup_table.h      \
        src/lz77.c              \
        src/lzx-common.c        \
        src/lzx-compress.c      \
        src/lzx-decompress.c    \
-       src/lzx.h               \
        src/metadata_resource.c \
        src/mount_image.c       \
+       src/paths.c             \
        src/resource.c          \
        src/rbtree.c            \
-       src/rbtree.h            \
        src/security.c          \
-       src/security.h          \
        src/sha1.c              \
-       src/sha1.h              \
        src/split.c             \
-       src/symlink.c           \
-       src/timestamp.h         \
+       src/swm.c               \
+       src/reparse.c           \
+       src/timestamp.c         \
+       src/update_image.c      \
        src/util.c              \
-       src/util.h              \
        src/verify.c            \
        src/wim.c               \
-       src/wimlib.h            \
-       wimlib_tchar.h          \
-       src/wimlib_internal.h   \
        src/write.c             \
        src/xml.c               \
-       src/xml.h               \
        src/xpress-compress.c   \
-       src/xpress-decompress.c \
-       src/xpress.h
+       src/xpress-decompress.c \
+       include/wimlib/apply.h          \
+       include/wimlib/assert.h         \
+       include/wimlib/callback.h       \
+       include/wimlib/capture.h        \
+       include/wimlib/compiler.h       \
+       include/wimlib/compress.h       \
+       include/wimlib/decompress.h     \
+       include/wimlib/dentry.h         \
+       include/wimlib/encoding.h       \
+       include/wimlib/endianness.h     \
+       include/wimlib/error.h          \
+       include/wimlib/file_io.h        \
+       include/wimlib/header.h         \
+       include/wimlib/integrity.h      \
+       include/wimlib/list.h           \
+       include/wimlib/lookup_table.h   \
+       include/wimlib/lzx.h            \
+       include/wimlib/metadata.h       \
+       include/wimlib/paths.h          \
+       include/wimlib/rbtree.h         \
+       include/wimlib/reparse.h        \
+       include/wimlib/resource.h       \
+       include/wimlib/security.h       \
+       include/wimlib/sha1.h           \
+       include/wimlib/swm.h            \
+       include/wimlib/timestamp.h      \
+       include/wimlib/types.h          \
+       include/wimlib/util.h           \
+       include/wimlib/version.h        \
+       include/wimlib/wim.h            \
+       include/wimlib/write.h          \
+       include/wimlib/xml.h            \
+       include/wimlib/xpress.h
 
 if WITH_NTFS_3G
-libwim_la_SOURCES += src/ntfs-apply.c  \
-                    src/ntfs-capture.c
+libwim_la_SOURCES += src/ntfs-3g_apply.c       \
+                    src/ntfs-3g_capture.c      \
+                    include/wimlib/ntfs_3g.h
+endif
+
+if WINDOWS_NATIVE_BUILD
+libwim_la_SOURCES += src/win32_common.c                        \
+                    src/win32_apply.c                  \
+                    src/win32_capture.c                \
+                    src/win32_replacements.c           \
+                    include/wimlib/win32_common.h      \
+                    include/wimlib/win32.h
+else
+libwim_la_SOURCES += src/unix_apply.c          \
+                    src/unix_capture.c
 endif
 
 
+
 EXTRA_libwim_la_SOURCES = src/sha1-ssse3.asm
 libwim_la_DEPENDENCIES = $(SSSE3_SHA1_OBJ)
 STRIP_FPIC = sh $(top_srcdir)/build-aux/strip_fPIC.sh
@@ -95,7 +139,9 @@ libwim_la_CFLAGS =           \
 
 
 bin_PROGRAMS    = imagex
-imagex_SOURCES   = programs/imagex.c wimlib_tchar.h
+imagex_SOURCES   = programs/imagex.c   \
+                  include/wimlib.h     \
+                  include/wimlib_tchar.h
 imagex_LDADD    = $(top_builddir)/libwim.la
 imagex_CFLAGS    = $(AM_CFLAGS) $(WINDOWS_CFLAGS)
 
@@ -104,29 +150,30 @@ 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@"; \
+               cd $(DESTDIR)$(bindir) && ln -s "@IMAGEX_PROGNAME@" imagex; \
        fi
 
 uninstall-hook:
        if [ "@IMAGEX_PROGNAME@" != imagex ]; then \
                cd $(DESTDIR)$(bindir) && rm -f "@IMAGEX_PROGNAME@"; \
+               cd $(DESTDIR)$(bindir) && rm -f imagex; \
        fi
 
 dist_bin_SCRIPTS = programs/mkwinpeimg
 
-include_HEADERS = src/wimlib.h
+include_HEADERS = include/wimlib.h
 
 EXTRA_DIST =                                   \
        build-aux/strip_fPIC.sh                 \
        archlinux                               \
        debian                                  \
        rpm                                     \
+       examples                                \
        README.WINDOWS                          \
        programs/install.cmd                    \
        programs/wimapply.c                     \
@@ -150,6 +197,7 @@ wimlib_manpages =                           \
        doc/@IMAGEX_PROGNAME@-delete.1          \
        doc/@IMAGEX_PROGNAME@-dir.1             \
        doc/@IMAGEX_PROGNAME@-export.1          \
+       doc/@IMAGEX_PROGNAME@-extract.1         \
        doc/@IMAGEX_PROGNAME@-info.1            \
        doc/@IMAGEX_PROGNAME@-join.1            \
        doc/@IMAGEX_PROGNAME@-mount.1           \
@@ -157,6 +205,7 @@ wimlib_manpages =                           \
        doc/@IMAGEX_PROGNAME@-optimize.1        \
        doc/@IMAGEX_PROGNAME@-split.1           \
        doc/@IMAGEX_PROGNAME@-unmount.1         \
+       doc/@IMAGEX_PROGNAME@-update.1          \
        doc/mkwinpeimg.1
 
 man1_MANS = $(wimlib_manpages)
@@ -168,7 +217,8 @@ check_PROGRAMS = tests/tree-cmp
 tests_tree_cmp_SOURCES = tests/tree-cmp.c
 
 dist_check_SCRIPTS = tests/test-imagex \
-                    tests/test-imagex-capture_and_apply
+                    tests/test-imagex-capture_and_apply \
+                    tests/test-imagex-update_and_extract
 
 if WITH_FUSE
 dist_check_SCRIPTS += tests/test-imagex-mount
@@ -179,7 +229,7 @@ dist_check_SCRIPTS += tests/test-imagex-ntfs
 endif
 
 if WINDOWS_NATIVE_BUILD
-# TODO: The tests need to be re-written for Windows builds.
+# Tests are run manually for Windows builds.
 TESTS =
 else
 TESTS = $(dist_check_SCRIPTS)