PageRenderTime 57ms CodeModel.GetById 13ms RepoModel.GetById 0ms app.codeStats 0ms

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

#
Java | 101 lines | 53 code | 8 blank | 40 comment | 8 complexity | 0eba3d4159c2f648e05256e1823a5eaf 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. * ExplicitFoldHandler.java - Explicit fold handler
  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 javax.swing.text.Segment;
  24. import org.gjt.sp.jedit.Buffer;
  25. /**
  26. * A fold handler that folds lines based markers embedded in the text.
  27. * ("{{{"
  28. * and "}}}").
  29. * @author Slava Pestov
  30. * @version $Id: ExplicitFoldHandler.java 4117 2002-03-28 04:08:42Z spestov $
  31. * @since jEdit 4.0pre1
  32. */
  33. public class ExplicitFoldHandler extends FoldHandler
  34. {
  35. //{{{ ExplicitFoldHandler constructor
  36. public ExplicitFoldHandler()
  37. {
  38. super("explicit");
  39. } //}}}
  40. //{{{ getFoldLevel() method
  41. /**
  42. * Returns the fold level of the specified line.
  43. * @param buffer The buffer in question
  44. * @param lineIndex The line index
  45. * @param seg A segment the fold handler can use to obtain any
  46. * text from the buffer, if necessary
  47. * @return The fold level of the specified line
  48. * @since jEdit 4.0pre1
  49. */
  50. public int getFoldLevel(Buffer buffer, int lineIndex, Segment seg)
  51. {
  52. if(lineIndex == 0)
  53. return 0;
  54. else
  55. {
  56. int tabSize = buffer.getTabSize();
  57. int foldLevel = buffer.getFoldLevel(lineIndex - 1);
  58. buffer.getLineText(lineIndex - 1,seg);
  59. int offset = seg.offset;
  60. int count = seg.count;
  61. int openingBrackets = 0, closingBrackets = 0;
  62. for(int i = 0; i < count; i++)
  63. {
  64. switch(seg.array[offset + i])
  65. {
  66. case '{':
  67. closingBrackets = 0;
  68. openingBrackets++;
  69. if(openingBrackets == 3)
  70. {
  71. foldLevel += tabSize;
  72. openingBrackets = 0;
  73. }
  74. break;
  75. case '}':
  76. openingBrackets = 0;
  77. closingBrackets++;
  78. if(closingBrackets == 3)
  79. {
  80. if(foldLevel >= tabSize)
  81. foldLevel -= tabSize;
  82. closingBrackets = 0;
  83. }
  84. break;
  85. default:
  86. closingBrackets = openingBrackets = 0;
  87. break;
  88. }
  89. }
  90. return foldLevel;
  91. }
  92. } //}}}
  93. }