blob: b2d9667d012d6a871b29866fbaa3c880957a8c94 [file] [log] [blame]
package org.apache.maven.doxia.module.twiki.parser;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.maven.doxia.util.ByLineSource;
import org.apache.maven.doxia.parser.ParseException;
/**
* Parse tables
*
* @author Juan F. Codagnone
* @version $Id$
*/
public class TableBlockParser
implements BlockParser
{
/**
* pattern to detect tables
*/
private static final Pattern TABLE_PATTERN = Pattern.compile( "^\\s*([|].*[|])+\\s*$" );
/**
* text parser
*/
private FormatedTextParser textParser;
/** {@inheritDoc} */
public final boolean accept( final String line )
{
return TABLE_PATTERN.matcher( line ).lookingAt();
}
/**
* {@inheritDoc}
*/
public final Block visit( final String line, final ByLineSource source )
throws ParseException
{
if ( !accept( line ) )
{
throw new IllegalAccessError( "call accept before this ;)" );
}
final List<Block> rows = new ArrayList<Block>();
String l = line;
do
{
final Matcher m = TABLE_PATTERN.matcher( l );
if ( m.lookingAt() )
{
final List<Block> cells = new ArrayList<Block>();
/* for each cell... */
for ( int lh = l.indexOf( '|' ) + 1, rh; ( rh = l.indexOf( '|', lh ) ) != -1; lh = rh + 1 )
{
final Block[] bs = textParser.parse( l.substring( lh, rh ).trim() );
if ( bs.length == 1 && bs[0] instanceof BoldBlock )
{
final Block[] tmp = ( (BoldBlock) bs[0] ).getBlocks();
cells.add( new TableCellHeaderBlock( tmp ) );
}
else
{
cells.add( new TableCellBlock( bs ) );
}
}
rows.add( new TableRowBlock( (Block[]) cells.toArray( new Block[] {} ) ) );
}
}
while ( ( l = source.getNextLine() ) != null && accept( l ) );
assert rows.size() >= 1;
return new TableBlock( rows.toArray( new Block[] {} ) );
}
/**
* <p>Setter for the field <code>textParser</code>.</p>
*
* @param textParser text parser to be set
*/
public final void setTextParser( final FormatedTextParser textParser )
{
if ( textParser == null )
{
throw new IllegalArgumentException( "argument can't be null" );
}
this.textParser = textParser;
}
}