X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fdemoscenemusic%2Fdata%2FDefaultArtist.java;h=151aeca9f54c7d4d0e9e7827bac14b1d6c90afb2;hb=9eee0f4f619731e5f8b79396d2476090d328be6b;hp=c739275595f450df238e316778486357d9bb15fa;hpb=f910bfec8c988bc9baf7e5e3a05b19237e899cec;p=demoscenemusic.git diff --git a/src/main/java/net/pterodactylus/demoscenemusic/data/DefaultArtist.java b/src/main/java/net/pterodactylus/demoscenemusic/data/DefaultArtist.java index c739275..151aeca 100644 --- a/src/main/java/net/pterodactylus/demoscenemusic/data/DefaultArtist.java +++ b/src/main/java/net/pterodactylus/demoscenemusic/data/DefaultArtist.java @@ -18,26 +18,52 @@ package net.pterodactylus.demoscenemusic.data; import java.util.Collection; +import java.util.Comparator; /** - * TODO + * Default implementation for an artist data container. * * @author David ‘Bombe’ Roden */ public class DefaultArtist extends DefaultBase implements Artist { + /** Comparator that sorts artists by name. */ + public static final Comparator NAME_COMPARATOR = new Comparator() { + + @Override + public int compare(Artist leftArtist, Artist rightArtist) { + return leftArtist.getName().compareToIgnoreCase(rightArtist.getName()); + } + }; + + /** + * Creates a new artist data container. + * + * @param id + * The ID of the artist + */ public DefaultArtist(String id) { super(id); } + // + // ARTIST METHODS + // + + /** + * {@inheritDoc} + */ @Override - public String name() { - return value("name", String.class).get(); + public String getName() { + return getValue("name", String.class).get(); } + /** + * {@inheritDoc} + */ @Override - public Artist name(String name) { - value("name", String.class).set(name); + public Artist setName(String name) { + getValue("name", String.class).set(name); return this; } @@ -46,28 +72,58 @@ public class DefaultArtist extends DefaultBase implements Artist { */ @Override @SuppressWarnings("unchecked") - public Collection groups() { - return value("groups", Collection.class).get(); + public Collection getGroups() { + return getValue("groups", Collection.class).get(); } /** * {@inheritDoc} */ @Override - public Artist groups(Collection groups) { - value("groups", Collection.class).set(groups); + public Artist setGroups(Collection groups) { + getValue("groups", Collection.class).set(groups); return this; } + /** + * {@inheritDoc} + */ @Override - public Collection tracks() { - return value("tracks", Collection.class).get(); + @SuppressWarnings({ "unchecked" }) + public Collection getTracks() { + return getValue("tracks", Collection.class).get(); } + /** + * {@inheritDoc} + */ @Override - public Artist tracks(Collection tracks) { - value("tracks", Collection.class).set(tracks); + public Artist setTracks(Collection tracks) { + getValue("tracks", Collection.class).set(tracks); return this; } + // + // OBJECT METHODS + // + + /** + * {@inheritDoc} + */ + @Override + public int hashCode() { + return getId().hashCode(); + } + + /** + * {@inheritDoc} + */ + @Override + public boolean equals(Object object) { + if (!(object instanceof Artist)) { + return false; + } + return ((Artist) object).getId().equals(getId()); + } + }