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

📄 tagindex.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.index;import net.sourceforge.pebble.domain.Blog;import net.sourceforge.pebble.domain.BlogEntry;import net.sourceforge.pebble.domain.Tag;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import java.io.*;import java.util.*;/** * Represents the tag index for a blog. * * @author    Simon Brown */public class TagIndex {  private static final Log log = LogFactory.getLog(TagIndex.class);  private Blog blog;  /** the map containing the tags */  private Map<String,IndexedTag> tags = new HashMap<String,IndexedTag>();  /** a view onto the map, ordered by tag name */  private List<Tag> orderedTags = new ArrayList<Tag>();  public TagIndex(Blog blog) {    this.blog = blog;    readIndex();    recalculateTagRankings();  }  /**   * Clears the index.   */  public void clear() {    tags = new HashMap<String,IndexedTag>();    writeIndex();  }  /**   * Indexes one or more blog entries.   *   * @param blogEntries   a List of BlogEntry instances   */  public synchronized void index(List<BlogEntry> blogEntries) {    for (BlogEntry blogEntry : blogEntries) {      if (blogEntry.isPublished()) {        for (Tag tag : blogEntry.getAllTags()) {          IndexedTag t = getTag(tag.getName());          t.addBlogEntry(blogEntry.getId());        }      }    }    writeIndex();    recalculateTagRankings();  }  /**   * Indexes a single blog entry.   *   * @param blogEntry   a BlogEntry instance   */  public synchronized void index(BlogEntry blogEntry) {    if (blogEntry.isPublished()) {      for (Tag tag : blogEntry.getAllTags()) {        IndexedTag t = getTag(tag.getName());        t.addBlogEntry(blogEntry.getId());      }      writeIndex();      recalculateTagRankings();    }  }  /**   * Unindexes a single blog entry.   *   * @param blogEntry   a BlogEntry instance   */  public synchronized void unindex(BlogEntry blogEntry) {    for (Tag tag : tags.values()) {      IndexedTag t = getTag(tag.getName());      t.removeBlogEntry(blogEntry.getId());    }    writeIndex();    recalculateTagRankings();  }  /**   * Helper method to load the index.   */  private void readIndex() {    File indexFile = new File(blog.getIndexesDirectory(), "tags.index");    if (indexFile.exists()) {      try {        BufferedReader reader = new BufferedReader(new FileReader(indexFile));        String indexEntry = reader.readLine();        while (indexEntry != null) {          String[] tuple = indexEntry.split("=");          IndexedTag tag = getTag(tuple[0]);          if (tuple.length > 1 && tuple[1] != null) {            String[] blogEntries = tuple[1].split(",");            for (String blogEntry : blogEntries) {              tag.addBlogEntry(blogEntry);            }          }          indexEntry = reader.readLine();        }        reader.close();      } catch (Exception e) {        log.error("Error while reading index", e);      }    }  }  /**   * Helper method to write out the index to disk.   */  private void writeIndex() {    try {      File indexFile = new File(blog.getIndexesDirectory(), "tags.index");      BufferedWriter writer = new BufferedWriter(new FileWriter(indexFile));      for (IndexedTag tag : tags.values()) {        writer.write(tag.getName());        writer.write("=");        for (String blogEntry : tag.getBlogEntries()) {          writer.write(blogEntry);          writer.write(",");        }        writer.newLine();      }      writer.flush();      writer.close();    } catch (Exception e) {      log.error("Error while writing index", e);    }  }  /**   * Gets a tag from the index, creating it if necessary.   *   * @param name    the tag as a String   * @return    a Tag instance   */  synchronized IndexedTag getTag(String name) {    String encodedName = Tag.encode(name);    IndexedTag tag = tags.get(encodedName);    if (tag == null) {      tag = new IndexedTag(name, blog);      tags.put(encodedName, tag);    }    return tag;  }  private synchronized void recalculateTagRankings() {    if (tags.size() > 0) {      // find the maximum      int maxBlogEntries = 0;      for (IndexedTag tag : tags.values()) {        if (tag.getNumberOfBlogEntries() > maxBlogEntries) {          maxBlogEntries = tag.getNumberOfBlogEntries();        }      }      int[] thresholds = new int[10];      for (int i = 0; i < 10; i++) {        thresholds[i] = (int)Math.round((maxBlogEntries/10.0) * (i+1));      }      orderedTags = new ArrayList<Tag>();      // now rank the tags      for (IndexedTag tag : tags.values()) {        tag.calculateRank(thresholds);        if (tag.getNumberOfBlogEntries() > 0) {          orderedTags.add(tag);        }      }      Collections.sort(orderedTags);    }  }  /**   * Gets the list of tags associated with this blog.   */  public List<Tag> getTags() {    return new ArrayList<Tag>(orderedTags);  }  /**   * Gets the blog entries for a given tag.   *   * @param tag   a tag   * @return  a List of blog entry IDs   */  public List<String> getRecentBlogEntries(Tag tag) {    return new ArrayList<String>(getTag(tag.getName()).getBlogEntries());  }}

⌨️ 快捷键说明

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