1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-06-14 23:50:19 +02:00

(scm_string_tokenize): Instead of using "isgraphic" as the subtitute

for char-set:graphic when then token-set hsa been defaulted, grab the
real char-set:graphic from (srfi srfi-14).
This commit is contained in:
Marius Vollmer 2002-05-06 18:44:02 +00:00
parent 139e5cb2fb
commit c8519a82f2

View file

@ -2802,7 +2802,7 @@ SCM_DEFINE (scm_string_tokenize, "string-tokenize", 1, 3, 0,
"Split the string @var{s} into a list of substrings, where each\n" "Split the string @var{s} into a list of substrings, where each\n"
"substring is a maximal non-empty contiguous sequence of\n" "substring is a maximal non-empty contiguous sequence of\n"
"characters from the character set @var{token_set}, which\n" "characters from the character set @var{token_set}, which\n"
"defaults to an equivalent of @code{char-set:graphic}.\n" "defaults to @code{char-set:graphic} from module (srfi srfi-14).\n"
"If @var{start} or @var{end} indices are provided, they restrict\n" "If @var{start} or @var{end} indices are provided, they restrict\n"
"@code{string-tokenize} to operating on the indicated substring\n" "@code{string-tokenize} to operating on the indicated substring\n"
"of @var{s}.") "of @var{s}.")
@ -2812,34 +2812,26 @@ SCM_DEFINE (scm_string_tokenize, "string-tokenize", 1, 3, 0,
int cstart, cend; int cstart, cend;
SCM result = SCM_EOL; SCM result = SCM_EOL;
static SCM charset_graphic = SCM_BOOL_F;
SCM_VALIDATE_SUBSTRING_SPEC_COPY (1, s, cstr, SCM_VALIDATE_SUBSTRING_SPEC_COPY (1, s, cstr,
3, start, cstart, 3, start, cstart,
4, end, cend); 4, end, cend);
if (SCM_UNBNDP (token_set)) if (SCM_UNBNDP (token_set))
{ {
int idx; if (charset_graphic == SCM_BOOL_F)
while (cstart < cend)
{ {
while (cstart < cend) SCM srfi_14_module = scm_c_resolve_module ("srfi srfi-14");
{ SCM charset_graphic_var = scm_c_module_lookup (srfi_14_module,
if (isgraph (cstr[cend - 1])) "char-set:graphic");
break; charset_graphic =
cend--; scm_permanent_object (SCM_VARIABLE_REF (charset_graphic_var));
}
if (cstart >= cend)
break;
idx = cend;
while (cstart < cend)
{
if (!isgraph (cstr[cend - 1]))
break;
cend--;
}
result = scm_cons (scm_mem2string (cstr + cend, idx - cend), result);
} }
token_set = charset_graphic;
} }
else if (SCM_CHARSETP (token_set))
if (SCM_CHARSETP (token_set))
{ {
int idx; int idx;