/hg/icedtea6: Encode new lines, carriage returns, and other spec...
dbhole at icedtea.classpath.org
dbhole at icedtea.classpath.org
Wed Feb 3 08:59:53 PST 2010
changeset c399b5cbbbaf in /hg/icedtea6
details: http://icedtea.classpath.org/hg/icedtea6?cmd=changeset;node=c399b5cbbbaf
author: Deepak Bhole <dbhole at redhat.com>
date: Wed Feb 03 11:59:46 2010 -0500
Encode new lines, carriage returns, and other special characters
before sending them to Java side (de-coding code is already in
effect on Java side).
diffstat:
2 files changed, 38 insertions(+), 4 deletions(-)
ChangeLog | 7 +++++++
plugin/icedteanp/IcedTeaNPPlugin.cc | 35 +++++++++++++++++++++++++++++++----
diffs (62 lines):
diff -r 55c898e59858 -r c399b5cbbbaf ChangeLog
--- a/ChangeLog Wed Feb 03 13:30:49 2010 +0100
+++ b/ChangeLog Wed Feb 03 11:59:46 2010 -0500
@@ -1,3 +1,10 @@ 2010-02-03 Pavel Tisnovsky <ptisnovs at red
+2010-02-03 Deepak Bhole <dbhole at redhat.com>
+
+ * plugin/icedteanp/IcedTeaNPPlugin.cc
+ (plugin_create_applet_tag): Encode new lines, carriage returns, and other
+ special characters before sending them to Java side (de-coding code is
+ already in effect on Java side).
+
2010-02-03 Pavel Tisnovsky <ptisnovs at redhat.com>
* Makefile.am: Add new patch.
diff -r 55c898e59858 -r c399b5cbbbaf plugin/icedteanp/IcedTeaNPPlugin.cc
--- a/plugin/icedteanp/IcedTeaNPPlugin.cc Wed Feb 03 13:30:49 2010 +0100
+++ b/plugin/icedteanp/IcedTeaNPPlugin.cc Wed Feb 03 11:59:46 2010 -0500
@@ -1575,13 +1575,40 @@ plugin_create_applet_tag (int16_t argc,
// characters will pass through the pipe.
if (argv[i] != '\0')
{
- gchar* escaped = NULL;
-
- escaped = g_strescape (argv[i], NULL);
+ // worst case scenario -> all characters are newlines or
+ // returns, each of which translates to 5 substitutions
+ char* escaped = (char*) calloc(((strlen(argv[i])*5)+1), sizeof(char));
+
+ strcpy(escaped, "");
+ for (int j=0; j < strlen(argv[i]); j++)
+ {
+ if (argv[i][j] == '\r')
+ strcat(escaped, " ");
+ else if (argv[i][j] == '\n')
+ strcat(escaped, " ");
+ else if (argv[i][j] == '>')
+ strcat(escaped, ">");
+ else if (argv[i][j] == '<')
+ strcat(escaped, "<");
+ else if (argv[i][j] == '&')
+ strcat(escaped, "&");
+ else
+ {
+ char* orig_char = (char*) calloc(2, sizeof(char));
+ orig_char[0] = argv[i][j];
+ orig_char[1] = '\0';
+
+ strcat(escaped, orig_char);
+
+ free(orig_char);
+ orig_char = NULL;
+ }
+ }
+
parameters = g_strconcat (parameters, "<PARAM NAME=\"", argn[i],
"\" VALUE=\"", escaped, "\">", NULL);
- g_free (escaped);
+ free (escaped);
escaped = NULL;
}
}
More information about the distro-pkg-dev
mailing list