1 | package test.rewolucja.resources; |
---|
2 | |
---|
3 | import java.util.ArrayList; |
---|
4 | import java.util.HashMap; |
---|
5 | import java.util.List; |
---|
6 | import java.util.Map; |
---|
7 | import java.util.Properties; |
---|
8 | |
---|
9 | import schedframe.resources.units.ResourceUnit; |
---|
10 | import schedframe.scheduling.utils.ResourceParameterName; |
---|
11 | |
---|
12 | |
---|
13 | public class ResourceCharacteristics extends Properties{ |
---|
14 | |
---|
15 | private static final long serialVersionUID = 2719535186621622647L; |
---|
16 | |
---|
17 | protected Map<ResourceParameterName, List<ResourceUnit>> resUnits; |
---|
18 | |
---|
19 | public ResourceCharacteristics(Map<ResourceParameterName, List<ResourceUnit>> resUnits){ |
---|
20 | this.resUnits = resUnits; |
---|
21 | } |
---|
22 | |
---|
23 | public ResourceCharacteristics(){ |
---|
24 | this.resUnits = null; |
---|
25 | } |
---|
26 | |
---|
27 | public Map<ResourceParameterName, List<ResourceUnit>> getResourceUnits() { |
---|
28 | return resUnits; |
---|
29 | } |
---|
30 | |
---|
31 | public ResourceUnit getResourceUnit(ResourceParameterName unitName){ |
---|
32 | return getResourceUnits().get(unitName).get(0); |
---|
33 | } |
---|
34 | |
---|
35 | public void addResourceUnit(ResourceUnit unit){ |
---|
36 | if(resUnits == null){ |
---|
37 | resUnits = new HashMap<ResourceParameterName, List<ResourceUnit>>(2); |
---|
38 | } |
---|
39 | List<ResourceUnit> list = null; |
---|
40 | if(resUnits.containsKey(unit.getName())){ |
---|
41 | list = resUnits.get(unit.getName()); |
---|
42 | } else { |
---|
43 | list = new ArrayList<ResourceUnit>(1); |
---|
44 | resUnits.put(unit.getName(), list); |
---|
45 | } |
---|
46 | list.add(unit); |
---|
47 | } |
---|
48 | |
---|
49 | } |
---|