eu.mihosoft.vrl.v3d.PropertyStorage Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of JavaCad Show documentation
Show all versions of JavaCad Show documentation
A Java based CSG Cad library
/**
* PropertyStorage.java
*
* Copyright 2014-2014 Michael Hoffer [email protected]. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY Michael Hoffer [email protected] "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL Michael Hoffer [email protected] OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* The views and conclusions contained in the software and documentation are
* those of the authors and should not be interpreted as representing official
* policies, either expressed or implied, of Michael Hoffer
* [email protected].
*/
package eu.mihosoft.vrl.v3d;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import javafx.scene.paint.Color;
/**
* A simple property storage.
*
* @author Michael Hoffer <[email protected]>
*/
public class PropertyStorage {
/** The map. */
private final Map map = new HashMap<>();
/** The Constant colors. */
private static final Color[] colors = {
Color.RED, Color.YELLOW, Color.GREEN, Color.BLUE, Color.MAGENTA,
Color.WHITE, Color.BLACK, Color.GRAY, Color.ORANGE};
/**
* Constructor. Creates a new property storage.
*/
public PropertyStorage() {
}
/**
* Sets a property. Existing properties are overwritten.
*
* @param key key
* @param property property
*/
public void set(String key, Object property) {
map.put(key, property);
}
/**
* Returns a property.
*
* @param property type
* @param key key
* @return the property; an empty {@link java.util.Optional} will be
* returned if the property does not exist or the type does not match
*/
public Optional getValue(String key) {
Object value = map.get(key);
try {
return Optional.ofNullable((T) value);
} catch (ClassCastException ex) {
return Optional.empty();
}
}
/**
* Deletes the requested property if present. Does nothing otherwise.
*
* @param key key
*/
public void delete(String key) {
map.remove(key);
}
/**
* Indicates whether this storage contains the requested property.
*
* @param key key
* @return {@code true} if this storage contains the requested property;
* {@code false}
*/
public boolean contains(String key) {
return map.containsKey(key);
}
public Set getKeys(){
return map.keySet();
}
public void syncProperties(PropertyStorage dying) {
for(String o:dying.map.keySet()) {
Object property = dying.map.get(o);
if(HashSet.class.isInstance(property)) {
HashSet clonedSet = new HashSet();
clonedSet.addAll((HashSet)property);
property=clonedSet;
}
set(o,property);
}
}
}