X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fdemoscenemusic%2Fdata%2FDefaultArtist.java;h=151aeca9f54c7d4d0e9e7827bac14b1d6c90afb2;hb=9eee0f4f619731e5f8b79396d2476090d328be6b;hp=d876169574bd44ee2c7cbd0a3d3852ac6a9286be;hpb=10561cf7c1b437433d58eaa13e32c3ee6156fa76;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 d876169..151aeca 100644 --- a/src/main/java/net/pterodactylus/demoscenemusic/data/DefaultArtist.java +++ b/src/main/java/net/pterodactylus/demoscenemusic/data/DefaultArtist.java @@ -18,51 +18,112 @@ 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); } - public String name() { - return value("name", String.class).get(); + // + // ARTIST METHODS + // + + /** + * {@inheritDoc} + */ + @Override + public String getName() { + return getValue("name", String.class).get(); } - public Artist name(String name) { - value("name", String.class).set(name); + /** + * {@inheritDoc} + */ + @Override + public Artist setName(String name) { + getValue("name", String.class).set(name); return this; } /** * {@inheritDoc} */ + @Override @SuppressWarnings("unchecked") - public Collection groups() { - return value("groups", Collection.class).get(); + public Collection getGroups() { + return getValue("groups", Collection.class).get(); } /** * {@inheritDoc} */ - public Artist groups(Collection groups) { - value("groups", Collection.class).set(groups); + @Override + public Artist setGroups(Collection groups) { + getValue("groups", Collection.class).set(groups); return this; } - public Collection tracks() { - return value("tracks", Collection.class).get(); + /** + * {@inheritDoc} + */ + @Override + @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()); + } + }