PageRenderTime 44ms CodeModel.GetById 19ms RepoModel.GetById 0ms app.codeStats 0ms

/jEdit/tags/jedit-4-1-pre5/org/gjt/sp/jedit/buffer/FoldHandler.java

#
Java | 182 lines | 72 code | 19 blank | 91 comment | 8 complexity | 50aec4f7bb9c815b970a91da6a778c6e MD5 | raw file
Possible License(s): BSD-3-Clause, AGPL-1.0, Apache-2.0, LGPL-2.0, LGPL-3.0, GPL-2.0, CC-BY-SA-3.0, LGPL-2.1, GPL-3.0, MPL-2.0-no-copyleft-exception, IPL-1.0
  1. /*
  2. * FoldHandler.java - Fold handler interface
  3. * :tabSize=8:indentSize=8:noTabs=false:
  4. * :folding=explicit:collapseFolds=1:
  5. *
  6. * Copyright (C) 2001 Slava Pestov
  7. *
  8. * This program is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU General Public License
  10. * as published by the Free Software Foundation; either version 2
  11. * of the License, or any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  21. */
  22. package org.gjt.sp.jedit.buffer;
  23. import java.util.*;
  24. import javax.swing.text.Segment;
  25. import org.gjt.sp.jedit.Buffer;
  26. import org.gjt.sp.util.Log;
  27. /**
  28. * Interface for obtaining the fold level of a specified label.
  29. * @author Slava Pestov
  30. * @version $Id: FoldHandler.java 4277 2002-06-22 08:33:00Z spestov $
  31. * @since jEdit 4.0pre1
  32. */
  33. public abstract class FoldHandler
  34. {
  35. //{{{ getName() method
  36. /**
  37. * Returns the internal name of this FoldHandler
  38. * @return The internal name of this FoldHandler
  39. * @since jEdit 4.0pre6
  40. */
  41. public String getName()
  42. {
  43. return name;
  44. }
  45. //}}}
  46. //{{{ getFoldLevel() method
  47. /**
  48. * Returns the fold level of the specified line.
  49. * @param buffer The buffer in question
  50. * @param lineIndex The line index
  51. * @param seg A segment the fold handler can use to obtain any
  52. * text from the buffer, if necessary
  53. * @return The fold level of the specified line
  54. * @since jEdit 4.0pre1
  55. */
  56. public abstract int getFoldLevel(Buffer buffer, int lineIndex, Segment seg);
  57. //}}}
  58. //{{{ equals() method
  59. /**
  60. * Returns if the specified fold handler is equal to this one.
  61. * @param o The object
  62. */
  63. public boolean equals(Object o)
  64. {
  65. // Default implementation... subclasses can extend this.
  66. if(o == null)
  67. return false;
  68. else
  69. return getClass() == o.getClass();
  70. } //}}}
  71. //{{{ registerFoldHandler() method
  72. /**
  73. * Adds a fold handler to the list of registered handlers
  74. * @param handler The fold handler to add
  75. * @since jEdit 4.0pre6
  76. */
  77. public static void registerFoldHandler(FoldHandler handler)
  78. {
  79. if (getFoldHandler(handler.getName()) != null)
  80. {
  81. Log.log(Log.ERROR, FoldHandler.class, "Cannot register more than one fold handler with the same name");
  82. return;
  83. }
  84. foldHandlers.add(handler);
  85. }
  86. //}}}
  87. //{{{ unregisterFoldHandler() method
  88. /**
  89. * Removes a fold handler from the list of registered handlers
  90. * @param handler The fold handler to add
  91. * @since jEdit 4.1pre2
  92. */
  93. public static void unregisterFoldHandler(FoldHandler handler)
  94. {
  95. foldHandlers.remove(handler);
  96. }
  97. //}}}
  98. //{{{ getFoldHandlers() method
  99. /**
  100. * Returns an array containing the list of registered fold handlers
  101. * @since jEdit 4.0pre6
  102. */
  103. public static FoldHandler[] getFoldHandlers()
  104. {
  105. FoldHandler[] handlers = new FoldHandler[foldHandlers.size()];
  106. return (FoldHandler[])foldHandlers.toArray(handlers);
  107. }
  108. //}}}
  109. //{{{ getFoldHandler() method
  110. /**
  111. * Returns the fold handler with the specified name, or null if
  112. * there is no registered handler with that name.
  113. * @param name The name of the desired fold handler
  114. * @since jEdit 4.0pre6
  115. */
  116. public static FoldHandler getFoldHandler(String name)
  117. {
  118. FoldHandler handler;
  119. Iterator i = foldHandlers.iterator();
  120. while (i.hasNext())
  121. {
  122. handler = (FoldHandler)i.next();
  123. if (name.equals(handler.getName())) return handler;
  124. }
  125. return null;
  126. }
  127. //}}}
  128. //{{{ getFoldModes() method
  129. /**
  130. * Returns an array containing the names of all registered fold handlers
  131. * @since jEdit 4.0pre6
  132. */
  133. public static String[] getFoldModes()
  134. {
  135. FoldHandler[] handlers = getFoldHandlers();
  136. String[] foldModes = new String[handlers.length];
  137. for (int i = 0; i < foldModes.length; i++)
  138. {
  139. foldModes[i] = handlers[i].getName();
  140. }
  141. return foldModes;
  142. }
  143. //}}}
  144. //{{{ FoldHandler() constructor
  145. protected FoldHandler(String name)
  146. {
  147. this.name = name;
  148. }
  149. //}}}
  150. //{{{ Private members
  151. private String name;
  152. private static ArrayList foldHandlers;
  153. //}}}
  154. //{{{ Static initializer
  155. static
  156. {
  157. foldHandlers = new ArrayList();
  158. registerFoldHandler(new DummyFoldHandler());
  159. registerFoldHandler(new IndentFoldHandler());
  160. registerFoldHandler(new ExplicitFoldHandler());
  161. }
  162. //}}}
  163. }