]> andersk Git - splint.git/blobdiff - src/scan.c
Fixed all /*@i...@*/ tags (except 1).
[splint.git] / src / scan.c
index 05fce973a838e3274e9a5fdad6fb6dd4e5f19ec1..8c38a02780cdd7a10326be668a9f072a34b68c1a 100644 (file)
@@ -1,6 +1,6 @@
 /*
-** 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
@@ -17,9 +17,9 @@
 ** 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 */
@@ -69,29 +67,32 @@ unsigned int lsllex (YYSTYPE *lval)
 
 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 ();
        }
     }
 }
@@ -106,7 +107,7 @@ LSLScanLookAhead (void)
   else
     {
       lastToken = 0;           
-      line = tsource_nextLine (scanFile);
+      line = inputStream_nextLine (scanFile);
 
       if (line != (char *) 0)
        {
@@ -142,7 +143,7 @@ LSLScanFreshToken (ltoken tok)
     }
 }
 
-/*@exposed@*/ tsource *LSLScanSource (void)
+/*@exposed@*/ inputStream LSLScanSource (void)
 {
   return scanFile;
 }
@@ -154,7 +155,7 @@ LSLScanInit (void)
 }
 
 void
-LSLScanReset (tsource *s)
+LSLScanReset (inputStream s)
 {
   scanFile = s;
   lastToken = 0;
This page took 0.037345 seconds and 4 git commands to generate.