dbertoni    00/05/24 12:37:20

  Added:       c/src/XSLT TraceListener.cpp TraceListenerDefault.cpp
                        TraceListenerDefault.hpp
  Log:
  Initial revision.
  
  Revision  Changes    Path
  1.1                  xml-xalan/c/src/XSLT/TraceListener.cpp
  
  Index: TraceListener.cpp
  ===================================================================
  /*
   * The Apache Software License, Version 1.1
   *
   *
   * Copyright (c) 2000 The Apache Software Foundation.  All rights 
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer. 
   *
   * 2. 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.
   *
   * 3. The end-user documentation included with the redistribution,
   *    if any, must include the following acknowledgment:  
   *       "This product includes software developed by the
   *        Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowledgment may appear in the software itself,
   *    if and wherever such third-party acknowledgments normally appear.
   *
   * 4. The names "Xalan" and "Apache Software Foundation" must
   *    not be used to endorse or promote products derived from this
   *    software without prior written permission. For written 
   *    permission, please contact [EMAIL PROTECTED]
   *
   * 5. Products derived from this software may not be called "Apache",
   *    nor may "Apache" appear in their name, without prior written
   *    permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED 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 APACHE SOFTWARE FOUNDATION OR
   * ITS 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.
   * ====================================================================
   *
   * This software consists of voluntary contributions made by many
   * individuals on behalf of the Apache Software Foundation and was
   * originally based on software copyright (c) 1999, International
   * Business Machines, Inc., http://www.ibm.com.  For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  
  #include "TraceListener.hpp"
  
  
  
  TraceListener::TraceListener()
  {
  }
  
  
  
  TraceListener::~TraceListener()
  {
  }
  
  
  
  1.1                  xml-xalan/c/src/XSLT/TraceListenerDefault.cpp
  
  Index: TraceListenerDefault.cpp
  ===================================================================
  /*
   * The Apache Software License, Version 1.1
   *
   *
   * Copyright (c) 2000 The Apache Software Foundation.  All rights 
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *      notice, this list of conditions and the following disclaimer. 
   *
   * 2. 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.
   *
   * 3. The end-user documentation included with the redistribution,
   *      if any, must include the following acknowledgment:  
   *             "This product includes software developed by the
   *              Apache Software Foundation (http://www.apache.org/)."
   *      Alternately, this acknowledgment may appear in the software itself,
   *      if and wherever such third-party acknowledgments normally appear.
   *
   * 4. The names "Xalan" and "Apache Software Foundation" must
   *      not be used to endorse or promote products derived from this
   *      software without prior written permission. For written 
   *      permission, please contact [EMAIL PROTECTED]
   *
   * 5. Products derived from this software may not be called "Apache",
   *      nor may "Apache" appear in their name, without prior written
   *      permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED 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 APACHE SOFTWARE FOUNDATION OR
   * ITS 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.
   * ====================================================================
   *
   * This software consists of voluntary contributions made by many
   * individuals on behalf of the Apache Software Foundation and was
   * originally based on software copyright (c) 1999, International
   * Business Machines, Inc., http://www.ibm.com.  For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  
  #include "TraceListenerDefault.hpp"
  
  
  
  #include <PlatformSupport/PrintWriter.hpp>
  
  
  
  #include <DOMSupport/DOMServices.hpp>
  
  
  
  #include <XPath/NodeRefListBase.hpp>
  #include <XPath/XPath.hpp>
  
  
  
  #include "Constants.hpp"
  #include "ElemTextLiteral.hpp"
  #include "ElemTemplate.hpp"
  #include "GenerateEvent.hpp"
  #include "SelectionEvent.hpp"
  #include "StylesheetRoot.hpp"
  #include "TracerEvent.hpp"
  
  
  
  TraceListenerDefault::TraceListenerDefault(
                        PrintWriter&    thePrintWriter,
                        bool                    traceTemplates,
                        bool                    traceElements,
                        bool                    traceGeneration,
                        bool                    traceSelection) :
        m_printWriter(thePrintWriter),
        m_traceTemplates(traceTemplates),
        m_traceElements(traceElements),
        m_traceGeneration(traceGeneration),
        m_traceSelection(traceSelection)
  {
  }
  
  
  
  TraceListenerDefault::~TraceListenerDefault()
  {
  }
  
  
  
  void
  TraceListenerDefault::trace(const TracerEvent&        ev)
  {
        switch(ev.m_styleNode.getXSLToken())
        {
        case Constants::ELEMNAME_TEXTLITERALRESULT:
                if(m_traceElements == true)
                {
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("Line 
#"));
                        m_printWriter.print(ev.m_styleNode.getLineNumber());
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING(", "));
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("Column 
#"));
                        m_printWriter.print(ev.m_styleNode.getColumnNumber());
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING(": "));
                        m_printWriter.print(ev.m_styleNode.getElementName());
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("    "));
  
                        const ElemTextLiteral&  etl = static_cast<const 
ElemTextLiteral&>(ev.m_styleNode);
  
                        m_printWriter.println(c_wstr(etl.getText()), 
etl.getText().size());
                }
                break;
  
        case Constants::ELEMNAME_TEMPLATE:
                if(m_traceTemplates == true || m_traceElements == true)
                {
                        const ElemTemplate&             et = static_cast<const 
ElemTemplate&>(ev.m_styleNode);
  
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("Line 
#"));
                        m_printWriter.print(ev.m_styleNode.getLineNumber());
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING(", "));
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("Column 
#"));
                        m_printWriter.print(ev.m_styleNode.getColumnNumber());
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING(": "));
                        m_printWriter.print(ev.m_styleNode.getElementName());
  
                        const XPath* const      theMatchPattern =
                                et.getMatchPattern();
  
                        if(0 != theMatchPattern)
                        {
                                m_printWriter.print(XALAN_STATIC_UCODE_STRING(" 
match=\""));
                                
m_printWriter.print(theMatchPattern->getExpression().getCurrentPattern());
                                
m_printWriter.print(XALAN_STATIC_UCODE_STRING("\" "));
                        }
  
                        const QName&    theName = et.getName();
  
                        if(theName.isEmpty() == false)
                        {
                                
m_printWriter.print(XALAN_STATIC_UCODE_STRING("name=\""));
  
                                const XalanDOMString&   theNamespace =
                                        theName.getNamespace();
  
                                if (isEmpty(theNamespace) == false)
                                {
                                        m_printWriter.print(theNamespace);
                                        m_printWriter.print(':');
                                }
  
                                m_printWriter.print(theName.getLocalPart());
                                
m_printWriter.print(XALAN_STATIC_UCODE_STRING("\" "));
                        }
  
                        m_printWriter.println();
                }
                break;
  
        default:
                if(m_traceElements == true)
                {
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("Line 
#"));
                        m_printWriter.print(ev.m_styleNode.getLineNumber());
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING(", Column 
#"));
                        m_printWriter.print(ev.m_styleNode.getColumnNumber());
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING(": "));
                        m_printWriter.println(ev.m_styleNode.getElementName());
                }
                break;
        }
  }
  
  
  
  void
  TraceListenerDefault::selected(const SelectionEvent&  ev)
  {
      if(m_traceSelection == true)
      {
                const ElemTemplateElement&      ete = ev.m_styleNode;
  
                if(ev.m_styleNode.getLineNumber() == 0)
                {
                        // You may not have line numbers if the selection is 
occuring from a
                        // default template.
  
                        ElemTemplateElement* const      parent = 
ete.getParentNodeElem();
  
                        if(parent == 
ete.getStylesheet().getStylesheetRoot().getDefaultRootRule())
                        {
                                m_printWriter.print("(default root rule) ");
                        }
                        else if(parent == 
ete.getStylesheet().getStylesheetRoot().getDefaultTextRule())
                        {
                                m_printWriter.print("(default text rule) ");
                        }
                        else if(parent == 
ete.getStylesheet().getStylesheetRoot().getDefaultRule())
                        {
                                m_printWriter.print("(default rule) ");
                        }
                }
                else
                {
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("Line 
#"));
                        m_printWriter.print(ev.m_styleNode.getLineNumber());
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING(", "));
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("Column 
#"));
                        m_printWriter.print(ev.m_styleNode.getColumnNumber());
                        m_printWriter.print(", ");
                }
  
                m_printWriter.print(ete.getElementName());
                m_printWriter.print(XALAN_STATIC_UCODE_STRING(", "));
                m_printWriter.print(ev.m_attributeName);
                m_printWriter.print(XALAN_STATIC_UCODE_STRING("=\""));
                
m_printWriter.print(ev.m_xpath.getExpression().getCurrentPattern());
                m_printWriter.print(XALAN_STATIC_UCODE_STRING("\": "));
  
                if(ev.m_selection->getType() == XObject::eTypeNodeSet)
                {
                        m_printWriter.println();
  
                        const NodeRefListBase&  nl = ev.m_selection->nodeset();
  
                        const unsigned int      n = nl.getLength();
  
                        if(n == 0)
                        {
                                
m_printWriter.println(XALAN_STATIC_UCODE_STRING("     [empty node list]"));
                        }
                        else
                        {
                                for(unsigned int i = 0; i < n; i++)
                                {
                                        
m_printWriter.print(XALAN_STATIC_UCODE_STRING("     "));
                                        
m_printWriter.println(DOMServices::getNodeData(*nl.item(i)));
                                }
                        }
                }
                else
                {
                        m_printWriter.println(ev.m_selection->str());
                }
      }
  }
  
  
  
  void
  TraceListenerDefault::generated(const GenerateEvent&  ev)
  {
        if(m_traceGeneration == true)
        {
                switch(ev.m_eventType)
                {
                case GenerateEvent::EVENTTYPE_STARTDOCUMENT:
                        
m_printWriter.println(XALAN_STATIC_UCODE_STRING("STARTDOCUMENT"));
                        break;
  
                case GenerateEvent::EVENTTYPE_ENDDOCUMENT:
                        
m_printWriter.println(XALAN_STATIC_UCODE_STRING("ENDDOCUMENT"));
                        break;
  
                case GenerateEvent::EVENTTYPE_STARTELEMENT:
                        
m_printWriter.print(XALAN_STATIC_UCODE_STRING("STARTELEMENT: "));
                        m_printWriter.println(ev.m_name);
                        break;
  
                case GenerateEvent::EVENTTYPE_ENDELEMENT:
                        
m_printWriter.print(XALAN_STATIC_UCODE_STRING("ENDELEMENT: "));
                        m_printWriter.println(ev.m_name);
                        break;
  
                case GenerateEvent::EVENTTYPE_CHARACTERS:
                        
m_printWriter.print(XALAN_STATIC_UCODE_STRING("CHARACTERS: "));
                        m_printWriter.println(ev.m_characters);
                        break;
  
                case GenerateEvent::EVENTTYPE_CDATA:
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("CDATA: 
"));
                        m_printWriter.println(ev.m_characters);
                        break;
  
                case GenerateEvent::EVENTTYPE_COMMENT:
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("COMMENT: 
"));
                        m_printWriter.println(ev.m_data);
                        break;
  
                case GenerateEvent::EVENTTYPE_PI:
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING("PI: "));
                        m_printWriter.print(ev.m_name);
                        m_printWriter.print(XALAN_STATIC_UCODE_STRING(", "));
                        m_printWriter.println(ev.m_data);
                        break;
  
                case GenerateEvent::EVENTTYPE_ENTITYREF:
                        
m_printWriter.println(XALAN_STATIC_UCODE_STRING("ENTITYREF: "));
                        m_printWriter.println(ev.m_name);
                        break;
  
                case GenerateEvent::EVENTTYPE_IGNORABLEWHITESPACE:
                        
m_printWriter.println(XALAN_STATIC_UCODE_STRING("IGNORABLEWHITESPACE"));
                        break;
                }
        }
  }
  
  
  
  1.1                  xml-xalan/c/src/XSLT/TraceListenerDefault.hpp
  
  Index: TraceListenerDefault.hpp
  ===================================================================
  /*
   * The Apache Software License, Version 1.1
   *
   *
   * Copyright (c) 2000 The Apache Software Foundation.  All rights 
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer. 
   *
   * 2. 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.
   *
   * 3. The end-user documentation included with the redistribution,
   *    if any, must include the following acknowledgment:  
   *       "This product includes software developed by the
   *        Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowledgment may appear in the software itself,
   *    if and wherever such third-party acknowledgments normally appear.
   *
   * 4. The names "Xalan" and "Apache Software Foundation" must
   *    not be used to endorse or promote products derived from this
   *    software without prior written permission. For written 
   *    permission, please contact [EMAIL PROTECTED]
   *
   * 5. Products derived from this software may not be called "Apache",
   *    nor may "Apache" appear in their name, without prior written
   *    permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED 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 APACHE SOFTWARE FOUNDATION OR
   * ITS 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.
   * ====================================================================
   *
   * This software consists of voluntary contributions made by many
   * individuals on behalf of the Apache Software Foundation and was
   * originally based on software copyright (c) 1999, International
   * Business Machines, Inc., http://www.ibm.com.  For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  #if !defined(XALAN_TraceListenerDefault_HEADER_GUARD)
  #define XALAN_TraceListenerDefault_HEADER_GUARD 
  
  
  
  // Base include file.  Must be first.
  #include <XSLT/XSLTDefinitions.hpp>
  
  
  
  // Base class header file...
  #include <XSLT/TraceListener.hpp>
  
  
  
  class DOMSupport;
  class PrintWriter;
  
  
  
  class XALAN_XSLT_EXPORT TraceListenerDefault : public TraceListener
  {
  public:
  
        TraceListenerDefault(
                        PrintWriter&    thePrintWriter,
                        bool                    traceTemplates = false,
                        bool                    traceElements = false,
                        bool                    traceGeneration = false,
                        bool                    traceSelection = false);
  
        virtual
        ~TraceListenerDefault();
  
        virtual void
        trace(const TracerEvent&        ev);
  
        virtual void
        selected(const SelectionEvent&  ev);
  
        virtual void
        generated(const GenerateEvent&  ev);
  
        bool
        getTraceTemplates() const
        {
                return m_traceTemplates;
        }
  
        void
        setTraceTemplates(bool  b)
        {
                m_traceTemplates = b;
        }
  
        bool
        getTraceElement() const
        {
                return m_traceElements;
        }
  
        void
        setTraceElements(bool   b)
        {
                m_traceElements = b;
        }
  
        bool
        getTraceGeneration() const
        {
                return m_traceGeneration;
        }
  
        void
        setTraceGeneration(bool         b)
        {
                m_traceGeneration = b;
        }
  
        bool
        getTraceSelection() const
        {
                return m_traceSelection;
        }
  
        void
        setTraceSelection(bool  b)
        {
                m_traceSelection = b;
        }
  
  private:
  
        PrintWriter&    m_printWriter;
  
        bool                    m_traceTemplates;
  
        bool                    m_traceElements;
  
        bool                    m_traceGeneration;
  
        bool                    m_traceSelection;
  };
  
  
  
  #endif //XALAN_TraceListenerDefault_HEADER_GUARD 
  
  
  

Reply via email to