//# 0 errors, 128 messages
//#
/*
    //#disableresponselistener.java:1:1: class: net.sourceforge.pebble.event.response.DisableResponseListener
 * 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.event.response;

import net.sourceforge.pebble.domain.Response;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
 * Deletes comments and TrackBacks that are left, effectively disabling the
 * ability for readers for leave responses.
 *
 * @author Simon Brown
 */
public class DisableResponseListener extends BlogEntryResponseListenerSupport {
    //#disableresponselistener.java:44: method: void net.sourceforge.pebble.event.response.DisableResponseListener.net.sourceforge.pebble.event.response.DisableResponseListener()
    //#input(void net.sourceforge.pebble.event.response.DisableResponseListener()): this
    //#disableresponselistener.java:44: end of method: void net.sourceforge.pebble.event.response.DisableResponseListener.net.sourceforge.pebble.event.response.DisableResponseListener()

  /** the log used by this class */
  private static final Log log = LogFactory.getLog(DisableResponseListener.class);
    //#disableresponselistener.java:47: method: net.sourceforge.pebble.event.response.DisableResponseListener.net.sourceforge.pebble.event.response.DisableResponseListener__static_init
    //#disableresponselistener.java:47: Warning: method not available
    //#    -- call on Log org.apache.commons.logging.LogFactory:getLog(Class)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.event.response.DisableResponseListener
    //#    method: net.sourceforge.pebble.event.response.DisableResponseListener__static_init
    //#    unanalyzed callee: Log org.apache.commons.logging.LogFactory:getLog(Class)
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Descendant_Table[net/sourceforge/pebble/event/response/DisableResponseListener]
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.blogEntryResponseAdded(Lnet/sourceforge/pebble/domain/Response;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.blogEntryResponseApproved(Lnet/sourceforge/pebble/domain/Response;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.blogEntryResponseRejected(Lnet/sourceforge/pebble/domain/Response;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.blogEntryResponseRemoved(Lnet/sourceforge/pebble/domain/Response;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.commentAdded(Lnet/sourceforge/pebble/api/event/comment/CommentEvent;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.commentApproved(Lnet/sourceforge/pebble/api/event/comment/CommentEvent;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.commentRejected(Lnet/sourceforge/pebble/api/event/comment/CommentEvent;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.commentRemoved(Lnet/sourceforge/pebble/api/event/comment/CommentEvent;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.trackBackAdded(Lnet/sourceforge/pebble/api/event/trackback/TrackBackEvent;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.trackBackApproved(Lnet/sourceforge/pebble/api/event/trackback/TrackBackEvent;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.trackBackRejected(Lnet/sourceforge/pebble/api/event/trackback/TrackBackEvent;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.trackBackRemoved(Lnet/sourceforge/pebble/api/event/trackback/TrackBackEvent;)V
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): log
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): net/sourceforge/pebble/api/event/comment/CommentListener.__Descendant_Table[net/sourceforge/pebble/event/response/DisableResponseListener]
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): net/sourceforge/pebble/api/event/trackback/TrackBackListener.__Descendant_Table[net/sourceforge/pebble/event/response/DisableResponseListener]
    //#output(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.__Descendant_Table[net/sourceforge/pebble/event/response/DisableResponseListener]
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Descendant_Table[net/sourceforge/pebble/event/response/DisableResponseListener] == &__Dispatch_Table
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): net/sourceforge/pebble/api/event/comment/CommentListener.__Descendant_Table[net/sourceforge/pebble/event/response/DisableResponseListener] == &__Dispatch_Table
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): net/sourceforge/pebble/api/event/trackback/TrackBackListener.__Descendant_Table[net/sourceforge/pebble/event/response/DisableResponseListener] == &__Dispatch_Table
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.__Descendant_Table[net/sourceforge/pebble/event/response/DisableResponseListener] == &__Dispatch_Table
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.blogEntryResponseAdded(Lnet/sourceforge/pebble/domain/Response;)V == &blogEntryResponseAdded
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.blogEntryResponseApproved(Lnet/sourceforge/pebble/domain/Response;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.blogEntryResponseApproved
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.blogEntryResponseRejected(Lnet/sourceforge/pebble/domain/Response;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.blogEntryResponseRejected
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.blogEntryResponseRemoved(Lnet/sourceforge/pebble/domain/Response;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.blogEntryResponseRemoved
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.commentAdded(Lnet/sourceforge/pebble/api/event/comment/CommentEvent;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.commentAdded
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.commentApproved(Lnet/sourceforge/pebble/api/event/comment/CommentEvent;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.commentApproved
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.commentRejected(Lnet/sourceforge/pebble/api/event/comment/CommentEvent;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.commentRejected
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.commentRemoved(Lnet/sourceforge/pebble/api/event/comment/CommentEvent;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.commentRemoved
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.trackBackAdded(Lnet/sourceforge/pebble/api/event/trackback/TrackBackEvent;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.trackBackAdded
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.trackBackApproved(Lnet/sourceforge/pebble/api/event/trackback/TrackBackEvent;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.trackBackApproved
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.trackBackRejected(Lnet/sourceforge/pebble/api/event/trackback/TrackBackEvent;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.trackBackRejected
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): __Dispatch_Table.trackBackRemoved(Lnet/sourceforge/pebble/api/event/trackback/TrackBackEvent;)V == &net/sourceforge/pebble/event/response/BlogEntryResponseListenerSupport.trackBackRemoved
    //#post(net.sourceforge.pebble.event.response.DisableResponseListener__static_init): init'ed(log)
    //#disableresponselistener.java:47: end of method: net.sourceforge.pebble.event.response.DisableResponseListener.net.sourceforge.pebble.event.response.DisableResponseListener__static_init

  /**
   * Called when a comment or TrackBack has been added.
   *
   * @param response a Response
   */
  protected void blogEntryResponseAdded(Response response) {
      log.info(response.getTitle() + " deleted");
    //#disableresponselistener.java:55: method: void net.sourceforge.pebble.event.response.DisableResponseListener.blogEntryResponseAdded(Response)
    //#disableresponselistener.java:55: Warning: method not available
    //#    -- call on void org.apache.commons.logging.Log:info(Object)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.event.response.DisableResponseListener
    //#    method: void blogEntryResponseAdded(Response)
    //#    unanalyzed callee: void org.apache.commons.logging.Log:info(Object)
    //#disableresponselistener.java:55: Warning: suspicious precondition
    //#    the precondition for response.__Tag is not a contiguous range of values
    //#    severity: SUPPRESSED
    //#    class: net.sourceforge.pebble.event.response.DisableResponseListener
    //#    method: void blogEntryResponseAdded(Response)
    //#    suspicious precondition index: [3]
    //#input(void blogEntryResponseAdded(Response)): log
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Descendant_Table[net/sourceforge/pebble/domain/BlogEntry]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Descendant_Table[others]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.addEvent(Lnet/sourceforge/pebble/api/event/PebbleEvent;)V
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.areEventsEnabled()Z
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.getComment(J)Lnet/sourceforge/pebble/domain/Comment;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.getComments()Ljava/util/List;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.getTrackBack(J)Lnet/sourceforge/pebble/domain/TrackBack;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.getTrackBacks()Ljava/util/List;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.removeComment(J)V
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.removeResponse(Lnet/sourceforge/pebble/domain/Response;)V
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.__Dispatch_Table.removeTrackBack(J)V
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/BlogEntry.log
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Descendant_Table[net/sourceforge/pebble/domain/Comment]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Descendant_Table[others]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Dispatch_Table.areEventsEnabled()Z
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Dispatch_Table.getBlogEntry()Lnet/sourceforge/pebble/domain/BlogEntry;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Dispatch_Table.getComments()Ljava/util/List;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Dispatch_Table.getId()J
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Dispatch_Table.getParent()Lnet/sourceforge/pebble/domain/Comment;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Dispatch_Table.getTitle()Ljava/lang/String;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Dispatch_Table.removeComment(Lnet/sourceforge/pebble/domain/Comment;)V
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Comment.__Dispatch_Table.setParent(Lnet/sourceforge/pebble/domain/Comment;)V
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Response.__Descendant_Table[net/sourceforge/pebble/domain/Comment]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Response.__Descendant_Table[net/sourceforge/pebble/domain/Response]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Response.__Descendant_Table[net/sourceforge/pebble/domain/TrackBack]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Response.__Descendant_Table[others]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Response.__Dispatch_Table.getBlogEntry()Lnet/sourceforge/pebble/domain/BlogEntry;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Response.__Dispatch_Table.getId()J
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/Response.__Dispatch_Table.getTitle()Ljava/lang/String;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/TrackBack.__Descendant_Table[net/sourceforge/pebble/domain/TrackBack]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/TrackBack.__Descendant_Table[others]
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/TrackBack.__Dispatch_Table.getBlogEntry()Lnet/sourceforge/pebble/domain/BlogEntry;
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/TrackBack.__Dispatch_Table.getId()J
    //#input(void blogEntryResponseAdded(Response)): net/sourceforge/pebble/domain/TrackBack.__Dispatch_Table.getTitle()Ljava/lang/String;
    //#input(void blogEntryResponseAdded(Response)): response
    //#input(void blogEntryResponseAdded(Response)): response.__Tag
    //#input(void blogEntryResponseAdded(Response)): response.blogEntry
    //#input(void blogEntryResponseAdded(Response)): response.blogEntry.__Tag
    //#input(void blogEntryResponseAdded(Response)): response.blogEntry.comments
    //#input(void blogEntryResponseAdded(Response)): response.blogEntry.events
    //#input(void blogEntryResponseAdded(Response)): response.blogEntry.eventsEnabled
    //#input(void blogEntryResponseAdded(Response)): response.blogEntry.trackBacks
    //#input(void blogEntryResponseAdded(Response)): response.date
    //#input(void blogEntryResponseAdded(Response)): response.title
    //#input(void blogEntryResponseAdded(Response)): response.url
    //#pre[2] (void blogEntryResponseAdded(Response)): response != null
    //#pre[3] (void blogEntryResponseAdded(Response)): response.__Tag in {net/sourceforge/pebble/domain/Comment, net/sourceforge/pebble/domain/Response, net/sourceforge/pebble/domain/TrackBack}
    //#pre[4] (void blogEntryResponseAdded(Response)): response.blogEntry != null
    //#pre[11] (void blogEntryResponseAdded(Response)): init'ed(response.title)
    //#pre[1] (void blogEntryResponseAdded(Response)): (soft) net/sourceforge/pebble/domain/BlogEntry.log != null
    //#pre[5] (void blogEntryResponseAdded(Response)): (soft) response.blogEntry.__Tag == net/sourceforge/pebble/domain/BlogEntry
    //#pre[6] (void blogEntryResponseAdded(Response)): (soft) response.blogEntry.comments != null
    //#pre[7] (void blogEntryResponseAdded(Response)): (soft) response.blogEntry.events != null
    //#pre[8] (void blogEntryResponseAdded(Response)): (soft) init'ed(response.blogEntry.eventsEnabled)
    //#pre[9] (void blogEntryResponseAdded(Response)): (soft) response.blogEntry.trackBacks != null
    //#pre[10] (void blogEntryResponseAdded(Response)): (soft) response.date != null
    //#pre[12] (void blogEntryResponseAdded(Response)): (soft) init'ed(response.url)
    //#presumption(void blogEntryResponseAdded(Response)): org.apache.commons.logging.LogFactory:getLog(...)@47 != null
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:getBlogEntry
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.lang.String:length
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:areEventsEnabled
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:net.sourceforge.pebble.api.event.PebbleEvent
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.EventObject
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:net.sourceforge.pebble.domain.BlogEntry:addEvent
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.Iterator:hasNext
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.Iterator:next
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.ArrayList
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.Date:getTime
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:getComment
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.List:contains
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.List:add
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:getTrackBack
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.List:remove
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.lang.StringBuilder
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.lang.StringBuilder:append
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.lang.StringBuilder:toString
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:org.apache.commons.logging.Log:warn
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.List:iterator
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:removeComment
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:getComments
    //#unanalyzed(void blogEntryResponseAdded(Response)): Effects-of-calling:java.util.List:addAll
      response.getBlogEntry().removeResponse(response);
  }
    //#disableresponselistener.java:57: end of method: void net.sourceforge.pebble.event.response.DisableResponseListener.blogEntryResponseAdded(Response)

}
    //#disableresponselistener.java:: end of class: net.sourceforge.pebble.event.response.DisableResponseListener
