mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-10-26 01:33:45 +02:00 
			
		
		
		
	git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1676 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			117 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * SList.C
 | |
|  *
 | |
|  * SOFTWARE RIGHTS
 | |
|  *
 | |
|  * We reserve no LEGAL rights to SORCERER -- SORCERER is in the public
 | |
|  * domain.  An individual or company may do whatever they wish with
 | |
|  * source code distributed with SORCERER or the code generated by
 | |
|  * SORCERER, including the incorporation of SORCERER, or its output, into
 | |
|  * commerical software.
 | |
|  *
 | |
|  * We encourage users to develop software with SORCERER.  However, we do
 | |
|  * ask that credit is given to us for developing SORCERER.  By "credit",
 | |
|  * we mean that if you incorporate our source code into one of your
 | |
|  * programs (commercial product, research project, or otherwise) that you
 | |
|  * acknowledge this fact somewhere in the documentation, research report,
 | |
|  * etc...  If you like SORCERER and have developed a nice tool with the
 | |
|  * output, please mention that you developed it using SORCERER.  In
 | |
|  * addition, we ask that this header remain intact in our source code.
 | |
|  * As long as these guidelines are kept, we expect to continue enhancing
 | |
|  * this system and expect to make other tools available as they are
 | |
|  * completed.
 | |
|  *
 | |
|  * PCCTS 1.33
 | |
|  * Terence Parr
 | |
|  * Parr Research Corporation
 | |
|  * with Purdue University and AHPCRC, University of Minnesota
 | |
|  * 1992-2000
 | |
|  */
 | |
| 
 | |
| #define ANTLR_SUPPORT_CODE
 | |
| 
 | |
| #include "SList.h"
 | |
| #include "pccts_stdarg.h" // MR23
 | |
| 
 | |
| /* Iterate over a list of elements; returns ptr to a new element
 | |
|  * in list upon every call and NULL when no more are left.
 | |
|  * Very useful like this:
 | |
|  *
 | |
|  *		cursor = mylist;
 | |
|  *		while ( (p=mylist->iterate(&cursor)) ) {
 | |
|  *			// place with element p
 | |
|  *		}
 | |
|  *
 | |
|  * The cursor must be initialized to point to the list to iterate over.
 | |
|  */
 | |
| void *SList::
 | |
| iterate(SListNode **cursor)
 | |
| {
 | |
| 	void *e;
 | |
| 
 | |
| 	if ( cursor == NULL || *cursor==NULL ) return NULL;
 | |
| 	if ( head == *cursor ) { *cursor = (*cursor)->next(); }
 | |
| 	e = (*cursor)->elem();
 | |
| 	(*cursor) = (*cursor)->next();
 | |
| 	return e;
 | |
| }
 | |
| 
 | |
| /* add an element to end of list. */
 | |
| void SList::
 | |
| add(void *e)
 | |
| {
 | |
| 	SListNode *p, *tail=NULL;
 | |
| 	require(e!=NULL, "slist_add: attempting to add NULL list element");
 | |
| 
 | |
| 	p = new SListNode;
 | |
| 	require(p!=NULL, "add: cannot alloc new list node");
 | |
| 	p->setElem(e);
 | |
| 	if ( head == NULL )
 | |
| 	{
 | |
| 		head = tail = p;
 | |
| 	}
 | |
| 	else								/* find end of list */
 | |
| 	{
 | |
| 		tail->setNext(p);
 | |
| 		tail = p;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| void SList::
 | |
| lfree()
 | |
| {
 | |
| 	SListNode *p,*q;
 | |
| 
 | |
| 	if ( head==NULL ) return;	/* empty list */
 | |
| 	for (p = head; p!=NULL; p=q)
 | |
| 	{
 | |
| 		q = p->next();
 | |
| 		free(p);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| PCCTS_AST *SList::
 | |
| to_ast(SList list)
 | |
| {
 | |
| 	PCCTS_AST *t=NULL, *last=NULL;
 | |
| 	SListNode *p;
 | |
| 
 | |
| 	for (p = head; p!=NULL; p=p->next())
 | |
| 	{
 | |
| 		PCCTS_AST *u = (PCCTS_AST *)p->elem();
 | |
| 		if ( last==NULL ) last = t = u;
 | |
| 		else { last->setRight(u); last = u; }
 | |
| 	}
 | |
| 	return t;
 | |
| }
 | |
| 
 | |
| // MR23
 | |
| int SList::printMessage(FILE* pFile, const char* pFormat, ...)
 | |
| {
 | |
| 	va_list marker;
 | |
| 	va_start( marker, pFormat );
 | |
|   	int iRet = vfprintf(pFile, pFormat, marker);
 | |
| 	va_end( marker );
 | |
| 	return iRet;
 | |
| }
 |