X-Git-Url: http://git.sourceforge.jp/view?a=blobdiff_plain;f=configure.ac;h=159a6d851421d50f3d8f7066e3c7a267f1a92f2c;hb=55f16f128c2324e0ab7a595a193b5fdb320edecc;hp=cf44b29015c5c3afcce90332bdb4186793979fce;hpb=069e72a01212e9e510a92b5a6caccafb80b84158;p=lha%2Flha.git diff --git a/configure.ac b/configure.ac index cf44b29..159a6d8 100644 --- a/configure.ac +++ b/configure.ac @@ -1,5 +1,6 @@ # Process this file with autoconf to produce a configure script. -AC_INIT([LHa for UNIX], 1.14i-ac20020605, jca02266@nifty.ne.jp, lha) +AC_INIT([LHa for UNIX], 1.14i-ac20021115, jca02266@nifty.ne.jp, lha) +AC_CANONICAL_HOST AC_CANONICAL_TARGET AM_INIT_AUTOMAKE AM_CONFIG_HEADER(config.h) @@ -16,12 +17,13 @@ AC_MINIX AM_C_PROTOTYPES # Checks for libraries. +AC_SEARCH_LIBS(opendir, [mingwex]) # Checks for header files. AC_HEADER_DIRENT AC_HEADER_STDC AC_CHECK_HEADERS(fcntl.h limits.h sys/file.h sys/param.h sys/time.h) -AC_CHECK_HEADERS(pwd.h grp.h) +AC_CHECK_HEADERS(pwd.h grp.h utime.h inttypes.h stdint.h fnmatch.h) # Checks for typedefs, structures, and compiler characteristics. AC_C_CONST @@ -29,7 +31,8 @@ AC_HEADER_TIME AC_STRUCT_TM AC_STRUCT_TIMEZONE -AC_CHECK_TYPES([uid_t, gid_t]) +AC_CHECK_SIZEOF(long) +AC_CHECK_TYPES([uid_t, gid_t, long long, uint64_t, ssize_t]) AC_CHECK_MEMBERS([struct tm.tm_gmtoff, struct stat.st_ino],,, [ #if HAVE_SYS_TYPES_H @@ -54,23 +57,97 @@ AC_CHECK_MEMBERS([struct tm.tm_gmtoff, struct stat.st_ino],,, AC_TYPE_SIGNAL AC_FUNC_FORK AC_FUNC_UTIME_NULL -AC_CHECK_FUNCS(strchr strdup memcpy memset memmove) +AC_FUNC_FNMATCH +AC_CHECK_FUNCS(strchr strdup memcpy memset memmove strcasecmp) AC_CHECK_FUNCS(mktime timelocal tzset ftime gettimeofday utime) -AC_CHECK_FUNCS(mkdir rmdir ftruncate lchown mkstemp) -AC_CHECK_FUNCS(strcasecmp link) +AC_CHECK_FUNCS(mkdir rmdir ftruncate chsize lchown mkstemp link) AC_CHECK_FUNCS(getpwuid getgrgid getpwnam getgrnam) +AC_CHECK_FUNCS(iconv basename) +AC_REPLACE_FUNCS(vsnprintf fnmatch) if test $ac_header_dirent = no; then AC_LIBOBJ(lhdir) fi +# checking whether 8 bit clean or not +AC_CACHE_CHECK([whether strchr()/strrchr() is 8bit clean], + [lha_cv_func_strchr_8bit_clean], + AC_TRY_RUN([ +#if STDC_HEADERS +# include +#else +# if !HAVE_STRCHR +# define strchr index +# define strrchr rindex +# endif +char *strchr (), *strrchr (); +#endif + +main() +{ + char *s = "\377"; + if (strchr(s, 0xff) != s) exit(1); + if (strchr(s, '\377') != s) exit(1); + if (strrchr(s, 0xff) != s) exit(1); + if (strrchr(s, '\377') != s) exit(1); + exit(0); /* ok */ +} +], lha_cv_func_strchr_8bit_clean=yes, + lha_cv_func_strchr_8bit_clean=no, + lha_cv_func_strchr_8bit_clean=no)) + +if test x$lha_cv_func_strchr_8bit_clean = xyes; then + AC_DEFINE(STRCHR_8BIT_CLEAN, 1, + [Define to 1 if strchr()/strrchr() works correctly.]) +fi + +# checking whether the 2nd argument of gettimeofday() is effective or not. +# note that this timezone argument is obsolete. +AC_CACHE_CHECK([whether the 2nd argument of gettimeofday() is effective], + [lha_cv_func_gettimeofday_2nd_arg], + AC_TRY_RUN([ +#if TIME_WITH_SYS_TIME +# include +# include +#else +# if HAVE_SYS_TIME_H +# include +# else +# include +# endif +#endif + +main() +{ + struct timeval tv; + struct timezone tz; + + tz.tz_minuteswest = -1; + if (gettimeofday(&tv, &tz) == -1) + exit(1); + + if (tz.tz_minuteswest == -1) + exit(1); /* the timezone information is no given */ + + exit(0); +}], lha_cv_func_gettimeofday_2nd_arg=yes, + lha_cv_func_gettimeofday_2nd_arg=no, + lha_cv_func_gettimeofday_2nd_arg=no)) + +if test x$lha_cv_func_gettimeofday_2nd_arg = xyes; then + AC_DEFINE(GETTIMEOFDAY_HAS_2ND_ARG, 1, + [Define to 1 if the 2nd argument of gettimeofday() is effective.]) +fi + # support kanji code conversion AC_SUBST(DEF_KCODE) -AC_ARG_ENABLE(text_conv, +AC_MSG_CHECKING(kanji code conversion on text file) +AC_ARG_ENABLE(text-conv, AC_HELP_STRING([--enable-text-conv], [support text code convert from/to EUC [[default=yes]]]), , enable_text_conv=yes) +AC_MSG_RESULT($enable_text_conv) if test $enable_text_conv = yes; then DEF_KCODE=-DEUC fi @@ -80,8 +157,8 @@ AC_SUBST(SUPPORT_LZHUFF_METHOD) SUPPORT_LZHUFF_METHOD=-DSUPPORT_LH7 # whether use the -lh567- method -AC_MSG_CHECKING(default archive method is ) -AC_ARG_WITH(default_method, +AC_MSG_CHECKING(default archive method) +AC_ARG_WITH(default-method, AC_HELP_STRING([--with-default-method=[[567]]], [create the -lh[[567]]- archive default [[default=5]]]), [case $withval in @@ -93,8 +170,8 @@ AC_MSG_RESULT(-lh$with_default_method-) AC_DEFINE_UNQUOTED(DEFAULT_LZHUFF_METHOD, LZHUFF${with_default_method}_METHOD_NUM, [Define it to 5, 6 or 7 which you want to use -lhX- method, default]) # decide temporary path names -AC_MSG_CHECKING(template of the temporary file is ) -AC_ARG_WITH(tmp_file, +AC_MSG_CHECKING(template of the temporary file) +AC_ARG_WITH(tmp-file, AC_HELP_STRING([--with-tmp-file=TEMPLATE], [temporary file template [[default=/tmp/lhXXXXXX]]]), [case $withval in @@ -102,6 +179,7 @@ AC_ARG_WITH(tmp_file, no) ;; esac], with_tmp_file=/tmp/lhXXXXXX) + AC_MSG_RESULT($with_tmp_file) if test x"$with_tmp_file" != xno; then AC_DEFINE_UNQUOTED(TMP_FILENAME_TEMPLATE, "$with_tmp_file", @@ -109,41 +187,105 @@ if test x"$with_tmp_file" != xno; then fi # incremental indicator +AC_MSG_CHECKING(whether incremental indicator is needed) AC_ARG_ENABLE(indicator, AC_HELP_STRING([--enable-indicator], [need incremental indicator [[default=yes]]]), , # default enable_indicator=yes) + +AC_MSG_RESULT($enable_indicator) if test "x$enable_indicator" = xyes; then AC_DEFINE(NEED_INCREMENTAL_INDICATOR, 1, [Define to 1 if you want to use the incremental indicator]) fi # support multibyte filename -AC_ARG_ENABLE(multibyte-char, - AC_HELP_STRING([--enable-multibyte-char], - [support multibyte filename [[default=yes]]]), - , +AC_MSG_CHECKING(kanji code of filename) +AC_ARG_ENABLE(multibyte-filename, + AC_HELP_STRING([--enable-multibyte-filename], + [support multibyte filename. specify kanji code (euc, sjis, utf8 or auto) [[default=auto]]]),, # default - enable_multibyte_char=yes) -if test "x$enable_multibyte_char" = xyes; then - AC_DEFINE(MULTIBYTE_CHAR, 1, - [Define to 1 if you want to use multibyte filename]) + enable_multibyte_filename=auto) + +case $enable_multibyte_filename in +auto|yes) + AC_EGREP_CPP(SJIS,[ +#if defined(__CYGWIN__) || defined(__MINGW32__) || defined(__hpux) +SJIS +#endif], enable_multibyte_filename=CODE_SJIS, + AC_EGREP_CPP(UTF8,[ +#if defined(__APPLE__) /* for Mac OS X */ +UTF8 +#endif], enable_multibyte_filename=CODE_UTF8, + enable_multibyte_filename=CODE_EUC));; +sjis) enable_multibyte_filename=CODE_SJIS;; +euc) enable_multibyte_filename=CODE_EUC;; +utf8) enable_multibyte_filename=CODE_UTF8;; +no) ;; +*) AC_MSG_ERROR([you should specify auto, sjis or euc as your system filename code.]);; +esac + +AC_MSG_RESULT($enable_multibyte_filename) +if test x$enable_multibyte_filename != xno; then + AC_DEFINE_UNQUOTED(MULTIBYTE_FILENAME, $enable_multibyte_filename, + [Define to CODE_EUC or CODE_SJIS if you want to use multibyte filename]) + + case $target_os in + darwin*) + # for multibyte filename + LDFLAGS="$LDFLAGS -framework CoreFoundation" + ;; + esac fi # make user/group name extented header +AC_MSG_CHECKING(whether user/group name extended header is needed) AC_ARG_ENABLE(user-name-header, AC_HELP_STRING([--enable-user-name-header], [make user/group name extended header [[default=no]]]), , # default enable_user_name_header=no) -if test "x$user_name_header" = xyes; then + +AC_MSG_RESULT($enable_user_name_header) +if test "x$enable_user_name_header" = xyes; then AC_DEFINE(INCLUDE_OWNER_NAME_IN_HEADER, 1, [Define to 1 if you want to use the user/group name extened header]) fi -AC_CONFIG_FILES([Makefile src/Makefile man/Makefile]) +# backup old archive file +AC_MSG_CHECKING(whether backup file for old archive is left) +AC_ARG_ENABLE(backup-archive, + AC_HELP_STRING([--enable-backup-archive], + [backup old archive [[default=no]]]), + , + # default + enable_backup_archive=no) + +AC_MSG_RESULT($enable_backup_archive) +if test "x$enable_backup_archive" = xyes; then + AC_DEFINE(BACKUP_OLD_ARCHIVE, 1, + [Define to 1 if you want to leave an old archive]) +fi + +# enable this option if you need to ignore '.file' files +# (mainly for the Mac OS X) *experimental* +AC_MSG_CHECKING(whether enable -X option which ignore dot files) +AC_ARG_ENABLE(ignore-dot-files, + AC_HELP_STRING([--enable-ignore-dot-files], + [enable -X option [[default=no]]]), + , + # default + enable_ignore_dot_files=no) + +AC_MSG_RESULT($enable_ignore_dot_files) +if test "x$enable_ignore_dot_files" = xyes; then + AC_DEFINE(IGNORE_DOT_FILES, 1, + [Define to 1 if you want to ignore dot files with -X command line switch]) +fi + +AC_CONFIG_FILES([Makefile src/Makefile man/Makefile olddoc/Makefile]) AC_CONFIG_FILES([tests/Makefile tests/lha-test]) AC_OUTPUT