Added support for template double brackets for C++0x.
Added test cases. git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/branches/gsoc2009-matevz@11245 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
3e0fc9f7b9
commit
2b4b1cc157
4 changed files with 144 additions and 4 deletions
|
|
@ -82,6 +82,7 @@ CPP_TEST_BROKEN += \
|
|||
nested_struct \
|
||||
overload_complicated \
|
||||
template_default_pointer \
|
||||
template_double_brackets_broke \
|
||||
template_expr
|
||||
|
||||
|
||||
|
|
@ -311,6 +312,7 @@ CPP_TEST_CASES += \
|
|||
template_default_inherit \
|
||||
template_default_qualify \
|
||||
template_default_vw \
|
||||
template_double_brackets \
|
||||
template_enum \
|
||||
template_enum_ns_inherit \
|
||||
template_enum_typedef \
|
||||
|
|
|
|||
26
Examples/test-suite/template_double_brackets.i
Normal file
26
Examples/test-suite/template_double_brackets.i
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
%module foo
|
||||
#include <map>
|
||||
std::map<int,std::map<int, double>> m;
|
||||
std::map<int,std::map<int, double> > n;
|
||||
std::map< std::map<(6>>1), double>, double> o;
|
||||
//std::map< std::map<6>>1, double>, double> p; // fails as it should
|
||||
|
||||
class ABC {
|
||||
public:
|
||||
int a;
|
||||
int operator>>(ABC &);
|
||||
int operator<<(ABC &);
|
||||
};
|
||||
|
||||
template<class T>
|
||||
class ABC2 {
|
||||
public:
|
||||
int a;
|
||||
|
||||
template<typename U>
|
||||
int operator>>(ABC &, U);
|
||||
|
||||
template<typename U>
|
||||
int operator<<(ABC &, U);
|
||||
};
|
||||
|
||||
26
Examples/test-suite/template_double_brackets_broke.i
Normal file
26
Examples/test-suite/template_double_brackets_broke.i
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
%module foo
|
||||
#include <map>
|
||||
std::map<int,std::map<int, double>> m;
|
||||
std::map<int,std::map<int, double> > n;
|
||||
std::map< std::map<(6>>1), double>, double> o;
|
||||
std::map< std::map<6>>1, double>, double> p; // fails as it should
|
||||
|
||||
class ABC {
|
||||
public:
|
||||
int a;
|
||||
int operator>>(ABC &);
|
||||
int operator<<(ABC &);
|
||||
};
|
||||
|
||||
template<class T>
|
||||
class ABC2 {
|
||||
public:
|
||||
int a;
|
||||
|
||||
template<typename U>
|
||||
int operator>>(ABC &, U);
|
||||
|
||||
template<typename U>
|
||||
int operator<<(ABC &, U);
|
||||
};
|
||||
|
||||
|
|
@ -31,8 +31,12 @@ struct Scanner {
|
|||
String *error; /* Last error message (if any) */
|
||||
int error_line; /* Error line number */
|
||||
int freeze_line; /* Suspend line number updates */
|
||||
List *brackets; /* Current level of < > brackets on each level */
|
||||
};
|
||||
|
||||
void Scanner_push_brackets(Scanner*);
|
||||
void Scanner_clear_brackets(Scanner*);
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* NewScanner()
|
||||
*
|
||||
|
|
@ -53,6 +57,8 @@ Scanner *NewScanner(void) {
|
|||
s->str = 0;
|
||||
s->error = 0;
|
||||
s->freeze_line = 0;
|
||||
s->brackets = NewList();
|
||||
Scanner_push_brackets(s);
|
||||
return s;
|
||||
}
|
||||
|
||||
|
|
@ -65,6 +71,7 @@ Scanner *NewScanner(void) {
|
|||
void DelScanner(Scanner * s) {
|
||||
assert(s);
|
||||
Delete(s->scanobjs);
|
||||
Delete(s->brackets);
|
||||
Delete(s->text);
|
||||
Delete(s->file);
|
||||
Delete(s->error);
|
||||
|
|
@ -84,6 +91,7 @@ void Scanner_clear(Scanner * s) {
|
|||
Delete(s->str);
|
||||
Clear(s->text);
|
||||
Clear(s->scanobjs);
|
||||
Scanner_clear_brackets(s);
|
||||
Delete(s->error);
|
||||
s->error = 0;
|
||||
s->line = 1;
|
||||
|
|
@ -245,6 +253,74 @@ Scanner_freeze_line(Scanner *s, int val) {
|
|||
s->freeze_line = val;
|
||||
}
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Scanner_brackets()
|
||||
*
|
||||
* Returns the number of brackets at the current depth.
|
||||
* ----------------------------------------------------------------------------- */
|
||||
int*
|
||||
Scanner_brackets(Scanner *s) {
|
||||
return (int*)(**((void***)Getitem(s->brackets, 0))); /* TODO: Use VoidObj*->ptr instead of void** */
|
||||
}
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Scanner_clear_brackets()
|
||||
*
|
||||
* Resets the current depth and clears all brackets.
|
||||
* Usually called at the end of statements;
|
||||
* ----------------------------------------------------------------------------- */
|
||||
void
|
||||
Scanner_clear_brackets(Scanner *s) {
|
||||
Clear(s->brackets);
|
||||
Scanner_push_brackets(s); /* base bracket count should always be created */
|
||||
}
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Scanner_inc_brackets()
|
||||
*
|
||||
* Increases the number of brackets at the current depth.
|
||||
* Usually called when '<' was found.
|
||||
* ----------------------------------------------------------------------------- */
|
||||
void
|
||||
Scanner_inc_brackets(Scanner *s) {
|
||||
(*Scanner_brackets(s))++;
|
||||
}
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Scanner_dec_brackets()
|
||||
*
|
||||
* Decreases the number of brackets at the current depth.
|
||||
* Usually called when '>' was found.
|
||||
* ----------------------------------------------------------------------------- */
|
||||
void
|
||||
Scanner_dec_brackets(Scanner *s) {
|
||||
(*Scanner_brackets(s))--;
|
||||
}
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Scanner_push_brackets()
|
||||
*
|
||||
* Increases the depth of brackets.
|
||||
* Usually called when '(' was found.
|
||||
* ----------------------------------------------------------------------------- */
|
||||
void
|
||||
Scanner_push_brackets(Scanner *s) {
|
||||
int *newInt = malloc(sizeof(int));
|
||||
*newInt = 0;
|
||||
Push(s->brackets, NewVoid(newInt, free));
|
||||
}
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Scanner_pop_brackets()
|
||||
*
|
||||
* Decreases the depth of brackets.
|
||||
* Usually called when ')' was found.
|
||||
* ----------------------------------------------------------------------------- */
|
||||
void
|
||||
Scanner_pop_brackets(Scanner *s) {
|
||||
Delitem(s->brackets, 0);
|
||||
}
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* retract()
|
||||
*
|
||||
|
|
@ -432,12 +508,18 @@ static int look(Scanner * s) {
|
|||
|
||||
/* Look for single character symbols */
|
||||
|
||||
else if (c == '(')
|
||||
else if (c == '(') {
|
||||
Scanner_push_brackets(s);
|
||||
return SWIG_TOKEN_LPAREN;
|
||||
else if (c == ')')
|
||||
}
|
||||
else if (c == ')') {
|
||||
Scanner_pop_brackets(s);
|
||||
return SWIG_TOKEN_RPAREN;
|
||||
else if (c == ';')
|
||||
}
|
||||
else if (c == ';') {
|
||||
Scanner_clear_brackets(s);
|
||||
return SWIG_TOKEN_SEMI;
|
||||
}
|
||||
else if (c == ',')
|
||||
return SWIG_TOKEN_COMMA;
|
||||
else if (c == '*')
|
||||
|
|
@ -704,6 +786,7 @@ static int look(Scanner * s) {
|
|||
break;
|
||||
|
||||
case 60: /* shift operators */
|
||||
Scanner_inc_brackets(s);
|
||||
if ((c = nextchar(s)) == 0)
|
||||
return SWIG_TOKEN_LESSTHAN;
|
||||
if (c == '<')
|
||||
|
|
@ -716,9 +799,10 @@ static int look(Scanner * s) {
|
|||
}
|
||||
break;
|
||||
case 61:
|
||||
Scanner_dec_brackets(s);
|
||||
if ((c = nextchar(s)) == 0)
|
||||
return SWIG_TOKEN_GREATERTHAN;
|
||||
if (c == '>')
|
||||
if (c == '>' && ((*Scanner_brackets(s))<0)) /* go to double >> only, if no template < has been used */
|
||||
state = 250;
|
||||
else if (c == '=')
|
||||
return SWIG_TOKEN_GTEQUAL;
|
||||
|
|
@ -1024,6 +1108,7 @@ static int look(Scanner * s) {
|
|||
break;
|
||||
|
||||
case 240: /* LSHIFT, LSEQUAL */
|
||||
Scanner_inc_brackets(s);
|
||||
if ((c = nextchar(s)) == 0)
|
||||
return SWIG_TOKEN_LSHIFT;
|
||||
else if (c == '=')
|
||||
|
|
@ -1035,6 +1120,7 @@ static int look(Scanner * s) {
|
|||
break;
|
||||
|
||||
case 250: /* RSHIFT, RSEQUAL */
|
||||
Scanner_dec_brackets(s);
|
||||
if ((c = nextchar(s)) == 0)
|
||||
return SWIG_TOKEN_RSHIFT;
|
||||
else if (c == '=')
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue