mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-18 09:19:24 +03:00
Merge branch '3972_fix_illumos'
Signed-off-by: Yury V. Zaytsev <yury@shurup.com>
This commit is contained in:
commit
a24d45ffab
18
autogen.sh
18
autogen.sh
@ -11,16 +11,20 @@ cd "$srcdir"
|
|||||||
${AUTORECONF:-autoreconf} --verbose --install --force -I m4 ${AUTORECONF_FLAGS}
|
${AUTORECONF:-autoreconf} --verbose --install --force -I m4 ${AUTORECONF_FLAGS}
|
||||||
|
|
||||||
# Customize the INSTALL file
|
# Customize the INSTALL file
|
||||||
rm -f INSTALL && ln -s doc/INSTALL
|
rm -f INSTALL && ln -s doc/INSTALL .
|
||||||
|
|
||||||
# Generate po/POTFILES.in
|
# Generate po/POTFILES.in
|
||||||
${XGETTEXT:-xgettext} --keyword=_ --keyword=N_ --keyword=Q_ --output=- \
|
if ! xgettext -h 2>&1 | grep -e '--keyword=' >/dev/null ; then
|
||||||
|
echo "gettext is unable to extract translations, set XGETTEXT to GNU gettext!" >&2
|
||||||
|
else
|
||||||
|
${XGETTEXT:-xgettext} --keyword=_ --keyword=N_ --keyword=Q_ --output=- \
|
||||||
`find . -name '*.[ch]'` | ${SED-sed} -ne '/^#:/{s/#://;s/:[0-9]*/\
|
`find . -name '*.[ch]'` | ${SED-sed} -ne '/^#:/{s/#://;s/:[0-9]*/\
|
||||||
/g;s/ //g;p;}' | \
|
/g;s/ //g;p;}' | \
|
||||||
grep -v '^$' | sort | uniq >po/POTFILES.in
|
grep -v '^$' | sort | uniq >po/POTFILES.in
|
||||||
|
fi
|
||||||
$srcdir/version.sh "$srcdir"
|
|
||||||
|
"$srcdir/version.sh" "$srcdir"
|
||||||
if test -x $srcdir/configure.mc; then
|
|
||||||
$srcdir/configure.mc "$@"
|
if test -x "$srcdir/configure.mc"; then
|
||||||
|
"$srcdir/configure.mc" "$@"
|
||||||
fi
|
fi
|
||||||
|
@ -705,6 +705,7 @@ tests/lib/mcconfig/Makefile
|
|||||||
tests/lib/search/Makefile
|
tests/lib/search/Makefile
|
||||||
tests/lib/strutil/Makefile
|
tests/lib/strutil/Makefile
|
||||||
tests/lib/vfs/Makefile
|
tests/lib/vfs/Makefile
|
||||||
|
tests/lib/vfs/mc.charsets
|
||||||
tests/lib/widget/Makefile
|
tests/lib/widget/Makefile
|
||||||
tests/src/Makefile
|
tests/src/Makefile
|
||||||
tests/src/filemanager/Makefile
|
tests/src/filemanager/Makefile
|
||||||
|
@ -267,17 +267,16 @@ get_codepage_index (const char *id)
|
|||||||
gboolean
|
gboolean
|
||||||
is_supported_encoding (const char *encoding)
|
is_supported_encoding (const char *encoding)
|
||||||
{
|
{
|
||||||
gboolean result = FALSE;
|
GIConv coder;
|
||||||
guint t;
|
gboolean result;
|
||||||
|
|
||||||
for (t = 0; t < codepages->len; t++)
|
if (encoding == NULL)
|
||||||
{
|
return FALSE;
|
||||||
const char *id;
|
|
||||||
|
|
||||||
id = ((codepage_desc *) g_ptr_array_index (codepages, t))->id;
|
|
||||||
result |= (g_ascii_strncasecmp (encoding, id, strlen (id)) == 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
coder = str_crt_conv_from (encoding);
|
||||||
|
result = coder != INVALID_CONV;
|
||||||
|
if (result)
|
||||||
|
str_close_conv (coder);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -364,6 +363,8 @@ str_nconvert_to_display (const char *str, int len)
|
|||||||
return g_string_new (str);
|
return g_string_new (str);
|
||||||
|
|
||||||
conv = str_crt_conv_from (cp_source);
|
conv = str_crt_conv_from (cp_source);
|
||||||
|
if (conv == INVALID_CONV)
|
||||||
|
return g_string_new (str);
|
||||||
|
|
||||||
buff = g_string_new ("");
|
buff = g_string_new ("");
|
||||||
str_nconvert (conv, str, len, buff);
|
str_nconvert (conv, str, len, buff);
|
||||||
@ -396,6 +397,8 @@ str_nconvert_to_input (const char *str, int len)
|
|||||||
return g_string_new (str);
|
return g_string_new (str);
|
||||||
|
|
||||||
conv = str_crt_conv_to (cp_source);
|
conv = str_crt_conv_to (cp_source);
|
||||||
|
if (conv == INVALID_CONV)
|
||||||
|
return g_string_new (str);
|
||||||
|
|
||||||
buff = g_string_new ("");
|
buff = g_string_new ("");
|
||||||
str_nconvert (conv, str, len, buff);
|
str_nconvert (conv, str, len, buff);
|
||||||
|
@ -57,18 +57,16 @@ static const char *const str_utf8_encodings[] = {
|
|||||||
|
|
||||||
/* standard 8bit encodings, no wide or multibytes characters */
|
/* standard 8bit encodings, no wide or multibytes characters */
|
||||||
static const char *const str_8bit_encodings[] = {
|
static const char *const str_8bit_encodings[] = {
|
||||||
/* Solaris has different names of Windows 1251 encoding */
|
|
||||||
#ifdef __sun
|
|
||||||
"ansi-1251",
|
|
||||||
"ansi1251",
|
|
||||||
#else
|
|
||||||
"cp-1251",
|
"cp-1251",
|
||||||
"cp1251",
|
"cp1251",
|
||||||
#endif
|
/* solaris */
|
||||||
|
"ansi-1251",
|
||||||
|
"ansi1251",
|
||||||
"cp-1250",
|
"cp-1250",
|
||||||
"cp1250",
|
"cp1250",
|
||||||
"cp-866",
|
"cp-866",
|
||||||
"cp866",
|
"cp866",
|
||||||
|
/* glibc */
|
||||||
"ibm-866",
|
"ibm-866",
|
||||||
"ibm866",
|
"ibm866",
|
||||||
"cp-850",
|
"cp-850",
|
||||||
@ -274,7 +272,7 @@ str_crt_conv_from (const char *from_enc)
|
|||||||
void
|
void
|
||||||
str_close_conv (GIConv conv)
|
str_close_conv (GIConv conv)
|
||||||
{
|
{
|
||||||
if (conv != str_cnv_not_convert)
|
if (conv != INVALID_CONV && conv != str_cnv_not_convert)
|
||||||
g_iconv_close (conv);
|
g_iconv_close (conv);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -920,11 +920,21 @@ canonicalize_pathname_custom (char *path, canon_path_flags_t flags)
|
|||||||
{
|
{
|
||||||
/* "token/../foo" -> "foo" */
|
/* "token/../foo" -> "foo" */
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
if ((strncmp (s, VFS_ENCODING_PREFIX, enc_prefix_len) == 0)
|
if (strncmp (s, VFS_ENCODING_PREFIX, enc_prefix_len) == 0)
|
||||||
&& (is_supported_encoding (s + enc_prefix_len)))
|
{
|
||||||
|
char *enc;
|
||||||
|
|
||||||
|
enc = vfs_get_encoding (s, -1);
|
||||||
|
|
||||||
|
if (is_supported_encoding (enc))
|
||||||
/* special case: remove encoding */
|
/* special case: remove encoding */
|
||||||
str_move (s, p + 1);
|
str_move (s, p + 1);
|
||||||
else
|
else
|
||||||
|
str_move (s, p + 4);
|
||||||
|
|
||||||
|
g_free (enc);
|
||||||
|
}
|
||||||
|
else
|
||||||
#endif /* HAVE_CHARSET */
|
#endif /* HAVE_CHARSET */
|
||||||
str_move (s, p + 4);
|
str_move (s, p + 4);
|
||||||
}
|
}
|
||||||
@ -947,9 +957,18 @@ canonicalize_pathname_custom (char *path, canon_path_flags_t flags)
|
|||||||
if (s == lpath + 1)
|
if (s == lpath + 1)
|
||||||
s[0] = '\0';
|
s[0] = '\0';
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
else if ((strncmp (s, VFS_ENCODING_PREFIX, enc_prefix_len) == 0)
|
else if (strncmp (s, VFS_ENCODING_PREFIX, enc_prefix_len) == 0)
|
||||||
&& (is_supported_encoding (s + enc_prefix_len)))
|
|
||||||
{
|
{
|
||||||
|
char *enc;
|
||||||
|
gboolean ok;
|
||||||
|
|
||||||
|
enc = vfs_get_encoding (s, -1);
|
||||||
|
ok = is_supported_encoding (enc);
|
||||||
|
g_free (enc);
|
||||||
|
|
||||||
|
if (!ok)
|
||||||
|
goto last;
|
||||||
|
|
||||||
/* special case: remove encoding */
|
/* special case: remove encoding */
|
||||||
s[0] = '.';
|
s[0] = '.';
|
||||||
s[1] = '.';
|
s[1] = '.';
|
||||||
@ -966,6 +985,7 @@ canonicalize_pathname_custom (char *path, canon_path_flags_t flags)
|
|||||||
#endif /* HAVE_CHARSET */
|
#endif /* HAVE_CHARSET */
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
last:
|
||||||
if (s >= lpath + url_delim_len
|
if (s >= lpath + url_delim_len
|
||||||
&& strncmp (s - url_delim_len, VFS_PATH_URL_DELIMITER, url_delim_len) == 0)
|
&& strncmp (s - url_delim_len, VFS_PATH_URL_DELIMITER, url_delim_len) == 0)
|
||||||
*s = '\0';
|
*s = '\0';
|
||||||
|
@ -182,42 +182,6 @@ vfs_canon (const char *path)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
|
||||||
|
|
||||||
#ifdef HAVE_CHARSET
|
|
||||||
/** get encoding after last #enc: or NULL, if part does not contain #enc:
|
|
||||||
*
|
|
||||||
* @param path null-terminated string
|
|
||||||
* @param len the maximum length of path, where #enc: should be searched
|
|
||||||
*
|
|
||||||
* @return newly allocated string.
|
|
||||||
*/
|
|
||||||
|
|
||||||
static char *
|
|
||||||
vfs_get_encoding (const char *path, ssize_t len)
|
|
||||||
{
|
|
||||||
char *semi;
|
|
||||||
|
|
||||||
/* try found #enc: */
|
|
||||||
semi = g_strrstr_len (path, len, VFS_ENCODING_PREFIX);
|
|
||||||
if (semi == NULL)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
if (semi == path || IS_PATH_SEP (semi[-1]))
|
|
||||||
{
|
|
||||||
char *slash;
|
|
||||||
|
|
||||||
semi += strlen (VFS_ENCODING_PREFIX); /* skip "#enc:" */
|
|
||||||
slash = strchr (semi, PATH_SEP);
|
|
||||||
if (slash != NULL)
|
|
||||||
return g_strndup (semi, slash - semi);
|
|
||||||
return g_strdup (semi);
|
|
||||||
}
|
|
||||||
|
|
||||||
return vfs_get_encoding (path, semi - path);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
/** Extract the hostname and username from the path
|
/** Extract the hostname and username from the path
|
||||||
*
|
*
|
||||||
@ -896,8 +860,8 @@ vfs_path_element_clone (const vfs_path_element_t *element)
|
|||||||
new_element->vfs_prefix = g_strdup (element->vfs_prefix);
|
new_element->vfs_prefix = g_strdup (element->vfs_prefix);
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
new_element->encoding = g_strdup (element->encoding);
|
new_element->encoding = g_strdup (element->encoding);
|
||||||
if (vfs_path_element_need_cleanup_converter (element) && new_element->encoding != NULL)
|
if (vfs_path_element_need_cleanup_converter (element) && element->encoding != NULL)
|
||||||
new_element->dir.converter = str_crt_conv_from (new_element->encoding);
|
new_element->dir.converter = str_crt_conv_from (element->encoding);
|
||||||
else
|
else
|
||||||
new_element->dir.converter = element->dir.converter;
|
new_element->dir.converter = element->dir.converter;
|
||||||
#endif
|
#endif
|
||||||
@ -1071,6 +1035,39 @@ vfs_prefix_to_class (const char *prefix)
|
|||||||
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
|
|
||||||
|
/** get encoding after last #enc: or NULL, if part does not contain #enc:
|
||||||
|
*
|
||||||
|
* @param path null-terminated string
|
||||||
|
* @param len the maximum length of path, where #enc: should be searched
|
||||||
|
*
|
||||||
|
* @return newly allocated string.
|
||||||
|
*/
|
||||||
|
|
||||||
|
char *
|
||||||
|
vfs_get_encoding (const char *path, ssize_t len)
|
||||||
|
{
|
||||||
|
char *semi;
|
||||||
|
|
||||||
|
/* try found #enc: */
|
||||||
|
semi = g_strrstr_len (path, len, VFS_ENCODING_PREFIX);
|
||||||
|
if (semi == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if (semi == path || IS_PATH_SEP (semi[-1]))
|
||||||
|
{
|
||||||
|
char *slash;
|
||||||
|
|
||||||
|
semi += strlen (VFS_ENCODING_PREFIX); /* skip "#enc:" */
|
||||||
|
slash = strchr (semi, PATH_SEP);
|
||||||
|
if (slash != NULL)
|
||||||
|
return g_strndup (semi, slash - semi);
|
||||||
|
return g_strdup (semi);
|
||||||
|
}
|
||||||
|
|
||||||
|
return vfs_get_encoding (path, semi - path);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
/**
|
/**
|
||||||
* Check if need cleanup charset converter for vfs_path_element_t
|
* Check if need cleanup charset converter for vfs_path_element_t
|
||||||
*
|
*
|
||||||
|
@ -82,6 +82,7 @@ void vfs_path_element_free (vfs_path_element_t * element);
|
|||||||
struct vfs_class *vfs_prefix_to_class (const char *prefix);
|
struct vfs_class *vfs_prefix_to_class (const char *prefix);
|
||||||
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
|
char *vfs_get_encoding(const char *path, ssize_t len);
|
||||||
gboolean vfs_path_element_need_cleanup_converter (const vfs_path_element_t * element);
|
gboolean vfs_path_element_need_cleanup_converter (const vfs_path_element_t * element);
|
||||||
vfs_path_t *vfs_path_change_encoding (vfs_path_t * vpath, const char *encoding);
|
vfs_path_t *vfs_path_change_encoding (vfs_path_t * vpath, const char *encoding);
|
||||||
#endif
|
#endif
|
||||||
|
@ -18,16 +18,27 @@ AC_DEFUN([mc_I18N],[
|
|||||||
have_charset=yes
|
have_charset=yes
|
||||||
charset_msg="yes"
|
charset_msg="yes"
|
||||||
|
|
||||||
|
AC_CHECK_HEADERS([gnu/libc-version.h])
|
||||||
|
|
||||||
dnl Solaris has different name of Windows 1251 encoding
|
dnl Solaris has different name of Windows 1251 encoding
|
||||||
case $host_os in
|
case $host_os in
|
||||||
solaris*)
|
solaris*)
|
||||||
CP1251="ANSI-1251"
|
ENCODING_CP1251="ANSI-1251"
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
CP1251="CP1251"
|
ENCODING_CP1251="CP1251"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
AC_SUBST(CP1251)
|
if test "x$ac_cv_header_gnu_libc_version_h" != "xno"; then
|
||||||
|
ENCODING_CP866="IBM866"
|
||||||
|
ENCODING_ISO8859="ISO-8859"
|
||||||
|
else
|
||||||
|
ENCODING_CP866="CP866"
|
||||||
|
ENCODING_ISO8859="ISO8859"
|
||||||
|
fi
|
||||||
|
|
||||||
|
AC_SUBST(ENCODING_CP1251)
|
||||||
|
AC_SUBST(ENCODING_CP866)
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
ASCII 7-bit ASCII
|
ASCII 7-bit ASCII
|
||||||
ISO-8859-1 ISO 8859-1
|
@ENCODING_ISO8859@-1 ISO 8859-1
|
||||||
ISO-8859-2 ISO 8859-2
|
@ENCODING_ISO8859@-2 ISO 8859-2
|
||||||
ISO-8859-5 ISO 8859-5
|
@ENCODING_ISO8859@-5 ISO 8859-5
|
||||||
CP1250 Windows 1250
|
CP1250 Windows 1250
|
||||||
@CP1251@ Windows 1251
|
@ENCODING_CP1251@ Windows 1251
|
||||||
CP437 CP 437
|
CP437 CP 437
|
||||||
CP850 CP 850
|
CP850 CP 850
|
||||||
CP852 CP 852
|
CP852 CP 852
|
||||||
IBM866 CP 866
|
@ENCODING_CP866@ CP 866
|
||||||
KOI8-R KOI8-R
|
KOI8-R KOI8-R
|
||||||
KOI8-U KOI8-U
|
KOI8-U KOI8-U
|
||||||
UTF-8 UTF-8
|
UTF-8 UTF-8
|
||||||
|
@ -607,7 +607,7 @@ dview_get_utf (const char *str, int *ch, int *ch_length)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
char *next_ch;
|
const char *next_ch;
|
||||||
|
|
||||||
/* Calculate UTF-8 char length */
|
/* Calculate UTF-8 char length */
|
||||||
next_ch = g_utf8_next_char (str);
|
next_ch = g_utf8_next_char (str);
|
||||||
|
@ -573,6 +573,7 @@ edit_draw_this_line (WEdit *edit, off_t b, long row, long start_col, long end_co
|
|||||||
unsigned int c;
|
unsigned int c;
|
||||||
gboolean wide_width_char = FALSE;
|
gboolean wide_width_char = FALSE;
|
||||||
gboolean control_char = FALSE;
|
gboolean control_char = FALSE;
|
||||||
|
gboolean printable;
|
||||||
|
|
||||||
p->ch = 0;
|
p->ch = 0;
|
||||||
p->style = q == edit->buffer.curs1 ? MOD_CURSOR : 0;
|
p->style = q == edit->buffer.curs1 ? MOD_CURSOR : 0;
|
||||||
@ -759,34 +760,30 @@ edit_draw_this_line (WEdit *edit, off_t b, long row, long start_col, long end_co
|
|||||||
control_char = TRUE;
|
control_char = TRUE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
if (edit->utf8)
|
if (edit->utf8)
|
||||||
{
|
{
|
||||||
if (g_unichar_isprint (c))
|
if (mc_global.utf8_display)
|
||||||
p->ch = c;
|
/* c is gunichar */
|
||||||
|
printable = g_unichar_isprint (c);
|
||||||
else
|
else
|
||||||
{
|
/* c was gunichar; now c is 8-bit char converted from gunichar */
|
||||||
p->ch = '.';
|
printable = is_printable (c);
|
||||||
p->style = abn_style;
|
|
||||||
}
|
|
||||||
p++;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
{
|
/* c is 8-bit char */
|
||||||
if ((mc_global.utf8_display && g_unichar_isprint (c)) ||
|
printable = is_printable (c);
|
||||||
(!mc_global.utf8_display && is_printable (c)))
|
|
||||||
{
|
if (printable)
|
||||||
p->ch = c;
|
p->ch = c;
|
||||||
p++;
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
p->ch = '.';
|
p->ch = '.';
|
||||||
p->style = abn_style;
|
p->style = abn_style;
|
||||||
|
}
|
||||||
p++;
|
p++;
|
||||||
}
|
|
||||||
}
|
|
||||||
col++;
|
col++;
|
||||||
break;
|
break;
|
||||||
} /* case */
|
} /* case */
|
||||||
|
@ -80,17 +80,16 @@ awk_xorriso_unesc=$(cat <<'EOF'
|
|||||||
EOF
|
EOF
|
||||||
)
|
)
|
||||||
|
|
||||||
xorriso_list() {
|
xorriso_list() (
|
||||||
if test -z "$XORRISO"; then
|
if test -z "$XORRISO"; then
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
local temp_ls
|
|
||||||
temp_ls=$(mktemp "${MC_TMPDIR:-/tmp}"/mc-iso9660.XXXXXX) || return 1
|
temp_ls=$(mktemp "${MC_TMPDIR:-/tmp}"/mc-iso9660.XXXXXX) || return 1
|
||||||
|
|
||||||
# $XORRISO must be unquoted here to hook into the testing framework
|
# $XORRISO must be unquoted here to hook into the testing framework
|
||||||
$XORRISO -abort_on FATAL -dev stdio:"$1" -find / -exec lsdl 2>/dev/null >"$temp_ls"
|
$XORRISO -abort_on FATAL -dev stdio:"$1" -find / -exec lsdl 2>/dev/null >"$temp_ls"
|
||||||
local r=$?
|
r=$?
|
||||||
|
|
||||||
if [ "$r" != 0 ]; then
|
if [ "$r" != 0 ]; then
|
||||||
rm -f "$temp_ls"
|
rm -f "$temp_ls"
|
||||||
@ -105,7 +104,7 @@ xorriso_list() {
|
|||||||
@AWK@ "$awk_xorriso_unesc"
|
@AWK@ "$awk_xorriso_unesc"
|
||||||
|
|
||||||
rm -f "$temp_ls"
|
rm -f "$temp_ls"
|
||||||
}
|
)
|
||||||
|
|
||||||
xorriso_copyout() {
|
xorriso_copyout() {
|
||||||
if test -z "$XORRISO"; then
|
if test -z "$XORRISO"; then
|
||||||
@ -175,9 +174,7 @@ test_iso () {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
mcisofs_list () {
|
mcisofs_list () (
|
||||||
local lsl r
|
|
||||||
|
|
||||||
# left as a reminder to implement compressed image support =)
|
# left as a reminder to implement compressed image support =)
|
||||||
case "$1" in
|
case "$1" in
|
||||||
*.lz) MYCAT="lzip -dc";;
|
*.lz) MYCAT="lzip -dc";;
|
||||||
@ -227,7 +224,7 @@ BEGIN {
|
|||||||
if (name == "..") next;
|
if (name == "..") next;
|
||||||
printf "%s%s%s\n", attr, dir, name
|
printf "%s%s%s\n", attr, dir, name
|
||||||
}'
|
}'
|
||||||
}
|
)
|
||||||
|
|
||||||
mcisofs_copyout () {
|
mcisofs_copyout () {
|
||||||
if [ "x$SEMICOLON" = "xYES" ]; then
|
if [ "x$SEMICOLON" = "xYES" ]; then
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
PACKAGE_STRING = "/lib/vfs"
|
PACKAGE_STRING = "/lib/vfs"
|
||||||
|
|
||||||
AM_CPPFLAGS = \
|
AM_CPPFLAGS = \
|
||||||
-DTEST_SHARE_DIR=\"$(abs_srcdir)\" \
|
-DTEST_SHARE_DIR=\"$(abs_builddir)\" \
|
||||||
$(GLIB_CFLAGS) \
|
$(GLIB_CFLAGS) \
|
||||||
-I$(top_srcdir) \
|
-I$(top_srcdir) \
|
||||||
-I$(top_srcdir)/lib/vfs \
|
-I$(top_srcdir)/lib/vfs \
|
||||||
@ -9,7 +9,11 @@ AM_CPPFLAGS = \
|
|||||||
|
|
||||||
AM_LDFLAGS = @TESTS_LDFLAGS@
|
AM_LDFLAGS = @TESTS_LDFLAGS@
|
||||||
|
|
||||||
EXTRA_DIST = mc.charsets
|
EXTRA_DIST = mc.charsets.in
|
||||||
|
|
||||||
|
if CHARSET
|
||||||
|
CLEANFILES = mc.charsets
|
||||||
|
endif
|
||||||
|
|
||||||
LIBS = @CHECK_LIBS@ \
|
LIBS = @CHECK_LIBS@ \
|
||||||
$(top_builddir)/lib/libmc.la
|
$(top_builddir)/lib/libmc.la
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
ASCII 7-bit ASCII
|
ASCII 7-bit ASCII
|
||||||
IBM866 CP 866
|
@ENCODING_CP866@ CP 866
|
||||||
KOI8-R KOI8-R
|
KOI8-R KOI8-R
|
||||||
KOI8-U KOI8-U
|
KOI8-U KOI8-U
|
||||||
UTF-8 UTF-8
|
UTF-8 UTF-8
|
@ -42,14 +42,14 @@
|
|||||||
static void
|
static void
|
||||||
setup (void)
|
setup (void)
|
||||||
{
|
{
|
||||||
str_init_strings (NULL);
|
str_init_strings ("UTF-8");
|
||||||
|
|
||||||
vfs_init ();
|
vfs_init ();
|
||||||
vfs_init_localfs ();
|
vfs_init_localfs ();
|
||||||
vfs_setup_work_dir ();
|
vfs_setup_work_dir ();
|
||||||
|
|
||||||
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
|
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
||||||
load_codepages_list ();
|
load_codepages_list ();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -42,14 +42,14 @@
|
|||||||
static void
|
static void
|
||||||
setup (void)
|
setup (void)
|
||||||
{
|
{
|
||||||
str_init_strings (NULL);
|
str_init_strings ("UTF-8");
|
||||||
|
|
||||||
vfs_init ();
|
vfs_init ();
|
||||||
vfs_init_localfs ();
|
vfs_init_localfs ();
|
||||||
vfs_setup_work_dir ();
|
vfs_setup_work_dir ();
|
||||||
|
|
||||||
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
|
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
||||||
load_codepages_list ();
|
load_codepages_list ();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -74,25 +74,30 @@ teardown (void)
|
|||||||
static const struct test_path_length_ds
|
static const struct test_path_length_ds
|
||||||
{
|
{
|
||||||
const char *input_path;
|
const char *input_path;
|
||||||
const size_t expected_length;
|
const size_t expected_length_element_encoding;
|
||||||
|
const size_t expected_length_terminal_encoding;
|
||||||
} test_path_length_ds[] =
|
} test_path_length_ds[] =
|
||||||
{
|
{
|
||||||
{ /* 0. */
|
{ /* 0. */
|
||||||
NULL,
|
NULL,
|
||||||
|
0,
|
||||||
0
|
0
|
||||||
},
|
},
|
||||||
{ /* 1. */
|
{ /* 1. */
|
||||||
"/",
|
"/",
|
||||||
|
1,
|
||||||
1
|
1
|
||||||
},
|
},
|
||||||
{ /* 2. */
|
{ /* 2. */
|
||||||
"/тестовый/путь",
|
"/тестовый/путь",
|
||||||
|
26,
|
||||||
26
|
26
|
||||||
},
|
},
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
{ /* 3. */
|
{ /* 3. */
|
||||||
"/#enc:KOI8-R/тестовый/путь",
|
"/#enc:KOI8-R/тестовый/путь",
|
||||||
38
|
14,
|
||||||
|
38,
|
||||||
},
|
},
|
||||||
#endif /* HAVE_CHARSET */
|
#endif /* HAVE_CHARSET */
|
||||||
};
|
};
|
||||||
@ -105,15 +110,19 @@ START_PARAMETRIZED_TEST (test_path_length, test_path_length_ds)
|
|||||||
{
|
{
|
||||||
/* given */
|
/* given */
|
||||||
vfs_path_t *vpath;
|
vfs_path_t *vpath;
|
||||||
size_t actual_length;
|
char *path;
|
||||||
|
size_t actual_length_terminal_encoding, actual_length_element_encoding;
|
||||||
|
|
||||||
vpath = vfs_path_from_str (data->input_path);
|
vpath = vfs_path_from_str (data->input_path);
|
||||||
|
path = vpath != NULL ? vfs_path_get_by_index (vpath, 0)->path : NULL;
|
||||||
|
|
||||||
/* when */
|
/* when */
|
||||||
actual_length = vfs_path_len (vpath);
|
actual_length_terminal_encoding = vfs_path_len (vpath);
|
||||||
|
actual_length_element_encoding = path != NULL ? strlen (path) : 0;
|
||||||
|
|
||||||
/* then */
|
/* then */
|
||||||
ck_assert_int_eq (actual_length, data->expected_length);
|
ck_assert_int_eq (actual_length_terminal_encoding, data->expected_length_terminal_encoding);
|
||||||
|
ck_assert_int_eq (actual_length_element_encoding, data->expected_length_element_encoding);
|
||||||
|
|
||||||
vfs_path_free (vpath, TRUE);
|
vfs_path_free (vpath, TRUE);
|
||||||
}
|
}
|
||||||
|
@ -60,7 +60,7 @@ init_test_classes (void)
|
|||||||
static void
|
static void
|
||||||
setup (void)
|
setup (void)
|
||||||
{
|
{
|
||||||
str_init_strings (NULL);
|
str_init_strings ("UTF-8");
|
||||||
|
|
||||||
vfs_init ();
|
vfs_init ();
|
||||||
vfs_init_localfs ();
|
vfs_init_localfs ();
|
||||||
@ -68,8 +68,8 @@ setup (void)
|
|||||||
|
|
||||||
init_test_classes ();
|
init_test_classes ();
|
||||||
|
|
||||||
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
|
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
||||||
load_codepages_list ();
|
load_codepages_list ();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -71,8 +71,6 @@ test_init_vfs (const char *encoding)
|
|||||||
vfs_init_localfs ();
|
vfs_init_localfs ();
|
||||||
vfs_setup_work_dir ();
|
vfs_setup_work_dir ();
|
||||||
|
|
||||||
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
|
||||||
|
|
||||||
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
||||||
load_codepages_list ();
|
load_codepages_list ();
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ static struct vfs_class vfs_test_ops1, vfs_test_ops2, vfs_test_ops3;
|
|||||||
static void
|
static void
|
||||||
setup (void)
|
setup (void)
|
||||||
{
|
{
|
||||||
str_init_strings (NULL);
|
str_init_strings ("UTF-8");
|
||||||
|
|
||||||
vfs_init ();
|
vfs_init ();
|
||||||
vfs_init_localfs ();
|
vfs_init_localfs ();
|
||||||
@ -60,8 +60,8 @@ setup (void)
|
|||||||
vfs_init_class (&vfs_test_ops3, "testfs3", VFSF_UNKNOWN, "test3");
|
vfs_init_class (&vfs_test_ops3, "testfs3", VFSF_UNKNOWN, "test3");
|
||||||
vfs_register_class (&vfs_test_ops3);
|
vfs_register_class (&vfs_test_ops3);
|
||||||
|
|
||||||
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
|
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
||||||
load_codepages_list ();
|
load_codepages_list ();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -84,8 +84,6 @@ setup (void)
|
|||||||
vfs_test_ops1->chdir = test_chdir;
|
vfs_test_ops1->chdir = test_chdir;
|
||||||
vfs_register_class (vfs_test_ops1);
|
vfs_register_class (vfs_test_ops1);
|
||||||
|
|
||||||
mc_global.sysconfig_dir = (char *) TEST_SHARE_DIR;
|
|
||||||
|
|
||||||
vfs_local_ops->chdir = test_chdir;
|
vfs_local_ops->chdir = test_chdir;
|
||||||
|
|
||||||
test_chdir__init ();
|
test_chdir__init ();
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
|
|
||||||
#include "tests/mctest.h"
|
#include "tests/mctest.h"
|
||||||
|
|
||||||
#include "lib/vfs/path.c" /* for testing of static vfs_get_encoding() */
|
#include "lib/vfs/path.h"
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
@ -112,8 +112,8 @@ static const struct test_vfs_get_encoding_ds
|
|||||||
NULL
|
NULL
|
||||||
},
|
},
|
||||||
{ /* 14 */
|
{ /* 14 */
|
||||||
"/aaaa/#enc:UTF-8/bbbb/#enc:KOI8-R#enc:IBM866/cccc",
|
"/aaaa/#enc:UTF-8/bbbb/#enc:KOI8-R#enc:CP866/cccc",
|
||||||
"KOI8-R#enc:IBM866"
|
"KOI8-R#enc:CP866"
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
/* *INDENT-ON* */
|
/* *INDENT-ON* */
|
||||||
|
@ -48,7 +48,7 @@ static struct vfs_class vfs_test_ops1, vfs_test_ops2, vfs_test_ops3;
|
|||||||
static void
|
static void
|
||||||
setup (void)
|
setup (void)
|
||||||
{
|
{
|
||||||
str_init_strings (NULL);
|
str_init_strings ("UTF-8");
|
||||||
|
|
||||||
vfs_init ();
|
vfs_init ();
|
||||||
vfs_init_localfs ();
|
vfs_init_localfs ();
|
||||||
@ -125,36 +125,36 @@ static const struct test_from_to_string_ds
|
|||||||
&vfs_test_ops3
|
&vfs_test_ops3
|
||||||
},
|
},
|
||||||
{ /* 4. */
|
{ /* 4. */
|
||||||
"/#test1/bla-bla1/#enc:IBM866/some/path/#test2/bla-bla2/#enc:KOI8-R/some/path#test3/111/22/33",
|
"/#test1/bla-bla1/#enc:CP866/some/path/#test2/bla-bla2/#enc:KOI8-R/some/path#test3/111/22/33",
|
||||||
"/test1://#enc:IBM866/bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
"/test1://#enc:CP866/bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
||||||
"111/22/33",
|
"111/22/33",
|
||||||
4,
|
4,
|
||||||
&vfs_test_ops3
|
&vfs_test_ops3
|
||||||
},
|
},
|
||||||
{ /* 5. */
|
{ /* 5. */
|
||||||
"/#test1/bla-bla1/some/path/#test2/bla-bla2/#enc:IBM866/#enc:KOI8-R/some/path#test3/111/22/33",
|
"/#test1/bla-bla1/some/path/#test2/bla-bla2/#enc:CP866/#enc:KOI8-R/some/path#test3/111/22/33",
|
||||||
"/test1://bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
"/test1://bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
||||||
"111/22/33",
|
"111/22/33",
|
||||||
4,
|
4,
|
||||||
&vfs_test_ops3
|
&vfs_test_ops3
|
||||||
},
|
},
|
||||||
{ /* 6. */
|
{ /* 6. */
|
||||||
"/#test1/bla-bla1/some/path/#test2/bla-bla2/#enc:IBM866/some/#enc:KOI8-R/path#test3/111/22/33",
|
"/#test1/bla-bla1/some/path/#test2/bla-bla2/#enc:CP866/some/#enc:KOI8-R/path#test3/111/22/33",
|
||||||
"/test1://bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
"/test1://bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
||||||
"111/22/33",
|
"111/22/33",
|
||||||
4,
|
4,
|
||||||
&vfs_test_ops3
|
&vfs_test_ops3
|
||||||
},
|
},
|
||||||
{ /* 7. */
|
{ /* 7. */
|
||||||
"/#test1/bla-bla1/some/path/#test2/#enc:IBM866/bla-bla2/#enc:KOI8-R/some/path#test3/111/22/33",
|
"/#test1/bla-bla1/some/path/#test2/#enc:CP866/bla-bla2/#enc:KOI8-R/some/path#test3/111/22/33",
|
||||||
"/test1://bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
"/test1://bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
||||||
"111/22/33",
|
"111/22/33",
|
||||||
4,
|
4,
|
||||||
&vfs_test_ops3
|
&vfs_test_ops3
|
||||||
},
|
},
|
||||||
{ /* 8. */
|
{ /* 8. */
|
||||||
"/#test1/bla-bla1/some/path/#enc:IBM866/#test2/bla-bla2/#enc:KOI8-R/some/path#test3/111/22/33",
|
"/#test1/bla-bla1/some/path/#enc:CP866/#test2/bla-bla2/#enc:KOI8-R/some/path#test3/111/22/33",
|
||||||
"/test1://#enc:IBM866/bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
"/test1://#enc:CP866/bla-bla1/some/path/test2://#enc:KOI8-R/bla-bla2/some/path/test3://111/22/33",
|
||||||
"111/22/33",
|
"111/22/33",
|
||||||
4,
|
4,
|
||||||
&vfs_test_ops3
|
&vfs_test_ops3
|
||||||
|
@ -241,12 +241,12 @@ static const struct test_autocomplete_ds
|
|||||||
1,
|
1,
|
||||||
"KOI8-R",
|
"KOI8-R",
|
||||||
0,
|
0,
|
||||||
"ワ゚ハテユヒナホ",
|
"\xDC\xDF\xCA\xC3\xD5\xCB\xC5\xCE", // эъйцукен
|
||||||
|
|
||||||
8,
|
8,
|
||||||
2,
|
2,
|
||||||
136,
|
136,
|
||||||
"ワ゚ハテユヒナホ"
|
"\xDC\xDF\xCA\xC3\xD5\xCB\xC5\xCE" // эъйцукен
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
/* *INDENT-ON* */
|
/* *INDENT-ON* */
|
||||||
@ -328,7 +328,7 @@ static const struct test_autocomplete_single_ds
|
|||||||
0,
|
0,
|
||||||
|
|
||||||
145,
|
145,
|
||||||
"ニルラチ"
|
"\xC6\xD9\xD7\xC1" // фыва
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
/* *INDENT-ON* */
|
/* *INDENT-ON* */
|
||||||
|
@ -19,6 +19,9 @@
|
|||||||
#
|
#
|
||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
# Suppress warnings about `local`
|
||||||
|
# shellcheck disable=SC3043
|
||||||
|
|
||||||
help() {
|
help() {
|
||||||
cat << EOS
|
cat << EOS
|
||||||
@ -94,6 +97,11 @@ opt_run_mcdiff_on_error=no # "yes" if '--mcdiff' provided.
|
|||||||
|
|
||||||
############################ Utility functions #############################
|
############################ Utility functions #############################
|
||||||
|
|
||||||
|
# Support shells missing local, but having typeset like ksh93+ on Solaris
|
||||||
|
if type typeset > /dev/null 2>&1; then
|
||||||
|
alias local="typeset"
|
||||||
|
fi
|
||||||
|
|
||||||
#
|
#
|
||||||
# Does $1 contain $2?
|
# Does $1 contain $2?
|
||||||
#
|
#
|
||||||
@ -109,7 +117,8 @@ has_string() {
|
|||||||
# Given "/path/to/basename.and.some.ext", returns "basename"
|
# Given "/path/to/basename.and.some.ext", returns "basename"
|
||||||
#
|
#
|
||||||
basename_sans_extensions() {
|
basename_sans_extensions() {
|
||||||
local base="$(basename "$1")"
|
local base
|
||||||
|
base="$(basename "$1")"
|
||||||
echo "${base%%.*}"
|
echo "${base%%.*}"
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -137,25 +146,26 @@ has_colors() {
|
|||||||
|
|
||||||
init_colors() {
|
init_colors() {
|
||||||
if has_colors; then
|
if has_colors; then
|
||||||
local esc="$(printf '\033')" # for portability
|
local esc
|
||||||
C_bold="$esc[1m"
|
esc="$(printf '\033')" # for portability
|
||||||
C_green="$esc[1;32m"
|
C_bold="${esc}[1m"
|
||||||
C_red="$esc[1;31m"
|
C_green="${esc}[1;32m"
|
||||||
C_magenta="$esc[1;35m"
|
C_red="${esc}[1;31m"
|
||||||
C_norm="$esc[0m"
|
C_magenta="${esc}[1;35m"
|
||||||
|
C_norm="${esc}[0m"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
# A few colorful alternatives to 'echo'.
|
# A few colorful alternatives to 'echo'.
|
||||||
#
|
#
|
||||||
header() { echo $C_bold"$@"$C_norm; }
|
header() { echo "$C_bold$*$C_norm"; }
|
||||||
err() { echo $C_red"$@"$C_norm; }
|
err() { echo "$C_red$*$C_norm"; }
|
||||||
notice() { echo $C_magenta"$@"$C_norm; }
|
notice() { echo "$C_magenta$*$C_norm"; }
|
||||||
success() { echo $C_green"$@"$C_norm; }
|
success() { echo "$C_green$*$C_norm"; }
|
||||||
|
|
||||||
die() {
|
die() {
|
||||||
err "Error: $@"
|
err "Error: $*"
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -251,7 +261,9 @@ run() {
|
|||||||
# Set up variables:
|
# Set up variables:
|
||||||
#
|
#
|
||||||
|
|
||||||
local helper_name="$(basename_sans_extensions "$input")"
|
local helper_name
|
||||||
|
helper_name="$(basename_sans_extensions "$input")"
|
||||||
|
|
||||||
local expected_parsed_output="${input%.input}.output"
|
local expected_parsed_output="${input%.input}.output"
|
||||||
local env_vars_file="${input%.input}.env_vars"
|
local env_vars_file="${input%.input}.env_vars"
|
||||||
local args_file="${input%.input}.args"
|
local args_file="${input%.input}.args"
|
||||||
@ -281,8 +293,10 @@ run() {
|
|||||||
local extra_parser_args=""
|
local extra_parser_args=""
|
||||||
[ -f "$args_file" ] && extra_parser_args="$(cat "$args_file")"
|
[ -f "$args_file" ] && extra_parser_args="$(cat "$args_file")"
|
||||||
|
|
||||||
local actual_output="$(temp_file $helper_name.actual-output.XXXXXXXX)"
|
local actual_output
|
||||||
local actual_parsed_output="$(temp_file $helper_name.actual-parsed-output.XXXXXXXX)"
|
local actual_parsed_output
|
||||||
|
actual_output="$(temp_file $helper_name.actual-output.XXXXXXXX)"
|
||||||
|
actual_parsed_output="$(temp_file $helper_name.actual-parsed-output.XXXXXXXX)"
|
||||||
|
|
||||||
#
|
#
|
||||||
# Variables are all set. Now do the actual stuff:
|
# Variables are all set. Now do the actual stuff:
|
||||||
@ -350,7 +364,7 @@ run() {
|
|||||||
if is_interactive; then
|
if is_interactive; then
|
||||||
if [ $opt_run_mcdiff_on_error = "yes" ]; then
|
if [ $opt_run_mcdiff_on_error = "yes" ]; then
|
||||||
notice "Hit ENTER to launch mcdiff ..."
|
notice "Hit ENTER to launch mcdiff ..."
|
||||||
read dummy_var # dash needs this.
|
read -r _dummy_argument # dash needs an argument
|
||||||
${MCDIFF:-mcdiff} "$expected_parsed_output" "$actual_parsed_output"
|
${MCDIFF:-mcdiff} "$expected_parsed_output" "$actual_parsed_output"
|
||||||
else
|
else
|
||||||
notice "Tip: invoke this program with '--mcdiff' to automatically launch"
|
notice "Tip: invoke this program with '--mcdiff' to automatically launch"
|
||||||
@ -377,7 +391,7 @@ run() {
|
|||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
[ $pass_count = "0" -a $error_count = "0" ] && notice "Note: The data directory contains no *.input files."
|
[ $pass_count = "0" ] && [ $error_count = "0" ] && notice "Note: The data directory contains no *.input files."
|
||||||
|
|
||||||
[ $error_count = "0" ] # exit status of function.
|
[ $error_count = "0" ] # exit status of function.
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user