//# 1 errors, 475 messages
//#
/*
    //#abstractlogaction.java:1:1: class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#abstractlogaction.java:1:1: method: net.sourceforge.pebble.web.action.AbstractLogAction.net.sourceforge.pebble.web.action.AbstractLogAction__static_init
 * 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.web.action;

import net.sourceforge.pebble.Constants;
import net.sourceforge.pebble.domain.Blog;
import net.sourceforge.pebble.domain.Month;
import net.sourceforge.pebble.domain.Day;
import net.sourceforge.pebble.logging.Log;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.text.SimpleDateFormat;
import java.util.Calendar;

/**
 * Superclass for all log related actions.
 *
 * @author    Simon Brown
 */
public abstract class AbstractLogAction extends SecureAction {
    //#abstractlogaction.java:51: method: void net.sourceforge.pebble.web.action.AbstractLogAction.net.sourceforge.pebble.web.action.AbstractLogAction()
    //#input(void net.sourceforge.pebble.web.action.AbstractLogAction()): this
    //#abstractlogaction.java:51: end of method: void net.sourceforge.pebble.web.action.AbstractLogAction.net.sourceforge.pebble.web.action.AbstractLogAction()

  protected Log getLog(HttpServletRequest request, HttpServletResponse response) throws ServletException {
    Blog blog = (Blog)getModel().get(Constants.BLOG_KEY);
    //#abstractlogaction.java:54: method: Log net.sourceforge.pebble.web.action.AbstractLogAction.getLog(HttpServletRequest, HttpServletResponse)
    //#abstractlogaction.java:54: Warning: suspicious precondition
    //#    the precondition for this.__Tag is not a contiguous range of values
    //#    severity: SUPPRESSED
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    suspicious precondition index: [3]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewCountriesAction]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewLogAction]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewReferersAction]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsAction]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsByHourAction]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsByTypeAction]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewUserAgentsAction]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Descendant_Table[others]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): __Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Descendant_Table[net/sourceforge/pebble/logging/AbstractLogger]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Descendant_Table[net/sourceforge/pebble/logging/CombinedLogFormatLogger]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Descendant_Table[net/sourceforge/pebble/logging/NullLogger]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Descendant_Table[others]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Dispatch_Table.getLog()Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Dispatch_Table.getLog(II)Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Dispatch_Table.getLog(III)Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/CombinedFormatLogEntryFormat.__Descendant_Table[net/sourceforge/pebble/logging/CombinedFormatLogEntryFormat]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/CombinedFormatLogEntryFormat.__Dispatch_Table.parse(Ljava/lang/String;)Lnet/sourceforge/pebble/logging/LogEntry;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/CombinedLogFormatLogger.__Dispatch_Table.getLog()Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/CombinedLogFormatLogger.__Dispatch_Table.getLog(II)Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/CombinedLogFormatLogger.__Dispatch_Table.getLog(III)Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/Log.__Descendant_Table[net/sourceforge/pebble/logging/Log]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/Log.__Descendant_Table[others]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/Log.__Dispatch_Table.getLogEntries()Ljava/util/Collection;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/LogEntry.__Descendant_Table[net/sourceforge/pebble/logging/LogEntry]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/LogEntry.__Dispatch_Table.setAgent(Ljava/lang/String;)V
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/LogEntry.__Dispatch_Table.setBytes(J)V
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/LogEntry.__Dispatch_Table.setDate(Ljava/util/Date;)V
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/LogEntry.__Dispatch_Table.setHost(Ljava/lang/String;)V
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/LogEntry.__Dispatch_Table.setReferer(Ljava/lang/String;)V
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/LogEntry.__Dispatch_Table.setRequest(Ljava/lang/String;)V
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/LogEntry.__Dispatch_Table.setStatusCode(I)V
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/NullLogger.__Dispatch_Table.getLog()Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/NullLogger.__Dispatch_Table.getLog(II)Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/NullLogger.__Dispatch_Table.getLog(III)Lnet/sourceforge/pebble/logging/Log;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewCountriesAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewLogAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewReferersAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewRequestsAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewRequestsByHourAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewRequestsByTypeAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewUserAgentsAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/model/Model.__Descendant_Table[net/sourceforge/pebble/web/model/Model]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/model/Model.__Descendant_Table[others]
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/model/Model.__Dispatch_Table.get(Ljava/lang/String;)Ljava/lang/Object;
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/model/Model.__Dispatch_Table.put(Ljava/lang/String;Ljava/lang/Object;)V
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): request
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): this
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): this.__Tag
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): this.model
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): this.model.__Tag
    //#input(Log getLog(HttpServletRequest, HttpServletResponse)): this.model.data
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new ArrayList(Log#1) num objects
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new ArrayList(getLog#1*) num objects
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new ArrayList(getLog#2*) num objects
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new HashSet(getLog#1*) num objects
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#1*) num objects
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#1*).__Tag
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#1*).blog
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#1*).logEntries
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#2*) num objects
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#2*).__Tag
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#2*).blog
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#2*).logEntries
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#6*) num objects
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#6*).__Tag
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#6*).blog
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#6*).logEntries
    //#output(Log getLog(HttpServletRequest, HttpServletResponse)): return_value
    //#new obj(Log getLog(HttpServletRequest, HttpServletResponse)): new ArrayList(Log#1)
    //#new obj(Log getLog(HttpServletRequest, HttpServletResponse)): new ArrayList(getLog#1*)
    //#new obj(Log getLog(HttpServletRequest, HttpServletResponse)): new ArrayList(getLog#2*)
    //#new obj(Log getLog(HttpServletRequest, HttpServletResponse)): new HashSet(getLog#1*)
    //#new obj(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#1*)
    //#new obj(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#2*)
    //#new obj(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#6*)
    //#pre[1] (Log getLog(HttpServletRequest, HttpServletResponse)): request != null
    //#pre[3] (Log getLog(HttpServletRequest, HttpServletResponse)): this.__Tag in {net/sourceforge/pebble/web/action/AbstractLogAction, net/sourceforge/pebble/web/action/ViewCountriesAction, net/sourceforge/pebble/web/action/ViewLogAction, net/sourceforge/pebble/web/action/ViewReferersAction, net/sourceforge/pebble/web/action/ViewRequestsAction, net/sourceforge/pebble/web/action/ViewRequestsByHourAction, net/sourceforge/pebble/web/action/ViewRequestsByTypeAction, net/sourceforge/pebble/web/action/ViewUserAgentsAction}
    //#pre[4] (Log getLog(HttpServletRequest, HttpServletResponse)): this.model != null
    //#pre[5] (Log getLog(HttpServletRequest, HttpServletResponse)): this.model.__Tag == net/sourceforge/pebble/web/model/Model
    //#pre[6] (Log getLog(HttpServletRequest, HttpServletResponse)): this.model.data != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): java.lang.Integer:parseInt(...)@68 >= -2_147_483_647
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): java.lang.Integer:parseInt(...)@81 >= -2_147_483_647
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): java.util.Calendar:get(...)@73 <= 4_294_967_294
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): java.util.Calendar:get(...)@84 <= 4_294_967_294
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): java.util.HashMap:get(...)@63 != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getBlogForDay(...)@76 != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getBlogForMonth(...)@87 != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getBlogForToday(...)@94 != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getCalendar(...)@60 != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).__Tag@73 in {net/sourceforge/pebble/logging/AbstractLogger, net/sourceforge/pebble/logging/CombinedLogFormatLogger, net/sourceforge/pebble/logging/NullLogger}
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).__Tag@84 in {net/sourceforge/pebble/logging/AbstractLogger, net/sourceforge/pebble/logging/CombinedLogFormatLogger, net/sourceforge/pebble/logging/NullLogger}
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).__Tag@91 in {net/sourceforge/pebble/logging/AbstractLogger, net/sourceforge/pebble/logging/CombinedLogFormatLogger, net/sourceforge/pebble/logging/NullLogger}
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).blog@84 != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...)@73 != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...)@84 != null
    //#presumption(Log getLog(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...)@91 != null
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): return_value != null
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): init'ed(new ArrayList(Log#1) num objects)
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new ArrayList(getLog#1*) num objects <= 1
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new ArrayList(getLog#2*) num objects <= 1
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new HashSet(getLog#1*) num objects <= 1
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#1*) num objects <= 1
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#1*).__Tag == net/sourceforge/pebble/logging/Log
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): init'ed(new Log(getLog#1*).blog)
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#1*).logEntries != null
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#2*) num objects <= 1
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#2*).__Tag == net/sourceforge/pebble/logging/Log
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): (soft) new Log(getLog#2*).blog != null
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#2*).logEntries == &new HashSet(getLog#1*)
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#6*) num objects <= 1
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#6*).__Tag == net/sourceforge/pebble/logging/Log
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): init'ed(new Log(getLog#6*).blog)
    //#post(Log getLog(HttpServletRequest, HttpServletResponse)): new Log(getLog#6*).logEntries != null
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.HashMap:get
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Blog:getCalendar
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Calendar:set
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Calendar:getTime
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.text.SimpleDateFormat:format
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Blog:getLogsDirectory
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.File
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.File:exists
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.FileReader
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.BufferedReader
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.BufferedReader:readLine
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.BufferedReader:close
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.Exception:printStackTrace
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Calendar:getActualMaximum
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Calendar:get
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.HashMap:put
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Blog:getBlogForFirstMonth
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:getPreviousMonth
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:getNextMonth
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:before
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:getDate
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Date:after
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:getBlogForFirstDay
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Day:getPreviousDay
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Day:getNextDay
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Day:before
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Day:getDate
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:getLog
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.ArrayList
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.text.SimpleDateFormat
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Blog:getTimeZone
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.text.SimpleDateFormat:setTimeZone
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Date
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.String:indexOf
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.String:substring
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.String:charAt
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.String:length
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.String:equals
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.text.SimpleDateFormat:parse
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.Integer:parseInt
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.Long:parseLong
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.List:add
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.HashSet
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Collections:unmodifiableCollection
    //#unanalyzed(Log getLog(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Collection:addAll
    //#test_vector(Log getLog(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@64: {0}, {1..4_294_967_295}
    //#test_vector(Log getLog(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@65: {0}, {1..4_294_967_295}
    //#test_vector(Log getLog(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@66: {0}, {1..4_294_967_295}
    //#test_vector(Log getLog(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@78: {0}, {1..4_294_967_295}
    //#test_vector(Log getLog(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@79: {0}, {1..4_294_967_295}
    //#test_vector(Log getLog(HttpServletRequest, HttpServletResponse)): javax.servlet.http.HttpServletRequest:getParameter(...)@56: Addr_Set{null}, Inverse{null}
    //#test_vector(Log getLog(HttpServletRequest, HttpServletResponse)): javax.servlet.http.HttpServletRequest:getParameter(...)@57: Addr_Set{null}, Inverse{null}
    //#test_vector(Log getLog(HttpServletRequest, HttpServletResponse)): javax.servlet.http.HttpServletRequest:getParameter(...)@58: Addr_Set{null}, Inverse{null}

    String yearAsString = request.getParameter("year");
    String monthAsString = request.getParameter("month");
    String dayAsString = request.getParameter("day");

    Calendar cal = blog.getCalendar();
    //#abstractlogaction.java:60: Warning: method not available
    //#    -- call on Calendar net.sourceforge.pebble.domain.Blog:getCalendar()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Calendar net.sourceforge.pebble.domain.Blog:getCalendar()
    Log log = null;
    //#abstractlogaction.java:61: Warning: unused assignment
    //#    unused assignment into log
    //#    severity: SUPPRESSED
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    Attribs:  Uncertain
    String logPeriod = "";
    //#abstractlogaction.java:62: Warning: unused assignment
    //#    unused assignment into logPeriod
    //#    severity: LOW
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)

    if (yearAsString != null && yearAsString.length() > 0 &&
        monthAsString != null && monthAsString.length() > 0 &&
        dayAsString != null && dayAsString.length() > 0) {
      int year = Integer.parseInt(yearAsString);
      int month = Integer.parseInt(monthAsString);
      int day = Integer.parseInt(dayAsString);
      cal.set(Calendar.YEAR, year);
      cal.set(Calendar.MONTH, month-1);
      cal.set(Calendar.DAY_OF_MONTH, day);
      log = blog.getLogger().getLog(cal.get(Calendar.YEAR), cal.get(Calendar.MONTH)+1, cal.get(Calendar.DAY_OF_MONTH));
    //#abstractlogaction.java:73: Warning: method not available
    //#    -- call on AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#abstractlogaction.java:73: Warning: method not available
    //#    -- call on Log getLog(int, int, int)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Log getLog(int, int, int)
      SimpleDateFormat dateFormat = new SimpleDateFormat("dd MMMM yyyy", blog.getLocale());
    //#abstractlogaction.java:74: Warning: method not available
    //#    -- call on Locale net.sourceforge.pebble.domain.Blog:getLocale()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Locale net.sourceforge.pebble.domain.Blog:getLocale()
      dateFormat.setTimeZone(blog.getTimeZone());
    //#abstractlogaction.java:75: Warning: method not available
    //#    -- call on TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
      registerObjectsForNavigation(blog, blog.getBlogForDay(year, month, day));
    //#abstractlogaction.java:76: Warning: method not available
    //#    -- call on Day net.sourceforge.pebble.domain.Blog:getBlogForDay(int, int, int)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Day net.sourceforge.pebble.domain.Blog:getBlogForDay(int, int, int)
      logPeriod = dateFormat.format(cal.getTime());
    } else if (yearAsString != null && yearAsString.length() > 0 &&
          monthAsString != null && monthAsString.length() > 0) {
      int year = Integer.parseInt(yearAsString);
      int month = Integer.parseInt(monthAsString);
      cal.set(Calendar.YEAR, year);
      cal.set(Calendar.MONTH, month-1);
      log = blog.getLogger().getLog(cal.get(Calendar.YEAR), cal.get(Calendar.MONTH)+1);
    //#abstractlogaction.java:84: Warning: method not available
    //#    -- call on AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
      SimpleDateFormat dateFormat = new SimpleDateFormat("MMMM yyyy", blog.getLocale());
    //#abstractlogaction.java:85: Warning: method not available
    //#    -- call on Locale net.sourceforge.pebble.domain.Blog:getLocale()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Locale net.sourceforge.pebble.domain.Blog:getLocale()
      dateFormat.setTimeZone(blog.getTimeZone());
    //#abstractlogaction.java:86: Warning: method not available
    //#    -- call on TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
      registerObjectsForNavigation(blog, blog.getBlogForMonth(year, month));
    //#abstractlogaction.java:87: Warning: method not available
    //#    -- call on Month net.sourceforge.pebble.domain.Blog:getBlogForMonth(int, int)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Month net.sourceforge.pebble.domain.Blog:getBlogForMonth(int, int)
      logPeriod = dateFormat.format(cal.getTime());
    } else {
      // get the log for today
      log = blog.getLogger().getLog();
    //#abstractlogaction.java:91: Warning: method not available
    //#    -- call on AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#abstractlogaction.java:91: ?precondition failure
    //#    net/sourceforge/pebble/logging/AbstractLogger.getLog: this.blog != null
    //#    severity: SUPPRESSED
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    basic block: bb_13
    //#    assertion: net.sourceforge.pebble.domain.Blog:getLogger(...).blog@91 != null
    //#    callee: Log net/sourceforge/pebble/logging/AbstractLogger.getLog()
    //#    callee assertion: this.blog != null
    //#    callee file: abstractlogger.java
    //#    callee precondition index: [3]
    //#    callee srcpos: 130
    //#    VN: net.sourceforge.pebble.domain.Blog:getLogger(...).blog@91
    //#    Expected: Inverse{null}
    //#    Bad: Addr_Set{null}
    //#    Attribs:  Ptr  null in Bad  Uncertain
      SimpleDateFormat dateFormat = new SimpleDateFormat("dd MMMM yyyy", blog.getLocale());
    //#abstractlogaction.java:92: Warning: method not available
    //#    -- call on Locale net.sourceforge.pebble.domain.Blog:getLocale()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Locale net.sourceforge.pebble.domain.Blog:getLocale()
      dateFormat.setTimeZone(blog.getTimeZone());
    //#abstractlogaction.java:93: Warning: method not available
    //#    -- call on TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
      registerObjectsForNavigation(blog, blog.getBlogForToday());
    //#abstractlogaction.java:94: Warning: method not available
    //#    -- call on Day net.sourceforge.pebble.domain.Blog:getBlogForToday()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: Log getLog(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Day net.sourceforge.pebble.domain.Blog:getBlogForToday()
      logPeriod = dateFormat.format(cal.getTime());
    }

    getModel().put("logPeriod", logPeriod);

    return log;
    //#abstractlogaction.java:100: end of method: Log net.sourceforge.pebble.web.action.AbstractLogAction.getLog(HttpServletRequest, HttpServletResponse)
  }

  protected String getLogFile(HttpServletRequest request, HttpServletResponse response) throws ServletException {
    Blog blog = (Blog)getModel().get(Constants.BLOG_KEY);
    //#abstractlogaction.java:104: method: String net.sourceforge.pebble.web.action.AbstractLogAction.getLogFile(HttpServletRequest, HttpServletResponse)
    //#abstractlogaction.java:104: Warning: suspicious precondition
    //#    the precondition for this.__Tag is not a contiguous range of values
    //#    severity: SUPPRESSED
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    suspicious precondition index: [3]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewCountriesAction]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewLogAction]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewReferersAction]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsAction]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsByHourAction]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsByTypeAction]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewUserAgentsAction]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Descendant_Table[others]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): __Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Descendant_Table[net/sourceforge/pebble/logging/AbstractLogger]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Descendant_Table[net/sourceforge/pebble/logging/CombinedLogFormatLogger]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Descendant_Table[net/sourceforge/pebble/logging/NullLogger]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Descendant_Table[others]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Dispatch_Table.getLogFile()Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Dispatch_Table.getLogFile(II)Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/AbstractLogger.__Dispatch_Table.getLogFile(III)Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/CombinedLogFormatLogger.__Dispatch_Table.getLogFile()Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/CombinedLogFormatLogger.__Dispatch_Table.getLogFile(II)Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/CombinedLogFormatLogger.__Dispatch_Table.getLogFile(III)Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/NullLogger.__Dispatch_Table.getLogFile()Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/NullLogger.__Dispatch_Table.getLogFile(II)Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/logging/NullLogger.__Dispatch_Table.getLogFile(III)Ljava/lang/String;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewCountriesAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewLogAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewReferersAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewRequestsAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewRequestsByHourAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewRequestsByTypeAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/action/ViewUserAgentsAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/model/Model.__Descendant_Table[net/sourceforge/pebble/web/model/Model]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/model/Model.__Descendant_Table[others]
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/model/Model.__Dispatch_Table.get(Ljava/lang/String;)Ljava/lang/Object;
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): net/sourceforge/pebble/web/model/Model.__Dispatch_Table.put(Ljava/lang/String;Ljava/lang/Object;)V
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): request
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): this
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): this.__Tag
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): this.model
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): this.model.__Tag
    //#input(String getLogFile(HttpServletRequest, HttpServletResponse)): this.model.data
    //#output(String getLogFile(HttpServletRequest, HttpServletResponse)): return_value
    //#pre[1] (String getLogFile(HttpServletRequest, HttpServletResponse)): request != null
    //#pre[3] (String getLogFile(HttpServletRequest, HttpServletResponse)): this.__Tag in {net/sourceforge/pebble/web/action/AbstractLogAction, net/sourceforge/pebble/web/action/ViewCountriesAction, net/sourceforge/pebble/web/action/ViewLogAction, net/sourceforge/pebble/web/action/ViewReferersAction, net/sourceforge/pebble/web/action/ViewRequestsAction, net/sourceforge/pebble/web/action/ViewRequestsByHourAction, net/sourceforge/pebble/web/action/ViewRequestsByTypeAction, net/sourceforge/pebble/web/action/ViewUserAgentsAction}
    //#pre[4] (String getLogFile(HttpServletRequest, HttpServletResponse)): this.model != null
    //#pre[5] (String getLogFile(HttpServletRequest, HttpServletResponse)): this.model.__Tag == net/sourceforge/pebble/web/model/Model
    //#pre[6] (String getLogFile(HttpServletRequest, HttpServletResponse)): this.model.data != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): java.lang.Integer:parseInt(...)@118 >= -2_147_483_647
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): java.lang.Integer:parseInt(...)@131 >= -2_147_483_647
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): java.util.Calendar:get(...)@123 <= 4_294_967_294
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): java.util.Calendar:get(...)@134 <= 4_294_967_294
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): java.util.HashMap:get(...)@63 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getBlogForDay(...)@126 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getBlogForMonth(...)@137 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getBlogForToday(...)@144 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getCalendar(...)@110 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).__Tag@123 in {net/sourceforge/pebble/logging/AbstractLogger, net/sourceforge/pebble/logging/CombinedLogFormatLogger, net/sourceforge/pebble/logging/NullLogger}
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).__Tag@134 in {net/sourceforge/pebble/logging/AbstractLogger, net/sourceforge/pebble/logging/CombinedLogFormatLogger, net/sourceforge/pebble/logging/NullLogger}
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).__Tag@141 in {net/sourceforge/pebble/logging/AbstractLogger, net/sourceforge/pebble/logging/CombinedLogFormatLogger, net/sourceforge/pebble/logging/NullLogger}
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).blog@134 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...).blog@141 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...)@123 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...)@134 != null
    //#presumption(String getLogFile(HttpServletRequest, HttpServletResponse)): net.sourceforge.pebble.domain.Blog:getLogger(...)@141 != null
    //#post(String getLogFile(HttpServletRequest, HttpServletResponse)): return_value != null
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.HashMap:get
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Blog:getCalendar
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:getLogFile
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Calendar:set
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Calendar:getTime
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.text.SimpleDateFormat:format
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Blog:getLogsDirectory
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.File
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.File:exists
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.FileReader
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.BufferedReader
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.BufferedReader:readLine
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.io.BufferedReader:close
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.Exception:printStackTrace
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.StringBuffer
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.StringBuffer:append
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.System:getProperty
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.lang.StringBuffer:toString
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Calendar:getActualMaximum
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Calendar:get
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.HashMap:put
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Blog:getBlogForFirstMonth
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:getPreviousMonth
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:getNextMonth
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:before
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:getDate
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:java.util.Date:after
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Month:getBlogForFirstDay
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Day:getPreviousDay
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Day:getNextDay
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Day:before
    //#unanalyzed(String getLogFile(HttpServletRequest, HttpServletResponse)): Effects-of-calling:net.sourceforge.pebble.domain.Day:getDate
    //#test_vector(String getLogFile(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@114: {0}, {1..4_294_967_295}
    //#test_vector(String getLogFile(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@115: {0}, {1..4_294_967_295}
    //#test_vector(String getLogFile(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@116: {0}, {1..4_294_967_295}
    //#test_vector(String getLogFile(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@128: {0}, {1..4_294_967_295}
    //#test_vector(String getLogFile(HttpServletRequest, HttpServletResponse)): java.lang.String:length(...)@129: {0}, {1..4_294_967_295}
    //#test_vector(String getLogFile(HttpServletRequest, HttpServletResponse)): javax.servlet.http.HttpServletRequest:getParameter(...)@106: Addr_Set{null}, Inverse{null}
    //#test_vector(String getLogFile(HttpServletRequest, HttpServletResponse)): javax.servlet.http.HttpServletRequest:getParameter(...)@107: Addr_Set{null}, Inverse{null}
    //#test_vector(String getLogFile(HttpServletRequest, HttpServletResponse)): javax.servlet.http.HttpServletRequest:getParameter(...)@108: Addr_Set{null}, Inverse{null}

    String yearAsString = request.getParameter("year");
    String monthAsString = request.getParameter("month");
    String dayAsString = request.getParameter("day");

    Calendar cal = blog.getCalendar();
    //#abstractlogaction.java:110: Warning: method not available
    //#    -- call on Calendar net.sourceforge.pebble.domain.Blog:getCalendar()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Calendar net.sourceforge.pebble.domain.Blog:getCalendar()
    String log = null;
    //#abstractlogaction.java:111: Warning: unused assignment
    //#    unused assignment into log
    //#    severity: SUPPRESSED
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    Attribs:  Uncertain
    String logPeriod = "";
    //#abstractlogaction.java:112: Warning: unused assignment
    //#    unused assignment into logPeriod
    //#    severity: LOW
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)

    if (yearAsString != null && yearAsString.length() > 0 &&
        monthAsString != null && monthAsString.length() > 0 &&
        dayAsString != null && dayAsString.length() > 0) {
      int year = Integer.parseInt(yearAsString);
      int month = Integer.parseInt(monthAsString);
      int day = Integer.parseInt(dayAsString);
      cal.set(Calendar.YEAR, year);
      cal.set(Calendar.MONTH, month-1);
      cal.set(Calendar.DAY_OF_MONTH, day);
      log = blog.getLogger().getLogFile(cal.get(Calendar.YEAR), cal.get(Calendar.MONTH)+1, cal.get(Calendar.DAY_OF_MONTH));
    //#abstractlogaction.java:123: Warning: method not available
    //#    -- call on AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#abstractlogaction.java:123: Warning: method not available
    //#    -- call on String getLogFile(int, int, int)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: String getLogFile(int, int, int)
      SimpleDateFormat dateFormat = new SimpleDateFormat("dd MMMM yyyy", blog.getLocale());
    //#abstractlogaction.java:124: Warning: method not available
    //#    -- call on Locale net.sourceforge.pebble.domain.Blog:getLocale()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Locale net.sourceforge.pebble.domain.Blog:getLocale()
      dateFormat.setTimeZone(blog.getTimeZone());
    //#abstractlogaction.java:125: Warning: method not available
    //#    -- call on TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
      registerObjectsForNavigation(blog, blog.getBlogForDay(year, month, day));
    //#abstractlogaction.java:126: Warning: method not available
    //#    -- call on Day net.sourceforge.pebble.domain.Blog:getBlogForDay(int, int, int)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Day net.sourceforge.pebble.domain.Blog:getBlogForDay(int, int, int)
      logPeriod = dateFormat.format(cal.getTime());
    } else if (yearAsString != null && yearAsString.length() > 0 &&
          monthAsString != null && monthAsString.length() > 0) {
      int year = Integer.parseInt(yearAsString);
      int month = Integer.parseInt(monthAsString);
      cal.set(Calendar.YEAR, year);
      cal.set(Calendar.MONTH, month-1);
      log = blog.getLogger().getLogFile(cal.get(Calendar.YEAR), cal.get(Calendar.MONTH)+1);
    //#abstractlogaction.java:134: Warning: method not available
    //#    -- call on AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
      SimpleDateFormat dateFormat = new SimpleDateFormat("MMMM yyyy", blog.getLocale());
    //#abstractlogaction.java:135: Warning: method not available
    //#    -- call on Locale net.sourceforge.pebble.domain.Blog:getLocale()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Locale net.sourceforge.pebble.domain.Blog:getLocale()
      dateFormat.setTimeZone(blog.getTimeZone());
    //#abstractlogaction.java:136: Warning: method not available
    //#    -- call on TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
      registerObjectsForNavigation(blog, blog.getBlogForMonth(year, month));
    //#abstractlogaction.java:137: Warning: method not available
    //#    -- call on Month net.sourceforge.pebble.domain.Blog:getBlogForMonth(int, int)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Month net.sourceforge.pebble.domain.Blog:getBlogForMonth(int, int)
      logPeriod = dateFormat.format(cal.getTime());
    } else {
      // get the log for today
      log = blog.getLogger().getLogFile();
    //#abstractlogaction.java:141: Warning: method not available
    //#    -- call on AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: AbstractLogger net.sourceforge.pebble.domain.Blog:getLogger()
      SimpleDateFormat dateFormat = new SimpleDateFormat("dd MMMM yyyy", blog.getLocale());
    //#abstractlogaction.java:142: Warning: method not available
    //#    -- call on Locale net.sourceforge.pebble.domain.Blog:getLocale()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Locale net.sourceforge.pebble.domain.Blog:getLocale()
      dateFormat.setTimeZone(blog.getTimeZone());
    //#abstractlogaction.java:143: Warning: method not available
    //#    -- call on TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: TimeZone net.sourceforge.pebble.domain.Blog:getTimeZone()
      registerObjectsForNavigation(blog, blog.getBlogForToday());
    //#abstractlogaction.java:144: Warning: method not available
    //#    -- call on Day net.sourceforge.pebble.domain.Blog:getBlogForToday()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: String getLogFile(HttpServletRequest, HttpServletResponse)
    //#    unanalyzed callee: Day net.sourceforge.pebble.domain.Blog:getBlogForToday()
      logPeriod = dateFormat.format(cal.getTime());
    }

    getModel().put("logPeriod", logPeriod);

    return log;
    //#abstractlogaction.java:150: end of method: String net.sourceforge.pebble.web.action.AbstractLogAction.getLogFile(HttpServletRequest, HttpServletResponse)
  }

  private void registerObjectsForNavigation(Blog blog, Month month) {
    Month firstMonth = blog.getBlogForFirstMonth();
    //#abstractlogaction.java:154: method: void net.sourceforge.pebble.web.action.AbstractLogAction.registerObjectsForNavigation(Blog, Month)
    //#abstractlogaction.java:154: Warning: method not available
    //#    -- call on Month net.sourceforge.pebble.domain.Blog:getBlogForFirstMonth()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Month)
    //#    unanalyzed callee: Month net.sourceforge.pebble.domain.Blog:getBlogForFirstMonth()
    //#abstractlogaction.java:154: Warning: suspicious precondition
    //#    the precondition for this.__Tag is not a contiguous range of values
    //#    severity: SUPPRESSED
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Month)
    //#    suspicious precondition index: [4]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewCountriesAction]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewLogAction]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewReferersAction]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsAction]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsByHourAction]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsByTypeAction]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewUserAgentsAction]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Descendant_Table[others]
    //#input(void registerObjectsForNavigation(Blog, Month)): __Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Month)): blog
    //#input(void registerObjectsForNavigation(Blog, Month)): month
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/action/ViewCountriesAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/action/ViewLogAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/action/ViewReferersAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/action/ViewRequestsAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/action/ViewRequestsByHourAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/action/ViewRequestsByTypeAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/action/ViewUserAgentsAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/model/Model.__Descendant_Table[net/sourceforge/pebble/web/model/Model]
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/model/Model.__Descendant_Table[others]
    //#input(void registerObjectsForNavigation(Blog, Month)): net/sourceforge/pebble/web/model/Model.__Dispatch_Table.put(Ljava/lang/String;Ljava/lang/Object;)V
    //#input(void registerObjectsForNavigation(Blog, Month)): this
    //#input(void registerObjectsForNavigation(Blog, Month)): this.__Tag
    //#input(void registerObjectsForNavigation(Blog, Month)): this.model
    //#input(void registerObjectsForNavigation(Blog, Month)): this.model.__Tag
    //#input(void registerObjectsForNavigation(Blog, Month)): this.model.data
    //#pre[1] (void registerObjectsForNavigation(Blog, Month)): blog != null
    //#pre[2] (void registerObjectsForNavigation(Blog, Month)): month != null
    //#pre[4] (void registerObjectsForNavigation(Blog, Month)): this.__Tag in {net/sourceforge/pebble/web/action/AbstractLogAction, net/sourceforge/pebble/web/action/ViewCountriesAction, net/sourceforge/pebble/web/action/ViewLogAction, net/sourceforge/pebble/web/action/ViewReferersAction, net/sourceforge/pebble/web/action/ViewRequestsAction, net/sourceforge/pebble/web/action/ViewRequestsByHourAction, net/sourceforge/pebble/web/action/ViewRequestsByTypeAction, net/sourceforge/pebble/web/action/ViewUserAgentsAction}
    //#pre[5] (void registerObjectsForNavigation(Blog, Month)): this.model != null
    //#pre[6] (void registerObjectsForNavigation(Blog, Month)): this.model.__Tag == net/sourceforge/pebble/web/model/Model
    //#pre[7] (void registerObjectsForNavigation(Blog, Month)): this.model.data != null
    //#presumption(void registerObjectsForNavigation(Blog, Month)): net.sourceforge.pebble.domain.Blog:getCalendar(...)@162 != null
    //#presumption(void registerObjectsForNavigation(Blog, Month)): net.sourceforge.pebble.domain.Month:getDate(...)@162 != null
    //#presumption(void registerObjectsForNavigation(Blog, Month)): net.sourceforge.pebble.domain.Month:getNextMonth(...)@156 != null
    //#presumption(void registerObjectsForNavigation(Blog, Month)): net.sourceforge.pebble.domain.Month:getPreviousMonth(...)@155 != null
    //#unanalyzed(void registerObjectsForNavigation(Blog, Month)): Effects-of-calling:java.util.HashMap:put
    //#test_vector(void registerObjectsForNavigation(Blog, Month)): java.util.Date:after(...)@162: {0}, {1}
    //#test_vector(void registerObjectsForNavigation(Blog, Month)): net.sourceforge.pebble.domain.Month:before(...)@158: {1}, {0}
    //#test_vector(void registerObjectsForNavigation(Blog, Month)): net.sourceforge.pebble.domain.Month:before(...)@162: {0}, {1}
    Month previousMonth = month.getPreviousMonth();
    //#abstractlogaction.java:155: Warning: method not available
    //#    -- call on Month net.sourceforge.pebble.domain.Month:getPreviousMonth()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Month)
    //#    unanalyzed callee: Month net.sourceforge.pebble.domain.Month:getPreviousMonth()
    Month nextMonth = month.getNextMonth();
    //#abstractlogaction.java:156: Warning: method not available
    //#    -- call on Month net.sourceforge.pebble.domain.Month:getNextMonth()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Month)
    //#    unanalyzed callee: Month net.sourceforge.pebble.domain.Month:getNextMonth()

    if (!previousMonth.before(firstMonth)) {
    //#abstractlogaction.java:158: Warning: method not available
    //#    -- call on bool net.sourceforge.pebble.domain.Month:before(Month)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Month)
    //#    unanalyzed callee: bool net.sourceforge.pebble.domain.Month:before(Month)
      getModel().put("previousMonth", previousMonth);
    }

    if (!nextMonth.getDate().after(blog.getCalendar().getTime()) || nextMonth.before(firstMonth)) {
    //#abstractlogaction.java:162: Warning: method not available
    //#    -- call on Date net.sourceforge.pebble.domain.Month:getDate()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Month)
    //#    unanalyzed callee: Date net.sourceforge.pebble.domain.Month:getDate()
    //#abstractlogaction.java:162: Warning: method not available
    //#    -- call on Calendar net.sourceforge.pebble.domain.Blog:getCalendar()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Month)
    //#    unanalyzed callee: Calendar net.sourceforge.pebble.domain.Blog:getCalendar()
    //#abstractlogaction.java:162: Warning: method not available
    //#    -- call on bool net.sourceforge.pebble.domain.Month:before(Month)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Month)
    //#    unanalyzed callee: bool net.sourceforge.pebble.domain.Month:before(Month)
      getModel().put("nextMonth", nextMonth);
    }
    getModel().put("displayMode", "logSummaryForMonth");
  }
    //#abstractlogaction.java:166: end of method: void net.sourceforge.pebble.web.action.AbstractLogAction.registerObjectsForNavigation(Blog, Month)

  private void registerObjectsForNavigation(Blog blog, Day day) {
    Day firstDay = blog.getBlogForFirstMonth().getBlogForFirstDay();
    //#abstractlogaction.java:169: method: void net.sourceforge.pebble.web.action.AbstractLogAction.registerObjectsForNavigation(Blog, Day)
    //#abstractlogaction.java:169: Warning: method not available
    //#    -- call on Month net.sourceforge.pebble.domain.Blog:getBlogForFirstMonth()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    unanalyzed callee: Month net.sourceforge.pebble.domain.Blog:getBlogForFirstMonth()
    //#abstractlogaction.java:169: Warning: method not available
    //#    -- call on Day net.sourceforge.pebble.domain.Month:getBlogForFirstDay()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    unanalyzed callee: Day net.sourceforge.pebble.domain.Month:getBlogForFirstDay()
    //#abstractlogaction.java:169: Warning: suspicious precondition
    //#    the precondition for this.__Tag is not a contiguous range of values
    //#    severity: SUPPRESSED
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    suspicious precondition index: [4]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewCountriesAction]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewLogAction]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewReferersAction]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsAction]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsByHourAction]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewRequestsByTypeAction]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[net/sourceforge/pebble/web/action/ViewUserAgentsAction]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Descendant_Table[others]
    //#input(void registerObjectsForNavigation(Blog, Day)): __Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Day)): blog
    //#input(void registerObjectsForNavigation(Blog, Day)): day
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/action/ViewCountriesAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/action/ViewLogAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/action/ViewReferersAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/action/ViewRequestsAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/action/ViewRequestsByHourAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/action/ViewRequestsByTypeAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/action/ViewUserAgentsAction.__Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/model/Model.__Descendant_Table[net/sourceforge/pebble/web/model/Model]
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/model/Model.__Descendant_Table[others]
    //#input(void registerObjectsForNavigation(Blog, Day)): net/sourceforge/pebble/web/model/Model.__Dispatch_Table.put(Ljava/lang/String;Ljava/lang/Object;)V
    //#input(void registerObjectsForNavigation(Blog, Day)): this
    //#input(void registerObjectsForNavigation(Blog, Day)): this.__Tag
    //#input(void registerObjectsForNavigation(Blog, Day)): this.model
    //#input(void registerObjectsForNavigation(Blog, Day)): this.model.__Tag
    //#input(void registerObjectsForNavigation(Blog, Day)): this.model.data
    //#pre[1] (void registerObjectsForNavigation(Blog, Day)): blog != null
    //#pre[2] (void registerObjectsForNavigation(Blog, Day)): day != null
    //#pre[4] (void registerObjectsForNavigation(Blog, Day)): this.__Tag in {net/sourceforge/pebble/web/action/AbstractLogAction, net/sourceforge/pebble/web/action/ViewCountriesAction, net/sourceforge/pebble/web/action/ViewLogAction, net/sourceforge/pebble/web/action/ViewReferersAction, net/sourceforge/pebble/web/action/ViewRequestsAction, net/sourceforge/pebble/web/action/ViewRequestsByHourAction, net/sourceforge/pebble/web/action/ViewRequestsByTypeAction, net/sourceforge/pebble/web/action/ViewUserAgentsAction}
    //#pre[5] (void registerObjectsForNavigation(Blog, Day)): this.model != null
    //#pre[6] (void registerObjectsForNavigation(Blog, Day)): this.model.__Tag == net/sourceforge/pebble/web/model/Model
    //#pre[7] (void registerObjectsForNavigation(Blog, Day)): this.model.data != null
    //#presumption(void registerObjectsForNavigation(Blog, Day)): net.sourceforge.pebble.domain.Blog:getBlogForFirstMonth(...)@169 != null
    //#presumption(void registerObjectsForNavigation(Blog, Day)): net.sourceforge.pebble.domain.Blog:getCalendar(...)@177 != null
    //#presumption(void registerObjectsForNavigation(Blog, Day)): net.sourceforge.pebble.domain.Day:getDate(...)@177 != null
    //#presumption(void registerObjectsForNavigation(Blog, Day)): net.sourceforge.pebble.domain.Day:getNextDay(...)@171 != null
    //#presumption(void registerObjectsForNavigation(Blog, Day)): net.sourceforge.pebble.domain.Day:getPreviousDay(...)@170 != null
    //#unanalyzed(void registerObjectsForNavigation(Blog, Day)): Effects-of-calling:java.util.HashMap:put
    //#test_vector(void registerObjectsForNavigation(Blog, Day)): java.util.Date:after(...)@177: {0}, {1}
    //#test_vector(void registerObjectsForNavigation(Blog, Day)): net.sourceforge.pebble.domain.Day:before(...)@173: {1}, {0}
    //#test_vector(void registerObjectsForNavigation(Blog, Day)): net.sourceforge.pebble.domain.Day:before(...)@177: {0}, {1}
    Day previousDay = day.getPreviousDay();
    //#abstractlogaction.java:170: Warning: method not available
    //#    -- call on Day net.sourceforge.pebble.domain.Day:getPreviousDay()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    unanalyzed callee: Day net.sourceforge.pebble.domain.Day:getPreviousDay()
    Day nextDay = day.getNextDay();
    //#abstractlogaction.java:171: Warning: method not available
    //#    -- call on Day net.sourceforge.pebble.domain.Day:getNextDay()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    unanalyzed callee: Day net.sourceforge.pebble.domain.Day:getNextDay()

    if (!previousDay.before(firstDay)) {
    //#abstractlogaction.java:173: Warning: method not available
    //#    -- call on bool net.sourceforge.pebble.domain.Day:before(Day)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    unanalyzed callee: bool net.sourceforge.pebble.domain.Day:before(Day)
      getModel().put("previousDay", previousDay);
    }

    if (!nextDay.getDate().after(blog.getCalendar().getTime()) || nextDay.before(firstDay)) {
    //#abstractlogaction.java:177: Warning: method not available
    //#    -- call on Date net.sourceforge.pebble.domain.Day:getDate()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    unanalyzed callee: Date net.sourceforge.pebble.domain.Day:getDate()
    //#abstractlogaction.java:177: Warning: method not available
    //#    -- call on Calendar net.sourceforge.pebble.domain.Blog:getCalendar()
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    unanalyzed callee: Calendar net.sourceforge.pebble.domain.Blog:getCalendar()
    //#abstractlogaction.java:177: Warning: method not available
    //#    -- call on bool net.sourceforge.pebble.domain.Day:before(Day)
    //#    severity: INFORMATIONAL
    //#    class: net.sourceforge.pebble.web.action.AbstractLogAction
    //#    method: void registerObjectsForNavigation(Blog, Day)
    //#    unanalyzed callee: bool net.sourceforge.pebble.domain.Day:before(Day)
      getModel().put("nextDay", nextDay);
    }
    getModel().put("displayMode", "logSummaryForDay");
  }
    //#abstractlogaction.java:181: end of method: void net.sourceforge.pebble.web.action.AbstractLogAction.registerObjectsForNavigation(Blog, Day)

  /**
   * Gets a list of all roles that are allowed to access this action.
   *
   * @return  an array of Strings representing role names
   * @param request
   */
  public String[] getRoles(HttpServletRequest request) {
    return new String[]{Constants.BLOG_ADMIN_ROLE, Constants.BLOG_OWNER_ROLE, Constants.BLOG_PUBLISHER_ROLE, Constants.BLOG_CONTRIBUTOR_ROLE};
    //#abstractlogaction.java:190: method: String[] net.sourceforge.pebble.web.action.AbstractLogAction.getRoles(HttpServletRequest)
    //#input(String[] getRoles(HttpServletRequest)): net.sourceforge.pebble.Constants.BLOG_ADMIN_ROLE
    //#input(String[] getRoles(HttpServletRequest)): net.sourceforge.pebble.Constants.BLOG_CONTRIBUTOR_ROLE
    //#input(String[] getRoles(HttpServletRequest)): net.sourceforge.pebble.Constants.BLOG_OWNER_ROLE
    //#input(String[] getRoles(HttpServletRequest)): net.sourceforge.pebble.Constants.BLOG_PUBLISHER_ROLE
    //#output(String[] getRoles(HttpServletRequest)): new String[](getRoles#1) num objects
    //#output(String[] getRoles(HttpServletRequest)): return_value.length
    //#output(String[] getRoles(HttpServletRequest)): return_value[0]
    //#output(String[] getRoles(HttpServletRequest)): return_value[1]
    //#output(String[] getRoles(HttpServletRequest)): return_value[2]
    //#output(String[] getRoles(HttpServletRequest)): return_value[3]
    //#output(String[] getRoles(HttpServletRequest)): return_value
    //#new obj(String[] getRoles(HttpServletRequest)): new String[](getRoles#1)
    //#presumption(String[] getRoles(HttpServletRequest)): init'ed(net.sourceforge.pebble.Constants.BLOG_ADMIN_ROLE)
    //#presumption(String[] getRoles(HttpServletRequest)): init'ed(net.sourceforge.pebble.Constants.BLOG_CONTRIBUTOR_ROLE)
    //#presumption(String[] getRoles(HttpServletRequest)): init'ed(net.sourceforge.pebble.Constants.BLOG_OWNER_ROLE)
    //#presumption(String[] getRoles(HttpServletRequest)): init'ed(net.sourceforge.pebble.Constants.BLOG_PUBLISHER_ROLE)
    //#post(String[] getRoles(HttpServletRequest)): return_value == &new String[](getRoles#1)
    //#post(String[] getRoles(HttpServletRequest)): new String[](getRoles#1) num objects == 1
    //#post(String[] getRoles(HttpServletRequest)): return_value.length == 4
    //#post(String[] getRoles(HttpServletRequest)): return_value[0] == net.sourceforge.pebble.Constants.BLOG_ADMIN_ROLE
    //#post(String[] getRoles(HttpServletRequest)): (soft) init'ed(return_value[0])
    //#post(String[] getRoles(HttpServletRequest)): return_value[1] == net.sourceforge.pebble.Constants.BLOG_OWNER_ROLE
    //#post(String[] getRoles(HttpServletRequest)): (soft) init'ed(return_value[1])
    //#post(String[] getRoles(HttpServletRequest)): return_value[2] == net.sourceforge.pebble.Constants.BLOG_PUBLISHER_ROLE
    //#post(String[] getRoles(HttpServletRequest)): (soft) init'ed(return_value[2])
    //#post(String[] getRoles(HttpServletRequest)): return_value[3] == net.sourceforge.pebble.Constants.BLOG_CONTRIBUTOR_ROLE
    //#post(String[] getRoles(HttpServletRequest)): (soft) init'ed(return_value[3])
    //#abstractlogaction.java:190: end of method: String[] net.sourceforge.pebble.web.action.AbstractLogAction.getRoles(HttpServletRequest)
  }

}    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction]
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getLocalizedString(Ljava/lang/String;)Ljava/lang/String;
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getLog(Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;)Lnet/sourceforge/pebble/logging/Log;
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getLogFile(Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;)Ljava/lang/String;
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model;
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getRoles(Ljavax/servlet/http/HttpServletRequest;)[Ljava/lang/String;
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.process(Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;)Lnet/sourceforge/pebble/web/view/View;
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.registerObjectsForNavigation(Lnet/sourceforge/pebble/domain/Blog;Lnet/sourceforge/pebble/domain/Day;)V
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.registerObjectsForNavigation(Lnet/sourceforge/pebble/domain/Blog;Lnet/sourceforge/pebble/domain/Month;)V
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.setModel(Lnet/sourceforge/pebble/web/model/Model;)V
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): net/sourceforge/pebble/web/action/Action.__Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction]
    //#output(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): net/sourceforge/pebble/web/action/SecureAction.__Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction]
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction] == &__Dispatch_Table
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): net/sourceforge/pebble/web/action/Action.__Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction] == &__Dispatch_Table
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): net/sourceforge/pebble/web/action/SecureAction.__Descendant_Table[net/sourceforge/pebble/web/action/AbstractLogAction] == &__Dispatch_Table
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getLocalizedString(Ljava/lang/String;)Ljava/lang/String; == &net/sourceforge/pebble/web/action/Action.getLocalizedString
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getLog(Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;)Lnet/sourceforge/pebble/logging/Log; == &getLog
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getLogFile(Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;)Ljava/lang/String; == &getLogFile
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getModel()Lnet/sourceforge/pebble/web/model/Model; == &net/sourceforge/pebble/web/action/Action.getModel
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.getRoles(Ljavax/servlet/http/HttpServletRequest;)[Ljava/lang/String; == &getRoles
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.process(Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;)Lnet/sourceforge/pebble/web/view/View; == &net/sourceforge/pebble/web/action/Action.process
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.registerObjectsForNavigation(Lnet/sourceforge/pebble/domain/Blog;Lnet/sourceforge/pebble/domain/Day;)V == &registerObjectsForNavigation
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.registerObjectsForNavigation(Lnet/sourceforge/pebble/domain/Blog;Lnet/sourceforge/pebble/domain/Month;)V == &registerObjectsForNavigation
    //#post(net.sourceforge.pebble.web.action.AbstractLogAction__static_init): __Dispatch_Table.setModel(Lnet/sourceforge/pebble/web/model/Model;)V == &net/sourceforge/pebble/web/action/Action.setModel
    //#abstractlogaction.java:: end of method: net.sourceforge.pebble.web.action.AbstractLogAction.net.sourceforge.pebble.web.action.AbstractLogAction__static_init
    //#abstractlogaction.java:: end of class: net.sourceforge.pebble.web.action.AbstractLogAction
