Merge branch '3972_fix_illumos'

Signed-off-by: Yury V. Zaytsev <yury@shurup.com>
This commit is contained in:
Yury V. Zaytsev 2024-10-05 11:49:38 +02:00
commit a24d45ffab
24 changed files with 206 additions and 154 deletions

View File

@ -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

View File

@ -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

View File

@ -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);

View File

@ -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);
} }

View File

@ -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';

View File

@ -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
* *

View File

@ -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

View File

@ -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
]) ])

View File

@ -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

View File

@ -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);

View File

@ -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 */

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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
} }

View File

@ -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);
} }

View File

@ -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
} }

View File

@ -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 ();
} }

View File

@ -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
} }

View File

@ -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 ();

View File

@ -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* */

View File

@ -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

View File

@ -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* */

View File

@ -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.
} }