From: Carsten Haitzler Date: Sat, 9 Apr 2011 02:49:19 +0000 (+0000) Subject: if we find a \ inside a macro parameter... handle it as an escape and X-Git-Tag: submit/efl/20131015.063327~9997 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=917a0ac7b2f4d9f2d95ff1945785f2ec029df4b3;p=platform%2Fupstream%2Fefl.git if we find a \ inside a macro parameter... handle it as an escape and skip it giving the next char verbatim. SVN revision: 58510 --- diff --git a/legacy/edje/src/bin/epp/cpplib.c b/legacy/edje/src/bin/epp/cpplib.c index ae458bcc72..8c92b3b2c4 100644 --- a/legacy/edje/src/bin/epp/cpplib.c +++ b/legacy/edje/src/bin/epp/cpplib.c @@ -2031,10 +2031,26 @@ cpp_expand_to_buffer(cpp_reader * pfile, unsigned char *buf, int length) unsigned char *p1 = buf; unsigned char *p2 = buf1; +#if 0 + while (p1 != limit) *p2++ = *p1++; +#else while (p1 != limit) - *p2++ = *p1++; + { + if (*p1 == '\\') + { + p1++; + if (p1 != limit) + *p2++ = *p1++; + } + else + { + *p2++ = *p1++; + } + } +#endif + *p2 = 0; + length = p2 - buf1; } - buf1[length] = 0; ip = cpp_push_buffer(pfile, buf1, length); ip->has_escapes = 1; @@ -2937,9 +2953,11 @@ macroexpand(cpp_reader * pfile, HASHNODE * hp) xbuf_len += args[ap->argno].stringified_length; } else if (ap->raw_before || ap->raw_after || CPP_TRADITIONAL(pfile)) - /* Add 4 for two newline-space markers to prevent - * token concatenation. */ - xbuf_len += args[ap->argno].raw_length + 4; + { + /* Add 4 for two newline-space markers to prevent + * token concatenation. */ + xbuf_len += args[ap->argno].raw_length + 4; + } else { /* We have an ordinary (expanded) occurrence of the arg.