From 4e46d04d518f2d6616dde51bc23c1cfefd014750 Mon Sep 17 00:00:00 2001 From: tromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4> Date: Tue, 24 Jan 2006 18:10:39 +0000 Subject: [PATCH] * prims.cc (next_property_value): Never return NULL. (process_gcj_properties): Copy 'props' before using it. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@110177 138bc75d-0d04-0410-961f-82ee72b054a4 --- libjava/ChangeLog | 6 ++++++ libjava/prims.cc | 15 ++++++++------- 2 files changed, 14 insertions(+), 7 deletions(-) diff --git a/libjava/ChangeLog b/libjava/ChangeLog index d13425b1316c..a2357c3e747e 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,9 @@ +2006-01-24 Archit Shah <ashah@redhat.com> + Tom Tromey <tromey@redhat.com> + + * prims.cc (next_property_value): Never return NULL. + (process_gcj_properties): Copy 'props' before using it. + 2006-01-23 Keith Seitz <keiths@redhat.com> * java/lang/Class.h (_Jv_FindInterpreterMethod): Add new declaration. diff --git a/libjava/prims.cc b/libjava/prims.cc index 09bca0b6f71f..a968a9b3013f 100644 --- a/libjava/prims.cc +++ b/libjava/prims.cc @@ -857,10 +857,6 @@ next_property_value (char *s, size_t *length) while (isspace (*s)) s++; - // If we've reached the end, return NULL. - if (*s == 0) - return NULL; - // Determine the length of the property value. while (s[l] != 0 && ! isspace (s[l]) @@ -883,13 +879,18 @@ static void process_gcj_properties () { char *props = getenv("GCJ_PROPERTIES"); - char *p = props; - size_t length; - size_t property_count = 0; if (NULL == props) return; + // Later on we will write \0s into this string. It is simplest to + // just duplicate it here. + props = strdup (props); + + char *p = props; + size_t length; + size_t property_count = 0; + // Whip through props quickly in order to count the number of // property values. while (p && (p = next_property_key (p, &length))) -- GitLab