All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.lowagie.text.pdf.parser.TextAssemblyBuffer Maven / Gradle / Ivy

There is a newer version: 2.0.4
Show newest version
/**
 * dgd: com.lowagie.text.pdf.parser
 */
package com.lowagie.text.pdf.parser;

import com.lowagie.text.pdf.PdfReader;

/**
 * @author dgd
 * 
 */
public interface TextAssemblyBuffer {

	/**
	 * @return the text to render
	 */
    String getText();

	/**
	 * @param reader
	 *            pdfReader that knows about our document. (size, etc. available
	 *            here).
	 * @param page
	 *            which page are we extracting text from.
	 * @param assembler
	 *            Builds result by accepting content from text components of
	 *            various sorts.
	 * @param useMarkup Should we generate tagged text, or just plain text.
	 * @return the final text ready to concatenate into result string.
	 */
    FinalText getFinalText(PdfReader reader, int page,
                           TextAssembler assembler, boolean useMarkup);

	/**
	 * We pass ourselves to the assembler, which is a visitor, so that it can
	 * accumulate information on this text depending on its type. The result is
	 * calculated by a final "assembly" phase, after accumulation is done. This
	 * is because we may have non-contiguous items in a PDF text stream.
	 * 
	 * @param p
	 *            the assembler that is visiting us.
	 * @param contextName Name of the surrounding markup element/"context" if
     * we're generating tagged output.
	 * 
	 * @see com.lowagie.text.pdf.parser.TextAssemblyBuffer#accumulate(com.lowagie.text.pdf.parser.TextAssembler, String)
	 */
    void accumulate(TextAssembler p, String contextName);

	/**
	 * @param p
	 *            we may pass ourselves to this assembler again during the final
	 *            assembly process.
	 */
    void assemble(TextAssembler p);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy