X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=data%2FMetaData.java;h=c969ec9366f5c7d7e45a1ae5e3701b6b4a521020;hb=HEAD;hp=2e34ef98ad27bda10ff34a009fa3d3d314aaf6b2;hpb=e992c260c059c53c4aabc980db85efd58f190205;p=nikiroo-utils.git diff --git a/data/MetaData.java b/data/MetaData.java deleted file mode 100644 index 2e34ef9..0000000 --- a/data/MetaData.java +++ /dev/null @@ -1,511 +0,0 @@ -package be.nikiroo.fanfix.data; - -import java.io.Serializable; -import java.util.ArrayList; -import java.util.List; - -import be.nikiroo.utils.Image; -import be.nikiroo.utils.StringUtils; - -/** - * The meta data associated to a {@link Story} object. - *
- * Note that some earlier version of the program did not save the resume as an - * external file; for those stories, the resume is not fetched until the story - * is. - *
- * The cover is never fetched until the story is.
- *
- * @author niki
- */
-public class MetaData implements Cloneable, Comparable
- * This can be NULL if we don't have a resume for this {@link Story}.
- *
- * Note that some earlier version of the program did not save the resume as
- * an external file; for those stories, the resume is not fetched until the
- * story is.
- *
- * @return the resume
- */
- public Chapter getResume() {
- return resume;
- }
-
- /**
- * The story resume (a.k.a. description).
- *
- * Note that some earlier version of the program did not save the resume as
- * an external file; for those stories, the resume is not fetched until the
- * story is.
- *
- * @param resume
- * the resume to set
- */
- public void setResume(Chapter resume) {
- this.resume = resume;
- }
-
- /**
- * The cover image of the story if any (can be NULL).
- *
- * The cover is not fetched until the story is.
- *
- * @return the cover
- */
- public Image getCover() {
- return cover;
- }
-
- /**
- * The cover image of the story if any (can be NULL).
- *
- * The cover is not fetched until the story is.
- *
- * @param cover
- * the cover to set
- */
- public void setCover(Image cover) {
- this.cover = cover;
- }
-
- /**
- * The subject of the story (or instance, if it is a fanfiction, what is the
- * original work; if it is a technical text, what is the technical
- * subject...).
- *
- * @return the subject
- */
- public String getSubject() {
- return subject;
- }
-
- /**
- * The subject of the story (for instance, if it is a fanfiction, what is
- * the original work; if it is a technical text, what is the technical
- * subject...).
- *
- * @param subject
- * the subject to set
- */
- public void setSubject(String subject) {
- this.subject = subject;
- }
-
- /**
- * The source of this story (which online library it was downloaded from).
- *
- * @return the source
- */
- public String getSource() {
- return source;
- }
-
- /**
- * The source of this story (which online library it was downloaded from).
- *
- * @param source
- * the source to set
- */
- public void setSource(String source) {
- this.source = source;
- }
-
- /**
- * The original URL from which this {@link Story} was imported.
- *
- * @return the url
- */
- public String getUrl() {
- return url;
- }
-
- /**
- * The original URL from which this {@link Story} was imported.
- *
- * @param url
- * the new url to set
- */
- public void setUrl(String url) {
- this.url = url;
- }
-
- /**
- * A unique value representing the story (it is often a URL).
- *
- * @return the uuid
- */
- public String getUuid() {
- return uuid;
- }
-
- /**
- * A unique value representing the story (it is often a URL).
- *
- * @param uuid
- * the uuid to set
- */
- public void setUuid(String uuid) {
- this.uuid = uuid;
- }
-
- /**
- * A unique value representing the story in the local library.
- *
- * @return the luid
- */
- public String getLuid() {
- return luid;
- }
-
- /**
- * A unique value representing the story in the local library.
- *
- * @param luid
- * the luid to set
- */
- public void setLuid(String luid) {
- this.luid = luid;
- }
-
- /**
- * The 2-letter code language of this story.
- *
- * @return the lang
- */
- public String getLang() {
- return lang;
- }
-
- /**
- * The 2-letter code language of this story.
- *
- * @param lang
- * the lang to set
- */
- public void setLang(String lang) {
- this.lang = lang;
- }
-
- /**
- * The story publisher (other the same as the source).
- *
- * @return the publisher
- */
- public String getPublisher() {
- return publisher;
- }
-
- /**
- * The story publisher (other the same as the source).
- *
- * @param publisher
- * the publisher to set
- */
- public void setPublisher(String publisher) {
- this.publisher = publisher;
- }
-
- /**
- * The output type this {@link Story} is in.
- *
- * @return the type the type
- */
- public String getType() {
- return type;
- }
-
- /**
- * The output type this {@link Story} is in.
- *
- * @param type
- * the new type to set
- */
- public void setType(String type) {
- this.type = type;
- }
-
- /**
- * Document catering mostly to image files.
- *
- * @return the imageDocument state
- */
- public boolean isImageDocument() {
- return imageDocument;
- }
-
- /**
- * Document catering mostly to image files.
- *
- * @param imageDocument
- * the imageDocument state to set
- */
- public void setImageDocument(boolean imageDocument) {
- this.imageDocument = imageDocument;
- }
-
- /**
- * The number of words in the related {@link Story}.
- *
- * @return the number of words
- */
- public long getWords() {
- return words;
- }
-
- /**
- * The number of words in the related {@link Story}.
- *
- * @param words
- * the number of words to set
- */
- public void setWords(long words) {
- this.words = words;
- }
-
- /**
- * The (Fanfix) {@link Story} creation date.
- *
- * @return the creationDate
- */
- public String getCreationDate() {
- return creationDate;
- }
-
- /**
- * The (Fanfix) {@link Story} creation date.
- *
- * @param creationDate
- * the creationDate to set
- */
- public void setCreationDate(String creationDate) {
- this.creationDate = creationDate;
- }
-
- /**
- * The cover in this {@link MetaData} object is "fake", in the sens that it
- * comes from the actual content images.
- *
- * @return TRUE for a fake cover
- */
- public boolean isFakeCover() {
- return fakeCover;
- }
-
- /**
- * The cover in this {@link MetaData} object is "fake", in the sens that it
- * comes from the actual content images
- *
- * @param fakeCover
- * TRUE for a fake cover
- */
- public void setFakeCover(boolean fakeCover) {
- this.fakeCover = fakeCover;
- }
-
- @Override
- public int compareTo(MetaData o) {
- if (o == null) {
- return 1;
- }
-
- String id = (getTitle() == null ? "" : getTitle())
- + (getUuid() == null ? "" : getUuid())
- + (getLuid() == null ? "" : getLuid());
- String oId = (getTitle() == null ? "" : o.getTitle())
- + (getUuid() == null ? "" : o.getUuid())
- + (o.getLuid() == null ? "" : o.getLuid());
-
- return id.compareToIgnoreCase(oId);
- }
-
- @Override
- public boolean equals(Object obj) {
- if (!(obj instanceof MetaData)) {
- return false;
- }
-
- return compareTo((MetaData) obj) == 0;
- }
-
- @Override
- public int hashCode() {
- String uuid = getUuid();
- if (uuid == null) {
- uuid = "" + title + author + source;
- }
-
- return uuid.hashCode();
- }
-
- @Override
- public MetaData clone() {
- MetaData meta = null;
- try {
- meta = (MetaData) super.clone();
- } catch (CloneNotSupportedException e) {
- // Did the clones rebel?
- System.err.println(e);
- }
-
- if (tags != null) {
- meta.tags = new ArrayList
- * This is not efficient, nor intended to be.
- */
- @Override
- public String toString() {
- String title = "";
- if (getTitle() != null) {
- title = getTitle();
- }
-
- StringBuilder tags = new StringBuilder();
- if (getTags() != null) {
- for (String tag : getTags()) {
- if (tags.length() > 0) {
- tags.append(", ");
- }
- tags.append(tag);
- }
- }
-
- String resume = "";
- if (getResume() != null) {
- for (Paragraph para : getResume()) {
- resume += "\n\t";
- resume += para.toString().substring(0,
- Math.min(para.toString().length(), 120));
- }
- resume += "\n";
- }
-
- String cover = "none";
- if (getCover() != null) {
- cover = StringUtils.formatNumber(getCover().getSize())
- + "bytes";
- }
-
- return String.format(
- "Meta %s:\n\tTitle: [%s]\n\tAuthor: [%s]\n\tDate: [%s]\n\tTags: [%s]\n\tWord count: [%s]"
- + "\n\tResume: [%s]\n\tCover: [%s]",
- luid, title, getAuthor(), getDate(), tags.toString(),
- "" + words, resume, cover);
- }
-}