From 532518c38ae475b9ba5f597a421a3ee3e596f994 Mon Sep 17 00:00:00 2001 From: Olly Betts Date: Thu, 20 Sep 2007 01:04:35 +0000 Subject: [PATCH] [Java] Eliminate some unnecessary uses of a temporary buffer allocated using new[]. SF#1796609. git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@9948 626c5289-ae23-0410-ae9c-e8d60b6d4f22 --- Lib/java/std_wstring.i | 24 ++++++++---------------- 1 file changed, 8 insertions(+), 16 deletions(-) diff --git a/Lib/java/std_wstring.i b/Lib/java/std_wstring.i index 4d7d4d73b..2e849ca3a 100644 --- a/Lib/java/std_wstring.i +++ b/Lib/java/std_wstring.i @@ -37,12 +37,10 @@ class wstring; if (!$1_pstr) return $null; jsize $1_len = jenv->GetStringLength($input); if ($1_len) { - wchar_t *conv_buf = new wchar_t[$1_len]; + $1.reserve($1_len); for (jsize i = 0; i < $1_len; ++i) { - conv_buf[i] = $1_pstr[i]; + $1.append((wchar_t)$1_pstr[i]); } - $1.assign(conv_buf, $1_len); - delete [] conv_buf; } jenv->ReleaseStringChars($input, $1_pstr); %} @@ -56,12 +54,10 @@ class wstring; if (!$1_pstr) return $null; jsize $1_len = jenv->GetStringLength($input); if ($1_len) { - wchar_t *conv_buf = new wchar_t[$1_len]; + $result.reserve($1_len); for (jsize i = 0; i < $1_len; ++i) { - conv_buf[i] = $1_pstr[i]; + $result.append((wchar_t)$1_pstr[i]); } - $result.assign(conv_buf, $1_len); - delete [] conv_buf; } jenv->ReleaseStringChars($input, $1_pstr); %} @@ -108,12 +104,10 @@ class wstring; jsize $1_len = jenv->GetStringLength($input); std::wstring $1_str; if ($1_len) { - wchar_t *conv_buf = new wchar_t[$1_len]; + $1_str.reserve($1_len); for (jsize i = 0; i < $1_len; ++i) { - conv_buf[i] = $1_pstr[i]; + $1_str.append((wchar_t)$1_pstr[i]); } - $1_str.assign(conv_buf, $1_len); - delete [] conv_buf; } $1 = &$1_str; jenv->ReleaseStringChars($input, $1_pstr); @@ -130,12 +124,10 @@ class wstring; /* possible thread/reentrant code problem */ static std::wstring $1_str; if ($1_len) { - wchar_t *conv_buf = new wchar_t[$1_len]; + $1_str.reserve($1_len); for (jsize i = 0; i < $1_len; ++i) { - conv_buf[i] = $1_pstr[i]; + $1_str.append((wchar_t)$1_pstr[i]); } - $1_str.assign(conv_buf, $1_len); - delete [] conv_buf; } $result = &$1_str; jenv->ReleaseStringChars($input, $1_pstr); %}