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

org.gjt.sp.jedit.buffer.FoldHandler Maven / Gradle / Ivy

Go to download

This project aims to build a command line tool that can create HTML view with syntax highlighted source code. It uses Jedit syntax highlighting engine and support all languages that are supported in JEdit. Which are currently: ActionScript, Ada 95, ANTLR, Apache HTTPD, APDL, AppleScript, ASP, Aspect-J, Assembly, AWK, B formal method, Batch, BBj, BCEL, BibTeX, C, C++, C#, CHILL, CIL, COBOL, ColdFusion, CSS, CVS Commit, D, DOxygen, DSSSL, Eiffel, EmbPerl, Erlang, Factor, Fortran, Foxpro, FreeMarker, Fortran, Gettext, Groovy, Haskell, HTML, Icon, IDL, Inform, INI, Inno Setup, Informix 4GL, Interlis, Io, Java, JavaScript, JCL, JHTML, JMK, JSP, Latex, Lilypond, Lisp, LOTOS, Lua, Makefile, Maple, ML, Modula-3, MoinMoin, MQSC, NetRexx, NQC, NSIS2, Objective C, ObjectRexx, Occam, Omnimark, Parrot, Pascal, Patch, Perl, PHP, Pike, PL-SQL, PL/I, Pop11, PostScript, Povray, PowerDynamo, Progress 4GL, Prolog, Properties, PSP, PV-WAVE, Pyrex, Python, REBOL, Redcode, Relax-NG, RelationalView, Rest, Rib, RPM spec, RTF, Ruby, Ruby-HTML, RView, S+, S#, SAS, Scheme, SDL/PL, SGML, Shell Script, SHTML, Smalltalk, SMI MIB, SQR, Squidconf, SVN Commit, Swig, TCL, TeX, Texinfo, TPL, Transact-SQL, UnrealScript, VBScript, Velocity, Verilog, VHDL, XML, XSL, ZPT

The newest version!
/*
 * FoldHandler.java - Fold handler interface
 * :tabSize=8:indentSize=8:noTabs=false:
 * :folding=explicit:collapseFolds=1:
 *
 * Copyright (C) 2001, 2005 Slava Pestov
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 */

package org.gjt.sp.jedit.buffer;

import javax.swing.text.Segment;

/**
 * Interface for obtaining the fold level of a specified line.

* * Plugins can provide fold handlers by defining entries in their * services.xml files like so: * *

<SERVICE CLASS="org.gjt.sp.jedit.buffer.FoldHandler" NAME="name">
 *    new MyFoldHandler();
 *</SERVICE>
* * See {@link org.gjt.sp.jedit.ServiceManager} for details. * * @author Slava Pestov * @version $Id: FoldHandler.java 12504 2008-04-22 23:12:43Z ezust $ * @since jEdit 4.3pre3 */ public abstract class FoldHandler { /** * The service type. See {@link org.gjt.sp.jedit.ServiceManager}. * @since jEdit 4.2pre1 * @deprecated use {@link org.gjt.sp.jedit.ServiceManager.ServiceFoldHandlerProvider} */ @Deprecated public static final String SERVICE = "org.gjt.sp.jedit.buffer.FoldHandler"; /** The FoldHandlerProvider. */ public static FoldHandlerProvider foldHandlerProvider; //{{{ getName() method /** * Returns the internal name of this FoldHandler * @return The internal name of this FoldHandler * @since jEdit 4.0pre6 */ public String getName() { return name; } //}}} //{{{ getFoldLevel() method /** * Returns the fold level of the specified line. * @param buffer The buffer in question * @param lineIndex The line index * @param seg A segment the fold handler can use to obtain any * text from the buffer, if necessary * @return The fold level of the specified line * @since jEdit 4.0pre1 */ public abstract int getFoldLevel(JEditBuffer buffer, int lineIndex, Segment seg); //}}} //{{{ equals() method /** * Returns if the specified fold handler is equal to this one. * @param o The object */ public boolean equals(Object o) { // Default implementation... subclasses can extend this. if(o == null) return false; else return getClass() == o.getClass(); } //}}} //{{{ hashCode() method public int hashCode() { return getClass().hashCode(); } //}}} //{{{ getFoldHandler() method /** * Returns the fold handler with the specified name, or null if * there is no registered handler with that name. * @param name The name of the desired fold handler * @since jEdit 4.0pre6 */ public static FoldHandler getFoldHandler(String name) { return foldHandlerProvider.getFoldHandler(name); } //}}} //{{{ getFoldModes() method /** * Returns an array containing the names of all registered fold * handlers. * * @since jEdit 4.0pre6 */ public static String[] getFoldModes() { return foldHandlerProvider.getFoldModes(); } //}}} //{{{ FoldHandler() constructor protected FoldHandler(String name) { this.name = name; } //}}} //{{{ toString() method public String toString() { return name; } //}}} private String name; }