Clover Coverage Report - Pebble 2.5-SNAPSHOT
Coverage timestamp: Sat Jun 12 2010 09:39:29 EST
../../../../img/srcFileCovDistChart10.png 0% of files have more coverage
13   110   8   2,17
4   32   0,62   6
6     1,33  
1    
This report was generated with an evaluation server license. Purchase Clover or configure your license.
 
  SearchIndexListener       Line # 43 13 0% 8 0 100% 1.0
 
  (180)
 
1    /*
2    * Copyright (c) 2003-2006, Simon Brown
3    * All rights reserved.
4    *
5    * Redistribution and use in source and binary forms, with or without
6    * modification, are permitted provided that the following conditions are met:
7    *
8    * - Redistributions of source code must retain the above copyright
9    * notice, this list of conditions and the following disclaimer.
10    *
11    * - Redistributions in binary form must reproduce the above copyright
12    * notice, this list of conditions and the following disclaimer in
13    * the documentation and/or other materials provided with the
14    * distribution.
15    *
16    * - Neither the name of Pebble nor the names of its contributors may
17    * be used to endorse or promote products derived from this software
18    * without specific prior written permission.
19    *
20    * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21    * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22    * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23    * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
24    * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25    * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26    * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27    * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28    * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29    * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30    * POSSIBILITY OF SUCH DAMAGE.
31    */
32    package net.sourceforge.pebble.index;
33   
34    import net.sourceforge.pebble.domain.BlogEntry;
35    import net.sourceforge.pebble.api.event.blogentry.BlogEntryEvent;
36    import net.sourceforge.pebble.api.event.blogentry.BlogEntryListener;
37   
38    /**
39    * Listens to blog entry events and keeps the search index up to date.
40    *
41    * @author Simon Brown
42    */
 
43    public class SearchIndexListener implements BlogEntryListener {
44   
45    /**
46    * Called when a blog entry has been added.
47    *
48    * @param event a BlogEntryEvent instance
49    */
 
50  276 toggle public void blogEntryAdded(BlogEntryEvent event) {
51  276 BlogEntry blogEntry = event.getBlogEntry();
52   
53  276 if (blogEntry.isPublished()) {
54  78 updateSearchIndex(blogEntry);
55    }
56    }
57   
58    /**
59    * Called when a blog entry has been removed.
60    *
61    * @param event a BlogEntryEvent instance
62    */
 
63  18 toggle public void blogEntryRemoved(BlogEntryEvent event) {
64  18 BlogEntry blogEntry = event.getBlogEntry();
65   
66  18 blogEntry.getBlog().getSearchIndex().unindex(blogEntry);
67    }
68   
69    /**
70    * Called when a blog entry has been changed.
71    *
72    * @param event a BlogEntryEvent instance
73    */
 
74  12 toggle public void blogEntryChanged(BlogEntryEvent event) {
75  12 BlogEntry blogEntry = event.getBlogEntry();
76   
77  12 if (blogEntry.isPublished()) {
78  6 updateSearchIndex(blogEntry);
79    }
80    }
81   
82    /**
83    * Called when a blog entry has been published.
84    *
85    * @param event a BlogEntryEvent instance
86    */
 
87  14 toggle public void blogEntryPublished(BlogEntryEvent event) {
88  14 BlogEntry blogEntry = event.getBlogEntry();
89  14 updateSearchIndex(blogEntry);
90    }
91   
92    /**
93    * Called when a blog entry has been unpublished.
94    *
95    * @param event a BlogEntryEvent instance
96    */
 
97  4 toggle public void blogEntryUnpublished(BlogEntryEvent event) {
98  4 BlogEntry blogEntry = event.getBlogEntry();
99   
100  4 blogEntry.getBlog().getSearchIndex().unindex(blogEntry);
101    }
102   
103    /**
104    * Updates the search index to reflect the new/changed/removed blog entry.
105    */
 
106  98 toggle private void updateSearchIndex(BlogEntry blogEntry) {
107  98 blogEntry.getBlog().getSearchIndex().index(blogEntry);
108    }
109   
110    }