diff options
author | Adrien Hopkins <ahopk127@my.yorku.ca> | 2021-08-26 15:18:30 -0400 |
---|---|---|
committer | Adrien Hopkins <ahopk127@my.yorku.ca> | 2021-08-26 15:18:30 -0400 |
commit | c4ae6887c32ee8d2e9e8853ffd12721d4db2fd3b (patch) | |
tree | b51679f692e90292901669d2c1bccad347c25434 /src/main/java/sevenUnits/unit/Nameable.java | |
parent | 360b4261ebb9b65dcf91a6e49c5d23784e592945 (diff) | |
parent | 54e481cdb7115b236bcddb86b785d88dcc757c39 (diff) |
Merge branch 'develop'
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(); + } +} |