diff options
-rw-r--r-- | devel/glrparser/Makefile | 11 | ||||
-rw-r--r-- | devel/glrparser/files/patch-glr::glrParser.h | 49 |
2 files changed, 52 insertions, 8 deletions
diff --git a/devel/glrparser/Makefile b/devel/glrparser/Makefile index 9a1e51b90d87..ce5cd0f6b2e0 100644 --- a/devel/glrparser/Makefile +++ b/devel/glrparser/Makefile @@ -8,18 +8,13 @@ PORTNAME= glrparser PORTVERSION= 1.4 +PORTREVISION= 1 CATEGORIES= devel MASTER_SITES= http://nlp.fi.muni.cz/projekty/glr/ MAINTAINER= ports@FreeBSD.org -COMMENT= A parser works with the GLR(0) algorithm +COMMENT= A parser which works with the GLR(0) algorithm GNU_CONFIGURE= yes -.include <bsd.port.pre.mk> - -.if ${OSVERSION} >= 502126 -BROKEN= "Does not compile with gcc 3.4.2" -.endif - -.include <bsd.port.post.mk> +.include <bsd.port.mk> diff --git a/devel/glrparser/files/patch-glr::glrParser.h b/devel/glrparser/files/patch-glr::glrParser.h new file mode 100644 index 000000000000..6010623aa1dd --- /dev/null +++ b/devel/glrparser/files/patch-glr::glrParser.h @@ -0,0 +1,49 @@ +--- glr/glrParser.h.orig Wed Mar 26 15:26:15 2003 ++++ glr/glrParser.h Thu Dec 23 16:27:38 2004 +@@ -502,7 +502,7 @@ + glrParser<glrNodeType,glrStateType>::printTable + (ostream &output){ + output << states.size() << endl; +- for(vector<glrStateType*>::iterator i=states.begin();i!=states.end();++i) { ++ for(typename vector<glrStateType*>::iterator i=states.begin();i!=states.end();++i) { + if(*i){ + (*i)->print(symbols,output); + }else{ +@@ -635,7 +635,7 @@ + } + + +- for(deque<glrStateType*>::iterator state=activeStates.begin();state!=activeStates.end();++state){ ++ for(typename deque<glrStateType*>::iterator state=activeStates.begin();state!=activeStates.end();++state){ + (*state)->stack->release(); + (*state)->stack=NULL; + (*state)->crossEdges.clear(); +@@ -1793,7 +1793,7 @@ + } + + for(map<glrSymbolTable::glrSymbol,glrItemSet*>::iterator tran=compState->transitions.begin();tran!=compState->transitions.end();++tran){ +- glrCompStatesMap<glrStateType>::iterator iNextState=compStatesMap.find(tran->second); ++ typename glrCompStatesMap<glrStateType>::iterator iNextState=compStatesMap.find(tran->second); + if(iNextState==compStatesMap.end()){ + + glrStateType *newState=new glrStateType(states.size(),symbols); +@@ -1871,7 +1871,7 @@ + template<class glrNodeType,class glrStateType> void + glrParser<glrNodeType,glrStateType>::clearTable + (){ +- for(vector<glrStateType*>::iterator iState=states.begin();iState!=states.end();++iState){ ++ for(typename vector<glrStateType*>::iterator iState=states.begin();iState!=states.end();++iState){ + delete (*iState); + } + states.clear(); +@@ -1892,8 +1892,8 @@ + template<class glrStateType> void + glrCompStatesMap<glrStateType>::releaseItemSets + (){ +- for(glrCompStatesMap<glrStateType>::iterator i=begin();i!=end();++i)delete i->first; +- clear(); ++ for(typename glrCompStatesMap<glrStateType>::iterator i=this->begin();i!=this->end();++i)delete i->first; ++ this->clear(); + } + + #ifdef CHECK_CONSISTENCY |