Merge branch '4180_file_S'

* 4180_file_S:
  Ticket #4180: fix zip handling.
This commit is contained in:
Andrew Borodin 2021-02-28 16:41:32 +03:00
commit c9cf22d458
3 changed files with 61 additions and 16 deletions

View File

@ -115,23 +115,65 @@ fi
AC_SUBST(MANDOC) AC_SUBST(MANDOC)
AC_SUBST(MAN_FLAGS) AC_SUBST(MAN_FLAGS)
dnl Check for -L option to file dnl Check for -z, -L, and -S options to file
AC_CHECK_PROG(HAVE_FILECMD, file, true, false) AC_CHECK_PROG(HAVE_FILECMD, file, true, false)
if $HAVE_FILECMD; then if $HAVE_FILECMD; then
AC_MSG_CHECKING([for -L option to file command]) dnl Don't use the file command if it doesn't accept the -z option
AC_CACHE_VAL(mc_cv_filel, [ AC_MSG_CHECKING([for -z option to file command])
file -L . > /dev/null 2>&1 AC_CACHE_VAL(mc_cv_file_z, [
file -z . > /dev/null 2>&1
if test $? = 0; then if test $? = 0; then
mc_cv_filel=yes mc_cv_file_z=yes
else else
mc_cv_filel=no mc_cv_file_z=no
fi fi
]) ])
if test x$mc_cv_filel = xyes; then AC_MSG_RESULT([$mc_cv_file_z])
AC_DEFINE(FILE_L, 1, [Define if the file command accepts the -L option])
if test x$mc_cv_file_z = xyes; then
AC_DEFINE(USE_FILE_CMD, 1, [Define if the file command accepts the -z option])
else
AC_MSG_WARN([The file command doesn't accept the -z option and will not be used])
fi
if test x$mc_cv_file_z = xyes; then
dnl file is used; check -L and -S options
AC_MSG_CHECKING([for -L option to file command])
AC_CACHE_VAL(mc_cv_file_L, [
file -L . > /dev/null 2>&1
if test $? = 0; then
mc_cv_file_L=yes
else
mc_cv_file_L=no
fi
])
AC_MSG_RESULT([$mc_cv_file_L])
if test x$mc_cv_file_L = xyes; then
AC_DEFINE(FILE_L, "-L ", [Define if the file command accepts the -L option])
else
AC_DEFINE(FILE_L, "", [Define if the file command accepts the -L option])
fi
dnl The file command accepts the -S option since 5.33
AC_MSG_CHECKING([for -S option to file command])
AC_CACHE_VAL(mc_cv_file_S, [
file -S . > /dev/null 2>&1
if test $? = 0; then
mc_cv_file_S=yes
else
mc_cv_file_S=no
fi
])
AC_MSG_RESULT([$mc_cv_file_S])
if test x$mc_cv_file_S = xyes; then
AC_DEFINE(FILE_S, "-S ", [Define if file command accepts the -S option])
else
AC_DEFINE(FILE_S, "", [Define if file command accepts the -S option])
fi
fi fi
filel=$mc_cv_filel
AC_MSG_RESULT([$filel])
fi fi
dnl Only list browsers here that can be run in background (i.e. with `&') dnl Only list browsers here that can be run in background (i.e. with `&')

View File

@ -71,10 +71,11 @@
/*** file scope macro definitions ****************************************************************/ /*** file scope macro definitions ****************************************************************/
#ifdef FILE_L #ifdef USE_FILE_CMD
#define FILE_CMD "file -L -z " #define FILE_CMD "file -z " FILE_S FILE_L
#else #else
#define FILE_CMD "file -z " /* actually file is unused, but define some reasonable command */
#define FILE_CMD "file "
#endif #endif
/*** file scope type declarations ****************************************************************/ /*** file scope type declarations ****************************************************************/

View File

@ -317,7 +317,9 @@ static const struct
{ "old_esc_mode", &old_esc_mode }, { "old_esc_mode", &old_esc_mode },
{ "cd_symlinks", &mc_global.vfs.cd_symlinks }, { "cd_symlinks", &mc_global.vfs.cd_symlinks },
{ "show_all_if_ambiguous", &mc_global.widget.show_all_if_ambiguous }, { "show_all_if_ambiguous", &mc_global.widget.show_all_if_ambiguous },
#ifdef USE_FILE_CMD
{ "use_file_to_guess_type", &use_file_to_check_type }, { "use_file_to_guess_type", &use_file_to_check_type },
#endif
{ "alternate_plus_minus", &mc_global.tty.alternate_plus_minus }, { "alternate_plus_minus", &mc_global.tty.alternate_plus_minus },
{ "only_leading_plus_minus", &only_leading_plus_minus }, { "only_leading_plus_minus", &only_leading_plus_minus },
{ "show_output_starts_shell", &output_starts_shell }, { "show_output_starts_shell", &output_starts_shell },