patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
/* common strings utilities
|
|
|
|
Copyright (C) 2007 Free Software Foundation, Inc.
|
2009-04-09 14:29:00 +04:00
|
|
|
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
Written 2007 by:
|
2009-04-09 14:29:00 +04:00
|
|
|
Rostislav Benes
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
|
|
|
|
The file_date routine is mostly from GNU's fileutils package,
|
|
|
|
written by Richard Stallman and David MacKenzie.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
2009-04-09 14:29:00 +04:00
|
|
|
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <iconv.h>
|
|
|
|
#include <glib.h>
|
|
|
|
#include <langinfo.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
|
|
|
#include "global.h"
|
|
|
|
#include "strutil.h"
|
|
|
|
|
|
|
|
//names, that are used for utf-8
|
|
|
|
static const char *str_utf8_encodings[] = {
|
|
|
|
"utf-8",
|
|
|
|
"utf8",
|
2009-04-14 14:29:01 +04:00
|
|
|
NULL
|
2009-04-14 14:29:01 +04:00
|
|
|
};
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
|
|
|
|
// standard 8bit encodings, no wide or multibytes characters
|
|
|
|
static const char *str_8bit_encodings[] = {
|
2009-04-14 14:29:01 +04:00
|
|
|
"cp-1251",
|
|
|
|
"cp1251",
|
|
|
|
"cp-1250",
|
|
|
|
"cp1250",
|
|
|
|
"cp-866",
|
|
|
|
"cp866",
|
|
|
|
"cp-850",
|
|
|
|
"cp850",
|
|
|
|
"cp-852",
|
|
|
|
"cp852",
|
|
|
|
"iso-8859",
|
|
|
|
"iso8859",
|
|
|
|
"koi8",
|
|
|
|
NULL
|
2009-04-09 14:29:00 +04:00
|
|
|
};
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
|
|
|
|
// terminal encoding
|
|
|
|
static char *codeset;
|
|
|
|
// function for encoding specific operations
|
|
|
|
static struct str_class used_class;
|
|
|
|
|
2009-04-15 13:22:34 +04:00
|
|
|
GIConv str_cnv_to_term;
|
|
|
|
GIConv str_cnv_from_term;
|
|
|
|
GIConv str_cnv_not_convert;
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
|
|
|
|
// if enc is same encoding like on terminal
|
2009-04-14 14:29:01 +04:00
|
|
|
static int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_test_not_convert (const char *enc)
|
|
|
|
{
|
|
|
|
return g_ascii_strcasecmp (enc, codeset) == 0;
|
2009-04-09 14:29:00 +04:00
|
|
|
}
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
GIConv
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_crt_conv_to (const char *to_enc)
|
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
return (!str_test_not_convert (to_enc))
|
|
|
|
? g_iconv_open (to_enc, codeset) : str_cnv_not_convert;
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
GIConv
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_crt_conv_from (const char *from_enc)
|
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
return (!str_test_not_convert (from_enc))
|
|
|
|
? g_iconv_open (codeset, from_enc) : str_cnv_not_convert;
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-04-14 14:29:01 +04:00
|
|
|
str_close_conv (GIConv conv)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
if (conv != str_cnv_not_convert)
|
2009-04-14 14:29:01 +04:00
|
|
|
g_iconv_close (conv);
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
2009-04-14 14:29:01 +04:00
|
|
|
_str_convert (GIConv coder, char *string, int size, GString * buffer)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
2009-04-09 14:29:00 +04:00
|
|
|
int state;
|
2009-04-20 14:09:59 +04:00
|
|
|
gchar *tmp_buff = NULL;
|
2009-04-14 14:29:01 +04:00
|
|
|
gssize left;
|
|
|
|
gsize bytes_read, bytes_written;
|
|
|
|
GError *error = NULL;
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
errno = 0;
|
2009-04-20 15:09:32 +04:00
|
|
|
|
2009-04-20 14:09:59 +04:00
|
|
|
if (string == NULL || buffer == NULL)
|
|
|
|
return ESTR_FAILURE;
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-20 15:09:32 +04:00
|
|
|
/*
|
2009-04-20 14:09:59 +04:00
|
|
|
if (! used_class.is_valid_string (string))
|
2009-04-14 14:29:01 +04:00
|
|
|
{
|
2009-04-20 15:09:32 +04:00
|
|
|
return ESTR_FAILURE;
|
2009-04-20 14:09:59 +04:00
|
|
|
}
|
2009-04-20 15:09:32 +04:00
|
|
|
*/
|
2009-04-20 14:09:59 +04:00
|
|
|
state = 0;
|
|
|
|
if (size < 0)
|
|
|
|
{
|
|
|
|
size = strlen (string);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
left = strlen (string);
|
|
|
|
if (left < size)
|
|
|
|
size = left;
|
|
|
|
}
|
2009-04-14 14:29:01 +04:00
|
|
|
|
2009-04-20 14:09:59 +04:00
|
|
|
left = size;
|
2009-04-14 14:29:01 +04:00
|
|
|
|
2009-04-20 14:09:59 +04:00
|
|
|
if (coder == (GIConv) (-1))
|
|
|
|
return ESTR_FAILURE;
|
2009-04-14 14:29:01 +04:00
|
|
|
|
2009-04-20 14:09:59 +04:00
|
|
|
g_iconv (coder, NULL, NULL, NULL, NULL);
|
2009-04-14 14:29:01 +04:00
|
|
|
|
2009-04-20 14:09:59 +04:00
|
|
|
while (left)
|
|
|
|
{
|
|
|
|
tmp_buff = g_convert_with_iconv ((const gchar *) string,
|
|
|
|
left,
|
|
|
|
coder,
|
|
|
|
&bytes_read,
|
|
|
|
&bytes_written, &error);
|
|
|
|
if (error)
|
|
|
|
{
|
|
|
|
switch (error->code)
|
2009-04-14 14:29:01 +04:00
|
|
|
{
|
2009-04-20 14:09:59 +04:00
|
|
|
case G_CONVERT_ERROR_NO_CONVERSION:
|
|
|
|
/* Conversion between the requested character sets is not supported. */
|
|
|
|
tmp_buff = g_strnfill (strlen (string), '?');
|
|
|
|
g_string_append (buffer, tmp_buff);
|
|
|
|
g_free (tmp_buff);
|
|
|
|
g_error_free (error);
|
|
|
|
error = NULL;
|
|
|
|
return ESTR_FAILURE;
|
|
|
|
break;
|
|
|
|
case G_CONVERT_ERROR_ILLEGAL_SEQUENCE:
|
|
|
|
/* Invalid byte sequence in conversion input. */
|
|
|
|
if (tmp_buff){
|
2009-04-14 14:29:01 +04:00
|
|
|
g_string_append (buffer, tmp_buff);
|
|
|
|
g_free (tmp_buff);
|
2009-04-20 14:09:59 +04:00
|
|
|
}
|
|
|
|
if (bytes_read < left)
|
|
|
|
{
|
|
|
|
string += bytes_read + 1;
|
|
|
|
size -= (bytes_read + 1);
|
|
|
|
left -= (bytes_read + 1);
|
|
|
|
g_string_append_c (buffer, *(string-1));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
g_error_free (error);
|
2009-04-20 14:09:59 +04:00
|
|
|
error = NULL;
|
2009-04-14 14:29:01 +04:00
|
|
|
return ESTR_PROBLEM;
|
2009-04-20 14:09:59 +04:00
|
|
|
}
|
|
|
|
state = ESTR_PROBLEM;
|
|
|
|
break;
|
|
|
|
case G_CONVERT_ERROR_PARTIAL_INPUT:
|
|
|
|
/* Partial character sequence at end of input. */
|
|
|
|
g_error_free (error);
|
|
|
|
error = NULL;
|
|
|
|
g_string_append (buffer, tmp_buff);
|
|
|
|
g_free (tmp_buff);
|
|
|
|
if (bytes_read < left)
|
|
|
|
{
|
|
|
|
left = left - bytes_read;
|
|
|
|
tmp_buff = g_strnfill (left, '?');
|
2009-04-14 14:29:01 +04:00
|
|
|
g_string_append (buffer, tmp_buff);
|
|
|
|
g_free (tmp_buff);
|
2009-04-20 14:09:59 +04:00
|
|
|
}
|
|
|
|
return ESTR_PROBLEM;
|
|
|
|
break;
|
|
|
|
case G_CONVERT_ERROR_BAD_URI: /* Don't know how handle this error :( */
|
|
|
|
case G_CONVERT_ERROR_NOT_ABSOLUTE_PATH: /* Don't know how handle this error :( */
|
|
|
|
case G_CONVERT_ERROR_FAILED: /* Conversion failed for some reason. */
|
|
|
|
default:
|
|
|
|
g_error_free (error);
|
|
|
|
error = NULL;
|
|
|
|
if (tmp_buff){
|
|
|
|
g_free (tmp_buff);
|
|
|
|
tmp_buff = NULL;
|
|
|
|
}
|
|
|
|
return ESTR_FAILURE;
|
|
|
|
}
|
|
|
|
g_error_free (error);
|
|
|
|
error = NULL;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (tmp_buff != NULL)
|
|
|
|
{
|
2009-04-20 15:09:32 +04:00
|
|
|
if (*tmp_buff)
|
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
g_string_append (buffer, tmp_buff);
|
|
|
|
g_free (tmp_buff);
|
2009-04-20 14:09:59 +04:00
|
|
|
string += bytes_read;
|
|
|
|
left -= bytes_read;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
g_free (tmp_buff);
|
|
|
|
g_string_append (buffer, string);
|
|
|
|
return state;
|
2009-04-14 14:29:01 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2009-04-20 14:09:59 +04:00
|
|
|
g_string_append (buffer, string);
|
|
|
|
return ESTR_PROBLEM;
|
2009-04-14 14:29:01 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-04-20 14:09:59 +04:00
|
|
|
return state;
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_convert (GIConv coder, char *string, GString * buffer)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
int result;
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
result = _str_convert (coder, string, -1, buffer);
|
2009-04-09 14:29:00 +04:00
|
|
|
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
int
|
|
|
|
str_nconvert (GIConv coder, char *string, int size, GString * buffer)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
int result;
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
result = _str_convert (coder, string, size, buffer);
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
return result;
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_vfs_convert_from (GIConv coder, char *string, GString * buffer)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
int result;
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
if (coder == str_cnv_not_convert)
|
|
|
|
{
|
2009-04-20 14:09:59 +04:00
|
|
|
g_string_append (buffer, (string)?string:"");
|
2009-04-14 14:29:01 +04:00
|
|
|
result = 0;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
result = _str_convert (coder, string, -1, buffer);
|
2009-04-09 14:29:00 +04:00
|
|
|
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
return result;
|
|
|
|
}
|
2009-04-09 14:29:00 +04:00
|
|
|
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_vfs_convert_to (GIConv coder, const char *string, int size,
|
|
|
|
GString * buffer)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.vfs_convert_to (coder, string, size, buffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-04-14 14:29:01 +04:00
|
|
|
str_printf (GString * buffer, const char *format, ...)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
va_start (ap, format);
|
2009-04-18 12:50:32 +04:00
|
|
|
#if GLIB_CHECK_VERSION (2, 14, 0)
|
|
|
|
g_string_append_vprintf (buffer, format, ap);
|
|
|
|
#else
|
|
|
|
{
|
|
|
|
gchar *tmp;
|
|
|
|
tmp = g_strdup_vprintf (format, ap);
|
|
|
|
g_string_append (buffer, tmp);
|
|
|
|
g_free(tmp);
|
|
|
|
}
|
|
|
|
#endif
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
va_end (ap);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-04-14 14:29:01 +04:00
|
|
|
str_insert_replace_char (GString * buffer)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
used_class.insert_replace_char (buffer);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
2009-04-20 11:30:32 +04:00
|
|
|
str_translate_char (GIConv conv, const char *keys, size_t ch_size,
|
2009-04-14 14:29:01 +04:00
|
|
|
char *output, size_t out_size)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
size_t left;
|
|
|
|
size_t cnv;
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-15 13:22:34 +04:00
|
|
|
g_iconv (conv, NULL, NULL, NULL, NULL);
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
left = (ch_size == (size_t) (-1)) ? strlen (keys) : ch_size;
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-20 12:10:06 +04:00
|
|
|
cnv = g_iconv (conv, (gchar **) &keys, &left, &output, &out_size);
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
if (cnv == (size_t)(-1)) {
|
|
|
|
if (errno == EINVAL) return ESTR_PROBLEM; else return ESTR_FAILURE;
|
|
|
|
} else {
|
|
|
|
output[0] = '\0';
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static const char *
|
|
|
|
str_detect_termencoding ()
|
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
return (nl_langinfo (CODESET));
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
str_test_encoding_class (const char *encoding, const char **table)
|
|
|
|
{
|
|
|
|
int t;
|
|
|
|
int result = 0;
|
2009-04-17 01:28:02 +04:00
|
|
|
if ( encoding == NULL )
|
|
|
|
return result;
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
for (t = 0; table[t] != NULL; t++)
|
|
|
|
{
|
|
|
|
result += (g_ascii_strncasecmp (encoding, table[t],
|
|
|
|
strlen (table[t])) == 0);
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
str_choose_str_functions ()
|
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
if (str_test_encoding_class (codeset, str_utf8_encodings))
|
|
|
|
{
|
|
|
|
used_class = str_utf8_init ();
|
|
|
|
}
|
|
|
|
else if (str_test_encoding_class (codeset, str_8bit_encodings))
|
|
|
|
{
|
|
|
|
used_class = str_8bit_init ();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
used_class = str_ascii_init ();
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
2009-04-09 14:29:00 +04:00
|
|
|
}
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
|
2009-04-09 18:23:08 +04:00
|
|
|
int
|
2009-04-17 01:28:02 +04:00
|
|
|
str_isutf8 (const char *codeset_name)
|
2009-04-09 18:23:08 +04:00
|
|
|
{
|
|
|
|
int result = 0;
|
2009-04-14 14:29:01 +04:00
|
|
|
if (str_test_encoding_class (codeset_name, str_utf8_encodings))
|
|
|
|
{
|
|
|
|
result = 1;
|
2009-04-09 18:23:08 +04:00
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
void
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_init_strings (const char *termenc)
|
|
|
|
{
|
|
|
|
codeset = g_strdup ((termenc != NULL)
|
|
|
|
? termenc
|
|
|
|
: str_detect_termencoding ());
|
|
|
|
|
2009-04-15 13:22:34 +04:00
|
|
|
str_cnv_not_convert = g_iconv_open (codeset, codeset);
|
2009-04-14 14:29:01 +04:00
|
|
|
if (str_cnv_not_convert == INVALID_CONV)
|
|
|
|
{
|
|
|
|
if (termenc != NULL)
|
|
|
|
{
|
|
|
|
g_free (codeset);
|
|
|
|
codeset = g_strdup (str_detect_termencoding ());
|
2009-04-15 13:22:34 +04:00
|
|
|
str_cnv_not_convert = g_iconv_open (codeset, codeset);
|
2009-04-14 14:29:01 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
if (str_cnv_not_convert == INVALID_CONV)
|
|
|
|
{
|
|
|
|
g_free (codeset);
|
|
|
|
codeset = g_strdup ("ascii");
|
2009-04-15 13:22:34 +04:00
|
|
|
str_cnv_not_convert = g_iconv_open (codeset, codeset);
|
2009-04-14 14:29:01 +04:00
|
|
|
}
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
2009-04-09 14:29:00 +04:00
|
|
|
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_cnv_to_term = str_cnv_not_convert;
|
|
|
|
str_cnv_from_term = str_cnv_not_convert;
|
2009-04-09 14:29:00 +04:00
|
|
|
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_choose_str_functions ();
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
void
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_uninit_strings ()
|
|
|
|
{
|
2009-04-15 13:22:34 +04:00
|
|
|
g_iconv_close (str_cnv_not_convert);
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
}
|
2009-04-09 14:29:00 +04:00
|
|
|
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
const char *
|
|
|
|
str_term_form (const char *text)
|
|
|
|
{
|
|
|
|
return used_class.term_form (text);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_fit_to_term (const char *text, int width, int just_mode)
|
|
|
|
{
|
|
|
|
return used_class.fit_to_term (text, width, just_mode);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_term_trim (const char *text, int width)
|
|
|
|
{
|
|
|
|
return used_class.term_trim (text, width);
|
|
|
|
}
|
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
void
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_msg_term_size (const char *text, int *lines, int *columns)
|
|
|
|
{
|
|
|
|
return used_class.msg_term_size (text, lines, columns);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_term_substring (const char *text, int start, int width)
|
|
|
|
{
|
|
|
|
return used_class.term_substring (text, start, width);
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
|
|
|
str_get_next_char (char *text)
|
|
|
|
{
|
2009-04-09 14:29:00 +04:00
|
|
|
|
2009-04-14 14:29:01 +04:00
|
|
|
used_class.cnext_char ((const char **) &text);
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_cget_next_char (const char *text)
|
|
|
|
{
|
2009-04-14 14:29:01 +04:00
|
|
|
used_class.cnext_char(&text);
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_next_char (char **text)
|
|
|
|
{
|
|
|
|
used_class.cnext_char ((const char **) text);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_cnext_char (const char **text)
|
|
|
|
{
|
|
|
|
used_class.cnext_char (text);
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
|
|
|
str_get_prev_char (char *text)
|
|
|
|
{
|
|
|
|
used_class.cprev_char ((const char **) &text);
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_cget_prev_char (const char *text)
|
|
|
|
{
|
|
|
|
used_class.cprev_char (&text);
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_prev_char (char **text)
|
|
|
|
{
|
|
|
|
used_class.cprev_char ((const char **) text);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_cprev_char (const char **text)
|
|
|
|
{
|
|
|
|
used_class.cprev_char (text);
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
|
|
|
str_get_next_char_safe (char *text)
|
|
|
|
{
|
|
|
|
used_class.cnext_char_safe ((const char **) &text);
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_cget_next_char_safe (const char *text)
|
|
|
|
{
|
|
|
|
used_class.cnext_char_safe (&text);
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_next_char_safe (char **text)
|
|
|
|
{
|
|
|
|
used_class.cnext_char_safe ((const char **) text);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_cnext_char_safe (const char **text)
|
|
|
|
{
|
|
|
|
used_class.cnext_char_safe (text);
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
|
|
|
str_get_prev_char_safe (char *text)
|
|
|
|
{
|
|
|
|
used_class.cprev_char_safe ((const char **) &text);
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_cget_prev_char_safe (const char *text)
|
|
|
|
{
|
|
|
|
used_class.cprev_char_safe (&text);
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_prev_char_safe (char **text)
|
|
|
|
{
|
|
|
|
used_class.cprev_char_safe ((const char **) text);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_cprev_char_safe (const char **text)
|
|
|
|
{
|
|
|
|
used_class.cprev_char_safe (text);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_next_noncomb_char (char **text)
|
|
|
|
{
|
|
|
|
return used_class.cnext_noncomb_char ((const char **) text);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_cnext_noncomb_char (const char **text)
|
|
|
|
{
|
|
|
|
return used_class.cnext_noncomb_char (text);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_prev_noncomb_char (char **text, const char *begin)
|
|
|
|
{
|
|
|
|
return used_class.cprev_noncomb_char ((const char **) text, begin);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_cprev_noncomb_char (const char **text, const char *begin)
|
|
|
|
{
|
|
|
|
return used_class.cprev_noncomb_char (text, begin);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_is_valid_char (const char *ch, size_t size)
|
|
|
|
{
|
|
|
|
return used_class.is_valid_char (ch, size);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_term_width1 (const char *text)
|
|
|
|
{
|
|
|
|
return used_class.term_width1 (text);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_term_width2 (const char *text, size_t length)
|
|
|
|
{
|
|
|
|
return used_class.term_width2 (text, length);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_term_char_width (const char *text)
|
|
|
|
{
|
|
|
|
return used_class.term_char_width (text);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_offset_to_pos (const char *text, size_t length)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.offset_to_pos (text, length);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_length (const char *text)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.length (text);
|
|
|
|
}
|
|
|
|
|
2009-04-17 12:46:06 +04:00
|
|
|
int
|
|
|
|
str_length_char (const char *text)
|
|
|
|
{
|
|
|
|
return str_cget_next_char_safe (text)-text;
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_length2 (const char *text, int size)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.length2 (text, size);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_length_noncomb (const char *text)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.length_noncomb (text);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_column_to_pos (const char *text, size_t pos)
|
|
|
|
{
|
|
|
|
return used_class.column_to_pos (text, pos);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_isspace (const char *ch)
|
|
|
|
{
|
|
|
|
return used_class.isspace (ch);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_ispunct (const char *ch)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.ispunct (ch);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_isalnum (const char *ch)
|
|
|
|
{
|
|
|
|
return used_class.isalnum (ch);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_isdigit (const char *ch)
|
|
|
|
{
|
|
|
|
return used_class.isdigit (ch);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_toupper (const char *ch, char **out, size_t * remain)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.toupper (ch, out, remain);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2009-04-14 14:29:01 +04:00
|
|
|
str_tolower (const char *ch, char **out, size_t * remain)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.tolower (ch, out, remain);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_isprint (const char *ch)
|
|
|
|
{
|
|
|
|
return used_class.isprint (ch);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_iscombiningmark (const char *ch)
|
|
|
|
{
|
|
|
|
return used_class.iscombiningmark (ch);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_trunc (const char *text, int width)
|
|
|
|
{
|
|
|
|
return used_class.trunc (text, width);
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
|
|
|
str_create_search_needle (const char *needle, int case_sen)
|
|
|
|
{
|
|
|
|
return used_class.create_search_needle (needle, case_sen);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
str_release_search_needle (char *needle, int case_sen)
|
|
|
|
{
|
|
|
|
used_class.release_search_needle (needle, case_sen);
|
2009-04-09 14:29:00 +04:00
|
|
|
}
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
|
|
|
|
const char *
|
|
|
|
str_search_first (const char *text, const char *search, int case_sen)
|
|
|
|
{
|
|
|
|
return used_class.search_first (text, search, case_sen);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *
|
|
|
|
str_search_last (const char *text, const char *search, int case_sen)
|
|
|
|
{
|
|
|
|
return used_class.search_last (text, search, case_sen);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_is_valid_string (const char *text)
|
|
|
|
{
|
|
|
|
return used_class.is_valid_string (text);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
str_compare (const char *t1, const char *t2)
|
|
|
|
{
|
|
|
|
return used_class.compare (t1, t2);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
str_ncompare (const char *t1, const char *t2)
|
|
|
|
{
|
|
|
|
return used_class.ncompare (t1, t2);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
str_casecmp (const char *t1, const char *t2)
|
|
|
|
{
|
|
|
|
return used_class.casecmp (t1, t2);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
str_ncasecmp (const char *t1, const char *t2)
|
|
|
|
{
|
|
|
|
return used_class.ncasecmp (t1, t2);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
str_prefix (const char *text, const char *prefix)
|
|
|
|
{
|
|
|
|
return used_class.prefix (text, prefix);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
str_caseprefix (const char *text, const char *prefix)
|
|
|
|
{
|
|
|
|
return used_class.caseprefix (text, prefix);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
str_fix_string (char *text)
|
|
|
|
{
|
|
|
|
used_class.fix_string (text);
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
2009-04-14 14:29:01 +04:00
|
|
|
str_create_key (const char *text, int case_sen)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.create_key (text, case_sen);
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
2009-04-14 14:29:01 +04:00
|
|
|
str_create_key_for_filename (const char *text, int case_sen)
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
{
|
|
|
|
return used_class.create_key_for_filename (text, case_sen);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
int
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_key_collate (const char *t1, const char *t2, int case_sen)
|
|
|
|
{
|
|
|
|
return used_class.key_collate (t1, t2, case_sen);
|
|
|
|
}
|
|
|
|
|
2009-04-09 14:29:00 +04:00
|
|
|
void
|
patches by Rostislav Beneš: mc-01-api
add functions for working with strings
some functions are implemented directlu in strutil.c, others have ascii, 8bit
or utf-8 variant. (8bit means singlebyte encodings, where all characters have
width one). Mc autodetects terminal encoding at start and chooses right
variant. If does not know terminal encoding, chooses ascii variant.
contains functions:
1. for translation strings and growing strings
2. for working with characters (next char, prev char, length in
characters, isspace, isalnum, ...)
3. prepeare for display, replace invalid characters with questionmark,
unprintable with dot, left / right / center align
4. comparing strings
in future all string function from util should be moved into strutil, some
function from util have new variant in strutil.
2008-12-29 01:46:37 +03:00
|
|
|
str_release_key (char *key, int case_sen)
|
|
|
|
{
|
|
|
|
used_class.release_key (key, case_sen);
|
|
|
|
}
|