summaryrefslogtreecommitdiff
path: root/library/backend/vcc_yacc.cpp
Side-by-side diff
Diffstat (limited to 'library/backend/vcc_yacc.cpp') (more/less context) (show whitespace changes)
-rw-r--r--library/backend/vcc_yacc.cpp29
1 files changed, 14 insertions, 15 deletions
diff --git a/library/backend/vcc_yacc.cpp b/library/backend/vcc_yacc.cpp
index 5f53aef..4006bc2 100644
--- a/library/backend/vcc_yacc.cpp
+++ b/library/backend/vcc_yacc.cpp
@@ -463,3 +463,3 @@ static void enterAttr(const char *s1, const char *s2)
{
- const char *p1, *p2;
+ const char *p1, *p2=0;
p1 = lookupProp_(s1);
@@ -835,3 +835,3 @@ static void finiLex() {
*/
-static char * lexGetDataFromBase64()
+static int lexGetDataFromBase64()
{
@@ -848,2 +848,3 @@ static char * lexGetDataFromBase64()
c = lexGetc();
+ lexSkipWhite();
if (c == '\n') {
@@ -870,4 +871,2 @@ static char * lexGetDataFromBase64()
pad++;
- } else if ((c == ' ') || (c == '\t')) {
- continue;
} else { /* error condition */
@@ -880,3 +879,5 @@ static char * lexGetDataFromBase64()
while (c != EOF) {
- if (c == '\n' && lexLookahead() == '\n') {
+ if (c == '\n') {
+ lexSkipWhite();
+ if(lexLookahead() == '\n') {
++mime_lineNum;
@@ -884,2 +885,3 @@ static char * lexGetDataFromBase64()
}
+ }
c = lexGetc();
@@ -887,3 +889,3 @@ static char * lexGetDataFromBase64()
}
- return NULL;
+ return c != EOF;
}
@@ -933,3 +935,3 @@ static char * lexGetDataFromBase64()
}
- return 0;
+ return bytesLen;
}
@@ -964,3 +966,3 @@ static char* lexGetQuotedPrintable()
- while (c != EOF && c != ';') {
+ while (c != EOF && (c != ';' || !fieldedProp)) {
if (c == '\n') {
@@ -1054,7 +1056,4 @@ static int yylex() {
/* get each char and convert to bin on the fly... */
- p = lexGetDataFromBase64();
-#if 0
- yylval.str = p;
- return STRING;
-#endif
+ yylval.str = NULL;
+ return lexGetDataFromBase64() ? STRING : 0;
}
@@ -1240,3 +1239,3 @@ void mime_error_(char *s)
-#line 1240 "y.tab.c"
+#line 1241 "y.tab.c"
#define YYABORT goto yyabort
@@ -1540,3 +1539,3 @@ case 45:
break;
-#line 1540 "y.tab.c"
+#line 1541 "y.tab.c"
}