Java tutorial
/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License (the "License"). * You may not use this file except in compliance with the License. * * See LICENSE.txt included in this distribution for the specific * language governing permissions and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at LICENSE.txt. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved. */ package org.opensolaris.opengrok.analysis.plain; import java.io.IOException; import java.io.InputStream; import java.io.Reader; import java.io.Writer; import org.apache.lucene.document.Document; import org.apache.lucene.document.StoredField; import org.apache.lucene.document.TextField; import org.opensolaris.opengrok.analysis.Definitions; import org.opensolaris.opengrok.analysis.ExpandTabsReader; import org.opensolaris.opengrok.analysis.FileAnalyzerFactory; import org.opensolaris.opengrok.analysis.IteratorReader; import org.opensolaris.opengrok.analysis.JFlexXref; import org.opensolaris.opengrok.analysis.StreamSource; import org.opensolaris.opengrok.analysis.TextAnalyzer; import org.opensolaris.opengrok.configuration.Project; import org.opensolaris.opengrok.history.Annotation; /** * Analyzer for plain text files Created on September 21, 2005 * * @author Chandan */ public class PlainAnalyzer extends TextAnalyzer { private JFlexXref xref; private Definitions defs; /** * Creates a new instance of PlainAnalyzer */ protected PlainAnalyzer(FileAnalyzerFactory factory) { super(factory); } /** * Create an xref for the language supported by this analyzer. * @param reader the data to produce xref for * @return an xref instance */ protected JFlexXref newXref(Reader reader) { return new PlainXref(reader); } @Override protected Reader getReader(InputStream stream) throws IOException { return ExpandTabsReader.wrap(super.getReader(stream), project); } @Override public void analyze(Document doc, StreamSource src, Writer xrefOut) throws IOException { doc.add(new TextField("full", getReader(src.getStream()))); String fullpath = doc.get("fullpath"); if (fullpath != null && ctags != null) { defs = ctags.doCtags(fullpath + "\n"); if (defs != null && defs.numberOfSymbols() > 0) { doc.add(new TextField("defs", new IteratorReader(defs.getSymbols()))); doc.add(new TextField("refs", getReader(src.getStream()))); byte[] tags = defs.serialize(); doc.add(new StoredField("tags", tags)); } } if (xrefOut != null) { try (Reader in = getReader(src.getStream())) { writeXref(in, xrefOut); } } } /** * Write a cross referenced HTML file. * * @param in Input source * @param out Writer to write HTML cross-reference */ private void writeXref(Reader in, Writer out) throws IOException { if (xref == null) { xref = newXref(in); } else { xref.reInit(in); } xref.setDefs(defs); xref.project = project; xref.write(out); } /** * Write a cross referenced HTML file reads the source from in * * @param in Input source * @param out Output xref writer * @param defs definitions for the file (could be null) * @param annotation annotation for the file (could be null) */ static void writeXref(Reader in, Writer out, Definitions defs, Annotation annotation, Project project) throws IOException { PlainXref xref = new PlainXref(in); xref.annotation = annotation; xref.project = project; xref.setDefs(defs); xref.write(out); } }