Package: FlatCheckedEnvironment

FlatCheckedEnvironment

nameinstructionbranchcomplexitylinemethod
FlatCheckedEnvironment(ITypeCheckerAssistantFactory, List, Environment, NameScope)
M: 0 C: 17
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 5
100%
M: 0 C: 1
100%
FlatCheckedEnvironment(ITypeCheckerAssistantFactory, List, NameScope)
M: 0 C: 12
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 4
100%
M: 0 C: 1
100%
FlatCheckedEnvironment(ITypeCheckerAssistantFactory, PDefinition, Environment, NameScope)
M: 0 C: 18
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 5
100%
M: 0 C: 1
100%
isStatic()
M: 0 C: 3
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
setStatic(boolean)
M: 0 C: 4
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 2
100%
M: 0 C: 1
100%

Coverage

1: /*******************************************************************************
2: *
3: *        Copyright (c) 2008 Fujitsu Services Ltd.
4: *
5: *        Author: Nick Battle
6: *
7: *        This file is part of VDMJ.
8: *
9: *        VDMJ is free software: you can redistribute it and/or modify
10: *        it under the terms of the GNU General Public License as published by
11: *        the Free Software Foundation, either version 3 of the License, or
12: *        (at your option) any later version.
13: *
14: *        VDMJ is distributed in the hope that it will be useful,
15: *        but WITHOUT ANY WARRANTY; without even the implied warranty of
16: *        MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17: *        GNU General Public License for more details.
18: *
19: *        You should have received a copy of the GNU General Public License
20: *        along with VDMJ. If not, see <http://www.gnu.org/licenses/>.
21: *
22: ******************************************************************************/
23:
24: package org.overture.typechecker;
25:
26: import java.util.List;
27:
28: import org.overture.ast.definitions.PDefinition;
29: import org.overture.ast.typechecker.NameScope;
30: import org.overture.typechecker.assistant.ITypeCheckerAssistantFactory;
31:
32: /**
33: * Define the type checking environment for a list of definitions, including a check for duplicates and name hiding.
34: */
35:
36: public class FlatCheckedEnvironment extends FlatEnvironment
37: {
38:         private boolean isStatic = false;
39:
40:         public FlatCheckedEnvironment(ITypeCheckerAssistantFactory af,
41:                         List<PDefinition> definitions, NameScope scope)
42:         {
43:                 super(af, definitions);
44:                 dupHideCheck(definitions, scope);
45:         }
46:
47:         public FlatCheckedEnvironment(ITypeCheckerAssistantFactory af,
48:                         List<PDefinition> definitions, Environment env, NameScope scope)
49:         {
50:                 super(af, definitions, env);
51:                 dupHideCheck(definitions, scope);
52:                 setStatic(env.isStatic());
53:         }
54:
55:         public FlatCheckedEnvironment(ITypeCheckerAssistantFactory af,
56:                         PDefinition one, Environment env, NameScope scope)
57:         {
58:                 super(af, one, env);
59:                 dupHideCheck(definitions, scope);
60:                 setStatic(env.isStatic());
61:         }
62:
63:         // TODO: AccessSpecifier not defined
64:         // public void setStatic(AccessSpecifier access)
65:         // {
66:         // isStatic = access.isStatic;
67:         // }
68:
69:         public void setStatic(boolean access)
70:         {
71:                 isStatic = access;
72:         }
73:
74:         @Override
75:         public boolean isStatic()
76:         {
77:                 return isStatic;
78:         }
79: }