X-Git-Url: https://wimlib.net/git/?p=wimlib;a=blobdiff_plain;f=Makefile.am;h=22e81ff0516aa4b1e46ccb373d8744ec61cd7a9a;hp=5aa4563de256154358639cdb615254eb1236642e;hb=ccba46cf8eb7849d340b24b035497ea50fb821b9;hpb=fd763f8533b72067aa38a08849e57f23aa300060 diff --git a/Makefile.am b/Makefile.am index 5aa4563d..22e81ff0 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,71 +1,115 @@ 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 -fno-strict-aliasing + +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 6:0:1 $(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,38 +139,41 @@ 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) +imagex_CFLAGS = $(AM_CFLAGS) $(WINDOWS_CFLAGS) -Wno-deprecated-declarations 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@"; \ + 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)