]> git.sur5r.net Git - cc65/commitdiff
Fixed problem with last change: Static declaration do also set the SC_EXTERN
authoruz <uz@b7a2c559-68d2-44c3-8de9-860c34a00d81>
Tue, 24 Aug 2010 07:28:08 +0000 (07:28 +0000)
committeruz <uz@b7a2c559-68d2-44c3-8de9-860c34a00d81>
Tue, 24 Aug 2010 07:28:08 +0000 (07:28 +0000)
flag (have to check why).

git-svn-id: svn://svn.cc65.org/cc65/trunk@4818 b7a2c559-68d2-44c3-8de9-860c34a00d81

src/cc65/compile.c

index e74ba2a4db418cdeb908f81fe11c3c8adddbb147..d0545e92b31d99f568e5507e68cc7ab2c0413fbe 100644 (file)
@@ -138,8 +138,8 @@ static void Parse (void)
            }
 
             /* Check if we must reserve storage for the variable. We do this,
-             * 
-             *   - if it is not a typedef or function, 
+             *
+             *   - if it is not a typedef or function,
              *   - if we don't had a storage class given ("int i")
              *   - if the storage class is explicitly specified as static,
              *   - or if there is an initialization.
@@ -149,8 +149,8 @@ static void Parse (void)
            if ((Decl.StorageClass & SC_FUNC) != SC_FUNC          &&
                 (Decl.StorageClass & SC_TYPEDEF) != SC_TYPEDEF    &&
                 ((Spec.Flags & DS_DEF_STORAGE) != 0         ||
-                 (Decl.StorageClass & SC_STATIC) != 0       ||
-                 ((Decl.StorageClass & SC_EXTERN) != 0 && 
+                 (Decl.StorageClass & (SC_EXTERN|SC_STATIC)) == SC_STATIC ||
+                 ((Decl.StorageClass & SC_EXTERN) != 0 &&
                   CurTok.Tok == TOK_ASSIGN))) {
 
                 /* We will allocate storage */