X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fdos.m4;h=868626e7e5942cd5e0ca34530546fea0e3ca38f5;hb=30ffdfca0db8e3dede862ce911a200ecc1894fd5;hp=618c1f437ea960a01f06af949eb6504b785babc5;hpb=f59bfc2aa2310796f88b9c60737d9a886451e2ac;p=gnulib.git diff --git a/m4/dos.m4 b/m4/dos.m4 index 618c1f437..868626e7e 100644 --- a/m4/dos.m4 +++ b/m4/dos.m4 @@ -1,25 +1,38 @@ -# serial 3 +#serial 5 # Define some macros required for proper operation of code in lib/*.c # on MSDOS/Windows systems. # From Jim Meyering. -AC_DEFUN(jm_AC_DOS, +AC_DEFUN([jm_AC_DOS], [ - # FIXME: this is incomplete. Add a compile-test that does something - # like this: - #if defined _WIN32 || defined __WIN32__ || defined __MSDOS__ + AC_CACHE_CHECK([whether system is Windows or MSDOS], [ac_cv_win_or_dos], + [ + AC_TRY_COMPILE([], + [#if !defined _WIN32 && !defined __WIN32__ && !defined __MSDOS__ +neither MSDOS nor Windows +#endif], + [ac_cv_win_or_dos=yes], + [ac_cv_win_or_dos=no]) + ]) + + if test x"$ac_cv_win_or_dos" = xyes; then + ac_fs_accepts_drive_letter_prefix=1 + ac_fs_backslash_is_file_name_separator=1 + else + ac_fs_accepts_drive_letter_prefix=0 + ac_fs_backslash_is_file_name_separator=0 + fi AH_VERBATIM(FILESYSTEM_PREFIX_LEN, [#if FILESYSTEM_ACCEPTS_DRIVE_LETTER_PREFIX # define FILESYSTEM_PREFIX_LEN(Filename) \ ((Filename)[0] && (Filename)[1] == ':' ? 2 : 0) -else +#else # define FILESYSTEM_PREFIX_LEN(Filename) 0 #endif]) - ac_fs_accepts_drive_letter_prefix=0 AC_DEFINE_UNQUOTED([FILESYSTEM_ACCEPTS_DRIVE_LETTER_PREFIX], $ac_fs_accepts_drive_letter_prefix, [Define on systems for which file names may have a so-called @@ -33,7 +46,6 @@ else # define ISSLASH(C) ((C) == '/') #endif]) - ac_fs_backslash_is_file_name_separator=0 AC_DEFINE_UNQUOTED([FILESYSTEM_BACKSLASH_IS_FILE_NAME_SEPARATOR], $ac_fs_backslash_is_file_name_separator, [Define if the backslash character may also serve as a file name