diff options
author | Adrien Hopkins <ahopk127@my.yorku.ca> | 2021-06-28 17:16:12 -0500 |
---|---|---|
committer | Adrien Hopkins <ahopk127@my.yorku.ca> | 2021-06-28 17:16:12 -0500 |
commit | 78af49e0e5b2ab2eaab87e62c33089c5caa834f8 (patch) | |
tree | 14d2a49900d706070882cfe150e08ec1882cdbc2 /src/main/java/sevenUnits/unit/Nameable.java | |
parent | a34d79383061ba53951f3f69a44f142820e82216 (diff) |
Renamed project to 7Units
Diffstat (limited to 'src/main/java/sevenUnits/unit/Nameable.java')
-rw-r--r-- | src/main/java/sevenUnits/unit/Nameable.java | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/src/main/java/sevenUnits/unit/Nameable.java b/src/main/java/sevenUnits/unit/Nameable.java new file mode 100644 index 0000000..ed23687 --- /dev/null +++ b/src/main/java/sevenUnits/unit/Nameable.java @@ -0,0 +1,59 @@ +/** + * Copyright (C) 2020 Adrien Hopkins + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program 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 Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <https://www.gnu.org/licenses/>. + */ +package sevenUnits.unit; + +import java.util.Optional; +import java.util.Set; + +/** + * An object that can hold one or more names, and possibly a symbol. The name + * and symbol data should be immutable. + * + * @since 2020-09-07 + */ +public interface Nameable { + /** + * @return a {@code NameSymbol} that contains this object's primary name, + * symbol and other names + * @since 2020-09-07 + */ + NameSymbol getNameSymbol(); + + /** + * @return set of alternate names + * @since 2020-09-07 + */ + default Set<String> getOtherNames() { + return this.getNameSymbol().getOtherNames(); + } + + /** + * @return preferred name of object + * @since 2020-09-07 + */ + default Optional<String> getPrimaryName() { + return this.getNameSymbol().getPrimaryName(); + } + + /** + * @return short symbol representing object + * @since 2020-09-07 + */ + default Optional<String> getSymbol() { + return this.getNameSymbol().getSymbol(); + } +} |