⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tag.java

📁 pebble-blog 博客源码博客源码博客源码
💻 JAVA
字号:
/* * Copyright (c) 2003-2006, Simon Brown * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * *   - Redistributions of source code must retain the above copyright *     notice, this list of conditions and the following disclaimer. * *   - Redistributions in binary form must reproduce the above copyright *     notice, this list of conditions and the following disclaimer in *     the documentation and/or other materials provided with the *     distribution. * *   - Neither the name of Pebble nor the names of its contributors may *     be used to endorse or promote products derived from this software *     without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */package net.sourceforge.pebble.domain;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import java.util.*;/** * Represents a tag. * * @author    Simon Brown */public class Tag implements Permalinkable, Comparable {  /** the log used by this class */  private static final Log log = LogFactory.getLog(Tag.class);  /** the owning blog */  private Blog blog;  /** the name of the tag */  private String name = "";  /** the rank for this tag */  protected int rank;  /**   * Creates a new tag with the specified properties.   *   * @param name    the name   * @param blog    a Blog instance   */  public Tag(String name, Blog blog) {    setName(name);    this.blog = blog;  }  /**   * Gets the name of this tag.   *   * @return    the name as a String   */  public String getName() {    return name;  }  /**   * Sets the name of this tag.   *   * @param name    the new tag name   */  public void setName(String name) {    this.name = Tag.encode(name);  }  /**   * Gets the permalink for this object.   *   * @return  a URL as a String   */  public String getPermalink() {    return blog.getUrl() + "tags/" + name + "/";  }  /**   * Gets the hashcode of this object.   *   * @return  the hashcode as an int   */  public int hashCode() {    return name.hashCode();  }  /**   * Determines whether the specified object is equal to this one.   *   * @param o   the object to compare against   * @return    true if Object o represents the same tag, false otherwise   */  public boolean equals(Object o) {    if (!(o instanceof Tag)) {      return false;    }    Tag tag = (Tag)o;    return tag.getName().equals(name);  }  /**   * Compares this object with the specified object for order.  Returns a   * negative integer, zero, or a positive integer as this object is less   * than, equal to, or greater than the specified object.<p>   *   * @param   o the Object to be compared.   * @return  a negative integer, zero, or a positive integer as this object   *		is less than, equal to, or greater than the specified object.   *   * @throws ClassCastException if the specified object's type prevents it   *         from being compared to this Object.   */  public int compareTo(Object o) {    Tag tag = (Tag)o;    return getName().compareTo(tag.getName());  }  /**   * Returns a String representation of this object.   *   * @return  a String   */  public String toString() {    return this.name;  }  /**   * Gets the rank for this tag.   *   * @return  an int between 1 and 10;   */  public int getRank() {    return this.rank;  }  /**   * Given a string containing whitespace separated tags, this method returns a   * List containing the tags.   *   * @param tags    a whitespace separated list of tags   * @return        a List of Tag instances   */  public static List<Tag> parse(Blog blog, String tags) {    List list = new ArrayList();    if (tags != null && tags.trim().length() > 0) {      String s[] = tags.trim().split(" ");      for (int i = 0; i < s.length; i++) {        Tag tag = new Tag(s[i].trim(), blog);        if (!list.contains(tag)) {          list.add(tag);        }      }    }    return list;  }  /**   * Encodes a tag.   *   * @param tag   a String   */  public static String encode(String tag) {    if (tag == null) {      return "";    } else {      return tag.trim().replaceAll(" ", "").toLowerCase();    }  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -