From 91af6cba27ce2e331d6a756f5137ae99a2a2b3b5 Mon Sep 17 00:00:00 2001 From: William S Fulton Date: Thu, 22 Dec 2022 21:06:45 +0000 Subject: Parser code refactor around variadic types --- Source/CParse/parser.y | 41 +++++++++++++++++++++-------------------- 1 file changed, 21 insertions(+), 20 deletions(-) (limited to 'Source/CParse') diff --git a/Source/CParse/parser.y b/Source/CParse/parser.y index af15f43ec..5204c4437 100644 --- a/Source/CParse/parser.y +++ b/Source/CParse/parser.y @@ -66,7 +66,7 @@ static String *Classprefix = 0; static String *Namespaceprefix = 0; static int inclass = 0; static Node *currentOuterClass = 0; /* for nested classes */ -static const char *last_cpptype = 0; +static String *last_cpptype = 0; static int inherit_list = 0; static Parm *template_parameters = 0; static int parsing_template_declaration = 0; @@ -1178,7 +1178,7 @@ static void update_nested_classes(Node *n) * Create the nested class/struct/union as a forward declaration. * ----------------------------------------------------------------------------- */ -static Node *nested_forward_declaration(const char *storage, const char *kind, String *sname, String *name, Node *cpp_opt_declarators) { +static Node *nested_forward_declaration(const char *storage, const String *kind, String *sname, String *name, Node *cpp_opt_declarators) { Node *nn = 0; if (sname) { @@ -1681,7 +1681,8 @@ static String *add_qualifier_to_declarator(SwigType *type, SwigType *qualifier) %type

parm_no_dox parm valparm rawvalparms valparms valptail ; %type

typemap_parm tm_list tm_tail ; %type

templateparameter ; -%type templcpptype cpptype classkey classkeyopt access_specifier; +%type templcpptype cpptype classkey classkeyopt; +%type access_specifier; %type base_specifier; %type variadic; %type type rawtype type_right anon_bitfield_type decltype ; @@ -3710,7 +3711,7 @@ cpp_class_decl: storage_class cpptype idcolon class_virt_specifier_opt inherit L Delete(fbase); Delete(tbase); } - if (strcmp($2,"class") == 0) { + if (Strcmp($2, "class") == 0) { cplus_mode = CPLUS_PRIVATE; } else { cplus_mode = CPLUS_PUBLIC; @@ -3927,7 +3928,7 @@ cpp_class_decl: storage_class cpptype idcolon class_virt_specifier_opt inherit L Swig_features_get(Swig_cparse_features(), Namespaceprefix, 0, 0, $$); /* save yyrename to the class attribute, to be used later in add_symbols()*/ Setattr($$, "class_rename", make_name($$,0,0)); - if (strcmp($2,"class") == 0) { + if (Strcmp($2, "class") == 0) { cplus_mode = CPLUS_PRIVATE; } else { cplus_mode = CPLUS_PUBLIC; @@ -4395,7 +4396,7 @@ template_parms : templateparameter templateparameterstail { ; templateparameter : templcpptype def_args { - $$ = NewParmWithoutFileLineInfo(NewString($1), 0); + $$ = NewParmWithoutFileLineInfo($1, 0); Setfile($$, cparse_file); Setline($$, cparse_line); Setattr($$, "value", $2.rawval ? $2.rawval : $2.val); @@ -6962,22 +6963,22 @@ access_specifier : PUBLIC { $$ = (char*)"public"; } | PROTECTED { $$ = (char*)"protected"; } ; -templcpptype : CLASS { - $$ = (char*)"class"; +templcpptype : CLASS { + $$ = NewString("class"); if (!inherit_list) last_cpptype = $$; } - | TYPENAME { - $$ = (char *)"typename"; + | TYPENAME { + $$ = NewString("typename"); if (!inherit_list) last_cpptype = $$; } | CLASS ELLIPSIS { - /* TODO: call SwigType_add_variadic() instead */ - $$ = (char *)"v.class"; + $$ = NewString("class"); + $$ = SwigType_add_variadic($$); if (!inherit_list) last_cpptype = $$; } | TYPENAME ELLIPSIS { - /* TODO: call SwigType_add_variadic() instead */ - $$ = (char *)"v.typename"; + $$ = NewString("typename"); + $$ = SwigType_add_variadic($$); if (!inherit_list) last_cpptype = $$; } ; @@ -6985,26 +6986,26 @@ templcpptype : CLASS { cpptype : templcpptype { $$ = $1; } - | STRUCT { - $$ = (char*)"struct"; + | STRUCT { + $$ = NewString("struct"); if (!inherit_list) last_cpptype = $$; } | UNION { - $$ = (char*)"union"; + $$ = NewString("union"); if (!inherit_list) last_cpptype = $$; } ; classkey : CLASS { - $$ = (char*)"class"; + $$ = NewString("class"); if (!inherit_list) last_cpptype = $$; } | STRUCT { - $$ = (char*)"struct"; + $$ = NewString("struct"); if (!inherit_list) last_cpptype = $$; } | UNION { - $$ = (char*)"union"; + $$ = NewString("union"); if (!inherit_list) last_cpptype = $$; } ; -- cgit v1.2.1