File: Namespace.java

package info (click to toggle)
herold 8.0.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,304 kB
  • sloc: java: 40,460; xml: 513; makefile: 37; sh: 29
file content (120 lines) | stat: -rw-r--r-- 2,703 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/* 
 * Copyright (C) 2001-2013 Michael Fuchs
 *
 * This file is part of herold.
 * 
 * herold is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 * 
 * herold is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with herold.  If not, see <http://www.gnu.org/licenses/>.  
 */
package org.dbdoclet.trafo.script;

import java.util.Collection;
import java.util.HashMap;

public class Namespace {

	private HashMap<String, AttributeRule> attributeRuleMap;
	private String name;
	private HashMap<String, NodeRule> nodeRuleMap;
	private HashMap<String, Section> sectionMap;

	public Namespace(String name) {

		this.setName(name);
		sectionMap = new HashMap<>();
		nodeRuleMap = new HashMap<>();
		attributeRuleMap = new HashMap<>();
	}

	public void addAttributeRule(AttributeRule attributeRule) {
		
		if (attributeRule == null) {
			return;			
		}
		
		attributeRuleMap.put(attributeRule.getName(), attributeRule);
	}
	
	public void addNodeRule(NodeRule nodeRule) {
		
		if (nodeRule == null) {
			return;			
		}
		
		nodeRuleMap.put(nodeRule.getName(), nodeRule);
	}
	
	public void addSection(Section section) {
		
		if (section == null) {
			return;			
		}
		
		sectionMap.put(section.getName(), section);
	}
	
	public AttributeRule findAttributeRule(String name) {
		return attributeRuleMap.get(name);
	}

	public NodeRule findNodeRule(String name) {
		return nodeRuleMap.get(name);
	}

	public Section findSection(String name) {
		return sectionMap.get(name);
	}

	public Collection<AttributeRule> getAttributeRules() {
		return attributeRuleMap.values();
	}

	public String getName() {
		return name;
	}

	public Collection<NodeRule> getNodeRules() {
		return nodeRuleMap.values();
	}

	public Collection<Section> getSections() {
		return sectionMap.values();
	}

	public void setName(String name) {
		this.name = name;
	}

	public Section addSection(String sectionName) {

		if (sectionName == null || sectionName.trim().length() == 0) {
			return null;
		}
		
		Section section = new Section(sectionName);
		addSection(section);
		return section;
	}

	public Section findOrCreateSection(String name) {

		Section section = findSection(name);
		
		if (section == null) {
			section = new Section(name);
			addSection(section);
		}
		
		return section;
	}
}