Home » freemarker-2.3.13 » freemarker.debug » [javadoc | source]

    1   /*
    2    * Copyright (c) 2003 The Visigoth Software Society. All rights
    3    * reserved.
    4    *
    5    * Redistribution and use in source and binary forms, with or without
    6    * modification, are permitted provided that the following conditions
    7    * are met:
    8    *
    9    * 1. Redistributions of source code must retain the above copyright
   10    *    notice, this list of conditions and the following disclaimer.
   11    *
   12    * 2. Redistributions in binary form must reproduce the above copyright
   13    *    notice, this list of conditions and the following disclaimer in
   14    *    the documentation and/or other materials provided with the
   15    *    distribution.
   16    *
   17    * 3. The end-user documentation included with the redistribution, if
   18    *    any, must include the following acknowledgement:
   19    *       "This product includes software developed by the
   20    *        Visigoth Software Society (http://www.visigoths.org/)."
   21    *    Alternately, this acknowledgement may appear in the software itself,
   22    *    if and wherever such third-party acknowledgements normally appear.
   23    *
   24    * 4. Neither the name "FreeMarker", "Visigoth", nor any of the names of the 
   25    *    project contributors may be used to endorse or promote products derived
   26    *    from this software without prior written permission. For written
   27    *    permission, please contact visigoths@visigoths.org.
   28    *
   29    * 5. Products derived from this software may not be called "FreeMarker" or "Visigoth"
   30    *    nor may "FreeMarker" or "Visigoth" appear in their names
   31    *    without prior written permission of the Visigoth Software Society.
   32    *
   33    * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
   34    * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
   35    * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
   36    * DISCLAIMED.  IN NO EVENT SHALL THE VISIGOTH SOFTWARE SOCIETY OR
   37    * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
   38    * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
   39    * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
   40    * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
   41    * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
   42    * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
   43    * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   44    * SUCH DAMAGE.
   45    * ====================================================================
   46    *
   47    * This software consists of voluntary contributions made by many
   48    * individuals on behalf of the Visigoth Software Society. For more
   49    * information on the Visigoth Software Society, please see
   50    * http://www.visigoths.org/
   51    */
   52   
   53   package freemarker.debug;
   54   
   55   import java.rmi.Remote;
   56   import java.rmi.RemoteException;
   57   import java.util.Date;
   58   
   59   import freemarker.template.TemplateModelException;
   60   
   61   /**
   62    * Represents the debugger-side mirror of a TemplateModel object, a Template
   63    * object, or a Configuration object. The Environment objects are also represented
   64    * by instances of this model, although not directly but through a separate
   65    * subinterface {@link DebuggedEnvironment}. The interface is a union of
   66    * almost all of FreeMarker template models with identical method signatures.
   67    * For purposes of optimizing network traffic there are bulk retrieval methods
   68    * for sequences and hashes, as well as a {@link #getModelTypes()} method that
   69    * returns a bit mask of various <tt>TYPE_xxx</tt> constants flagging which
   70    * template models are implemented by the mirrored object.
   71    *  
   72    * @author Attila Szegedi
   73    * @version $Id: DebugModel.java,v 1.2 2003/06/08 00:58:16 herbyderby Exp $
   74    */
   75   public interface DebugModel extends Remote
   76   {
   77       public static final int TYPE_SCALAR        =    1;
   78       public static final int TYPE_NUMBER        =    2;
   79       public static final int TYPE_DATE          =    4;
   80       public static final int TYPE_BOOLEAN       =    8;
   81       public static final int TYPE_SEQUENCE      =   16;
   82       public static final int TYPE_COLLECTION    =   32;
   83       public static final int TYPE_HASH          =   64;
   84       public static final int TYPE_HASH_EX       =  128;
   85       public static final int TYPE_METHOD        =  256;
   86       public static final int TYPE_METHOD_EX     =  512;
   87       public static final int TYPE_TRANSFORM     = 1024;
   88       public static final int TYPE_ENVIRONMENT   = 2048;
   89       public static final int TYPE_TEMPLATE      = 4096;
   90       public static final int TYPE_CONFIGURATION = 8192;
   91       
   92       public String getAsString()
   93       throws
   94           TemplateModelException,
   95           RemoteException;
   96           
   97       public Number getAsNumber()
   98       throws
   99           TemplateModelException,
  100           RemoteException;
  101       
  102       public boolean getAsBoolean()
  103       throws
  104           TemplateModelException,
  105           RemoteException;
  106       
  107       public Date getAsDate()
  108       throws
  109           TemplateModelException,
  110           RemoteException;
  111       
  112       public int getDateType()
  113       throws
  114           TemplateModelException,
  115           RemoteException;
  116           
  117       public int size()
  118       throws
  119           TemplateModelException,
  120           RemoteException;
  121           
  122       public DebugModel get(int index)
  123       throws
  124           TemplateModelException,
  125           RemoteException;
  126       
  127       public DebugModel[] get(int fromIndex, int toIndex)
  128       throws
  129           TemplateModelException,
  130           RemoteException;
  131           
  132       public DebugModel get(String key)
  133       throws
  134           TemplateModelException,
  135           RemoteException;
  136           
  137       public DebugModel[] get(String[] keys)
  138       throws
  139           TemplateModelException,
  140           RemoteException;
  141       
  142       public DebugModel[] getCollection()
  143       throws
  144           TemplateModelException,
  145           RemoteException;
  146   
  147       public String[] keys()
  148       throws
  149           TemplateModelException,
  150           RemoteException;
  151       
  152       public int getModelTypes()
  153       throws
  154           RemoteException;
  155   }

Home » freemarker-2.3.13 » freemarker.debug » [javadoc | source]