mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-01 20:30:28 +02:00
Make literal strings (i.e., returned by `read') read-only.
* libguile/read.c (scm_read_string): Use `scm_i_make_read_only_string ()' to return a read-only string, as mandated by R5RS. Reported by Bill Schottstaedt <bil@ccrma.Stanford.EDU>. * libguile/strings.c (scm_i_make_read_only_string): New function. (scm_i_shared_substring_read_only): Special-case the empty string so that the read-only and read-write empty strings are `eq?'. This optimization is relied on by the `substring/shared' `empty string' test case in `srfi-13.test'. * libguile/strings.h (scm_i_make_read_only_string): New declaration. * test-suite/tests/strings.test ("string-set!")["literal string"]: New test. * NEWS: Update.
This commit is contained in:
parent
40de0323e7
commit
be5c4a82ab
5 changed files with 38 additions and 13 deletions
1
NEWS
1
NEWS
|
@ -27,6 +27,7 @@ available: Guile is now always configured in "maintainer mode".
|
||||||
* Bugs fixed
|
* Bugs fixed
|
||||||
|
|
||||||
** `symbol->string' now returns a read-only string, as per R5RS
|
** `symbol->string' now returns a read-only string, as per R5RS
|
||||||
|
** Literal strings as returned by `read' are now read-only, as per R5RS
|
||||||
** `guile-config link' now prints `-L$libdir' before `-lguile'
|
** `guile-config link' now prints `-L$libdir' before `-lguile'
|
||||||
** Fix memory corruption involving GOOPS' `class-redefinition'
|
** Fix memory corruption involving GOOPS' `class-redefinition'
|
||||||
** Fix possible deadlock in `mutex-lock'
|
** Fix possible deadlock in `mutex-lock'
|
||||||
|
|
|
@ -514,7 +514,7 @@ scm_read_string (int chr, SCM port)
|
||||||
else
|
else
|
||||||
str = (str == SCM_BOOL_F) ? scm_nullstr : str;
|
str = (str == SCM_BOOL_F) ? scm_nullstr : str;
|
||||||
|
|
||||||
return str;
|
return scm_i_make_read_only_string (str);
|
||||||
}
|
}
|
||||||
#undef FUNC_NAME
|
#undef FUNC_NAME
|
||||||
|
|
||||||
|
|
|
@ -217,6 +217,12 @@ get_str_buf_start (SCM *str, SCM *buf, size_t *start)
|
||||||
*buf = STRING_STRINGBUF (*str);
|
*buf = STRING_STRINGBUF (*str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SCM
|
||||||
|
scm_i_make_read_only_string (SCM str)
|
||||||
|
{
|
||||||
|
return scm_i_substring_read_only (str, 0, STRING_LENGTH (str));
|
||||||
|
}
|
||||||
|
|
||||||
SCM
|
SCM
|
||||||
scm_i_substring (SCM str, size_t start, size_t end)
|
scm_i_substring (SCM str, size_t start, size_t end)
|
||||||
{
|
{
|
||||||
|
@ -234,15 +240,28 @@ scm_i_substring (SCM str, size_t start, size_t end)
|
||||||
SCM
|
SCM
|
||||||
scm_i_substring_read_only (SCM str, size_t start, size_t end)
|
scm_i_substring_read_only (SCM str, size_t start, size_t end)
|
||||||
{
|
{
|
||||||
|
SCM result;
|
||||||
|
|
||||||
|
if (SCM_UNLIKELY (STRING_LENGTH (str) == 0))
|
||||||
|
/* We want the empty string to be `eq?' with the read-only empty
|
||||||
|
string. */
|
||||||
|
result = str;
|
||||||
|
else
|
||||||
|
{
|
||||||
SCM buf;
|
SCM buf;
|
||||||
size_t str_start;
|
size_t str_start;
|
||||||
|
|
||||||
get_str_buf_start (&str, &buf, &str_start);
|
get_str_buf_start (&str, &buf, &str_start);
|
||||||
scm_i_pthread_mutex_lock (&stringbuf_write_mutex);
|
scm_i_pthread_mutex_lock (&stringbuf_write_mutex);
|
||||||
SET_STRINGBUF_SHARED (buf);
|
SET_STRINGBUF_SHARED (buf);
|
||||||
scm_i_pthread_mutex_unlock (&stringbuf_write_mutex);
|
scm_i_pthread_mutex_unlock (&stringbuf_write_mutex);
|
||||||
return scm_double_cell (RO_STRING_TAG, SCM_UNPACK(buf),
|
|
||||||
(scm_t_bits)str_start + start,
|
result = scm_double_cell (RO_STRING_TAG, SCM_UNPACK (buf),
|
||||||
|
(scm_t_bits) str_start + start,
|
||||||
(scm_t_bits) end - start);
|
(scm_t_bits) end - start);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
SCM
|
SCM
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
#ifndef SCM_STRINGS_H
|
#ifndef SCM_STRINGS_H
|
||||||
#define SCM_STRINGS_H
|
#define SCM_STRINGS_H
|
||||||
|
|
||||||
/* Copyright (C) 1995,1996,1997,1998,2000,2001, 2004, 2005, 2006 Free Software Foundation, Inc.
|
/* Copyright (C) 1995,1996,1997,1998,2000,2001, 2004, 2005, 2006, 2008 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
@ -152,6 +152,7 @@ SCM_API void scm_i_get_substring_spec (size_t len,
|
||||||
SCM start, size_t *cstart,
|
SCM start, size_t *cstart,
|
||||||
SCM end, size_t *cend);
|
SCM end, size_t *cend);
|
||||||
SCM_API SCM scm_i_take_stringbufn (char *str, size_t len);
|
SCM_API SCM scm_i_take_stringbufn (char *str, size_t len);
|
||||||
|
SCM_API SCM scm_i_make_read_only_string (SCM str);
|
||||||
|
|
||||||
/* deprecated stuff */
|
/* deprecated stuff */
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
;;;; strings.test --- test suite for Guile's string functions -*- scheme -*-
|
;;;; strings.test --- test suite for Guile's string functions -*- scheme -*-
|
||||||
;;;; Jim Blandy <jimb@red-bean.com> --- August 1999
|
;;;; Jim Blandy <jimb@red-bean.com> --- August 1999
|
||||||
;;;;
|
;;;;
|
||||||
;;;; Copyright (C) 1999, 2001, 2004, 2005, 2006 Free Software Foundation, Inc.
|
;;;; Copyright (C) 1999, 2001, 2004, 2005, 2006, 2008 Free Software Foundation, Inc.
|
||||||
;;;;
|
;;;;
|
||||||
;;;; This program is free software; you can redistribute it and/or modify
|
;;;; 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
|
;;;; it under the terms of the GNU General Public License as published by
|
||||||
|
@ -168,7 +168,11 @@
|
||||||
|
|
||||||
(pass-if-exception "read-only string"
|
(pass-if-exception "read-only string"
|
||||||
exception:read-only-string
|
exception:read-only-string
|
||||||
(string-set! (substring/read-only "abc" 0) 1 #\space)))
|
(string-set! (substring/read-only "abc" 0) 1 #\space))
|
||||||
|
|
||||||
|
(pass-if-exception "literal string"
|
||||||
|
exception:read-only-string
|
||||||
|
(string-set! "an immutable string" 0 #\a)))
|
||||||
|
|
||||||
(with-test-prefix "string-split"
|
(with-test-prefix "string-split"
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue