Coverage Report - org.apache.maven.doxia.DefaultDoxia
 
Classes in this File Line Coverage Branch Coverage Complexity
DefaultDoxia
0%
0/6
N/A
1
 
 1  
 package org.apache.maven.doxia;
 2  
 
 3  
 /*
 4  
  * Licensed to the Apache Software Foundation (ASF) under one
 5  
  * or more contributor license agreements.  See the NOTICE file
 6  
  * distributed with this work for additional information
 7  
  * regarding copyright ownership.  The ASF licenses this file
 8  
  * to you under the Apache License, Version 2.0 (the
 9  
  * "License"); you may not use this file except in compliance
 10  
  * with the License.  You may obtain a copy of the License at
 11  
  *
 12  
  *   http://www.apache.org/licenses/LICENSE-2.0
 13  
  *
 14  
  * Unless required by applicable law or agreed to in writing,
 15  
  * software distributed under the License is distributed on an
 16  
  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 17  
  * KIND, either express or implied.  See the License for the
 18  
  * specific language governing permissions and limitations
 19  
  * under the License.
 20  
  */
 21  
 
 22  
 import org.apache.maven.doxia.logging.PlexusLoggerWrapper;
 23  
 import org.apache.maven.doxia.parser.ParseException;
 24  
 import org.apache.maven.doxia.parser.Parser;
 25  
 import org.apache.maven.doxia.parser.manager.ParserManager;
 26  
 import org.apache.maven.doxia.parser.manager.ParserNotFoundException;
 27  
 import org.apache.maven.doxia.sink.Sink;
 28  
 
 29  
 import org.codehaus.plexus.logging.AbstractLogEnabled;
 30  
 
 31  
 import java.io.Reader;
 32  
 
 33  
 /**
 34  
  * Simple implementation of the Doxia interface:
 35  
  * uses a ParserManager to lookup a parser.
 36  
  *
 37  
  * @author Jason van Zyl
 38  
  * @version $Id: DefaultDoxia.java 628059 2008-02-15 13:22:30Z vsiveton $
 39  
  * @since 1.0
 40  
  * @plexus.component
 41  
  */
 42  0
 public class DefaultDoxia
 43  
     extends AbstractLogEnabled
 44  
     implements Doxia
 45  
 {
 46  
     /** @plexus.requirement */
 47  
     private ParserManager parserManager;
 48  
 
 49  
     // ----------------------------------------------------------------------
 50  
     // This remains because the sinks are not threadsafe which they probably
 51  
     // should be. In some places a constructor is used to initialize a sink
 52  
     // which can probably be done away with.
 53  
     // ----------------------------------------------------------------------
 54  
 
 55  
     /** {@inheritDoc} */
 56  
     public void parse( Reader source, String parserId, Sink sink )
 57  
         throws ParserNotFoundException, ParseException
 58  
     {
 59  0
         Parser parser = parserManager.getParser( parserId );
 60  
 
 61  0
         parser.enableLogging( new PlexusLoggerWrapper( getLogger() ) );
 62  
 
 63  0
         parser.parse( source, sink );
 64  0
     }
 65  
 
 66  
     /** {@inheritDoc} */
 67  
     public Parser getParser( String parserId )
 68  
         throws ParserNotFoundException
 69  
     {
 70  0
         return parserManager.getParser( parserId );
 71  
     }
 72  
 }