/*
-** LCLint - annotation-assisted static program checker
-** Copyright (C) 1994-2000 University of Virginia,
+** Splint - annotation-assisted static program checker
+** Copyright (C) 1994-2003 University of Virginia,
** Massachusetts Institute of Technology
**
** This program is free software; you can redistribute it and/or modify it
** the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
** MA 02111-1307, USA.
**
-** For information on lclint: lclint-request@cs.virginia.edu
-** To report a bug: lclint-bug@cs.virginia.edu
-** For more information: http://lclint.cs.virginia.edu
+** For information on splint: info@splint.org
+** To report a bug: splint-bug@splint.org
+** For more information: http://www.splint.org
*/
/*
** scan.c
** yet implemented in this version).
*/
-# include "lclintMacros.nf"
-# include "llbasic.h"
+# include "splintMacros.nf"
+# include "basic.h"
# include "signature.h"
# include "signature2.h"
# include "scan.h"
# include "scanline.h"
-extern /*@external@*/ /*@unused@*/ YYSTYPE lsllval;
-
static /*@exposed@*/ ltoken LSLScanLookAhead (void);
-static tsource *scanFile; /* file to scan */
+static inputStream scanFile; /* file to scan */
static o_ltoken TokenList[MAXLINE]; /* available tokens */
static int nextToken; /* next available token */
static int lastToken; /* next available slot */
ltoken LSLScanNextToken (void)
{
-
if (nextToken < lastToken)
{
- /*@-retalias@*/
- return TokenList[nextToken++];
- /*@=retalias@*/
+ ltoken res = TokenList[nextToken];
+ TokenList[nextToken] = ltoken_undefined;
+ nextToken++;
+ /*@-dependenttrans@*/
+ return res; /* Its the only reference now. */
+ /*@=dependenttrans@*/
+
}
else
{
lastToken = 0;
lineNumber++;
- line = tsource_nextLine (scanFile);
+ line = inputStream_nextLine (scanFile);
if (line != (char *) 0)
{
- lscanLine (line); /* tokenize */
+ lscanLine (line); /* tokenize */
nextToken = 0;
return LSLScanNextToken ();
}
else
{
- return LSLScanEofToken ();
+ return LSLScanEofToken ();
}
}
}
else
{
lastToken = 0;
- line = tsource_nextLine (scanFile);
+ line = inputStream_nextLine (scanFile);
if (line != (char *) 0)
{
}
}
-/*@exposed@*/ tsource *LSLScanSource (void)
+/*@exposed@*/ inputStream LSLScanSource (void)
{
return scanFile;
}
}
void
-LSLScanReset (tsource *s)
+LSLScanReset (inputStream s)
{
scanFile = s;
lastToken = 0;