From 4b121482f1a8323ea23858e8118934be5d9aa54c Mon Sep 17 00:00:00 2001 From: Paul-Christian Volkmer Date: Fri, 10 Mar 2023 09:24:12 +0100 Subject: Issue #5: Vorschlag für den Aufbau des Projekts * Maven-Projekt direkt im Hauptverzeichnis * Anpassung der Maven-POM-Datei - nicht benötigte Abhängigkeiten entfernt * Gitignore-Datei angelegt --- src/main/java/ATCCodes/AtcCode.java | 51 +++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 src/main/java/ATCCodes/AtcCode.java (limited to 'src/main/java/ATCCodes/AtcCode.java') diff --git a/src/main/java/ATCCodes/AtcCode.java b/src/main/java/ATCCodes/AtcCode.java new file mode 100644 index 0000000..e8bf9f1 --- /dev/null +++ b/src/main/java/ATCCodes/AtcCode.java @@ -0,0 +1,51 @@ +package ATCCodes; + +import java.util.Objects; + +/** + * ATC-Code as used in WHO XML file + * + * @author Paul-Christian Volkmer + * @since 0.1.0 + */ +public class AtcCode implements AgentCode { + + private final String code; + private final String name; + + public AtcCode(String code, String name) { + this.code = code; + this.name = name; + } + + public String getCode() { + return code; + } + + public String getName() { + return name; + } + + public CodeSystem getSystem() { + return CodeSystem.ATC; + } + + @Override + public int compareTo(final AgentCode agentCode) { + return this.name.toLowerCase().compareTo(agentCode.getName().toLowerCase()); + } + + @Override + public boolean equals(final Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) return false; + AgentCode otherAgentCode = (AgentCode) o; + return Objects.equals(code.toLowerCase(), otherAgentCode.getCode().toLowerCase()) + && Objects.equals(name.toLowerCase(), otherAgentCode.getName().toLowerCase()); + } + + @Override + public int hashCode() { + return Objects.hash(code.toLowerCase(), name.toLowerCase()); + } +} \ No newline at end of file -- cgit v1.2.3