PageRenderTime 58ms CodeModel.GetById 23ms RepoModel.GetById 0ms app.codeStats 0ms

/jEdit/tags/jedit-4-5-pre1/org/gjt/sp/jedit/JEditKillRing.java

#
Java | 224 lines | 164 code | 28 blank | 32 comment | 17 complexity | dbf5b3f5e348a817f9e6094ad649643b 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. * :tabSize=8:indentSize=8:noTabs=false:
  3. * :folding=explicit:collapseFolds=1:
  4. *
  5. * Copyright (C) 2003, 2005 Slava Pestov
  6. * Portions copyright (C) 2006, 2011 Matthieu Casanova
  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;
  23. import java.io.File;
  24. import java.util.List;
  25. import java.util.LinkedList;
  26. import java.io.IOException;
  27. import org.xml.sax.Attributes;
  28. import org.xml.sax.InputSource;
  29. import org.xml.sax.helpers.DefaultHandler;
  30. import org.gjt.sp.jedit.buffer.KillRing;
  31. import org.gjt.sp.util.Log;
  32. import org.gjt.sp.util.XMLUtilities;
  33. import org.gjt.sp.util.IOUtilities;
  34. import javax.swing.*;
  35. /**
  36. * The basic KillRing of jEdit.
  37. * @author Matthieu Casanova
  38. * @version $Id: ParserRuleSet.java 5471 2006-06-22 06:31:23Z kpouer $
  39. */
  40. class JEditKillRing extends KillRing
  41. {
  42. //{{{ Constructor
  43. JEditKillRing()
  44. {
  45. String settingsDirectory = jEdit.getSettingsDirectory();
  46. if(settingsDirectory != null)
  47. {
  48. killringXML = new SettingsXML(settingsDirectory, "killring");
  49. }
  50. } //}}}
  51. //{{{ load() method
  52. @Override
  53. public void load()
  54. {
  55. if(killringXML == null)
  56. return;
  57. if(!killringXML.fileExists())
  58. return;
  59. Log.log(Log.MESSAGE,KillRing.class,"Loading " + killringXML);
  60. KillRingHandler handler = new KillRingHandler();
  61. try
  62. {
  63. killringXML.load(handler);
  64. }
  65. catch (OutOfMemoryError oem)
  66. {
  67. Log.log(Log.ERROR, this, "Unable to load entire Killring, too low memory, increase your jvm max heap size");
  68. String start = jEdit.getProperty("killring.start");
  69. String deleteKillRing = jEdit.getProperty("killring.delete");
  70. String stop = jEdit.getProperty("killring.stop");
  71. int selected = GUIUtilities.option(null, "killring.load-memoryerror", null,
  72. JOptionPane.ERROR_MESSAGE,
  73. new Object[]{start, deleteKillRing, stop}, start);
  74. if (selected == 2)
  75. {
  76. System.exit(-1);
  77. }
  78. else if (selected == 1)
  79. {
  80. new File(MiscUtilities.constructPath(
  81. jEdit.getSettingsDirectory(),"killring.xml")).delete();
  82. return;
  83. }
  84. }
  85. catch (IOException ioe)
  86. {
  87. Log.log(Log.ERROR, this, ioe);
  88. }
  89. reset(handler.list);
  90. } //}}}
  91. //{{{ save() method
  92. @Override
  93. public void save()
  94. {
  95. if(killringXML == null)
  96. return;
  97. if(killringXML.hasChangedOnDisk())
  98. {
  99. Log.log(Log.WARNING,KillRing.class,killringXML
  100. + " changed on disk; will not save killring"
  101. + " files");
  102. return;
  103. }
  104. Log.log(Log.MESSAGE,KillRing.class,"Saving " + killringXML);
  105. String lineSep = System.getProperty("line.separator");
  106. SettingsXML.Saver out = null;
  107. try
  108. {
  109. out = killringXML.openSaver();
  110. out.writeXMLDeclaration("1.1");
  111. out.write("<!DOCTYPE KILLRING SYSTEM \"killring.dtd\">");
  112. out.write(lineSep);
  113. out.write("<KILLRING>");
  114. out.write(lineSep);
  115. int size = getSize();
  116. for(int i = size - 1; i >=0; i--)
  117. {
  118. out.write("<ENTRY>");
  119. out.write(XMLUtilities.charsToEntities(
  120. getElementAt(i).toString(),true));
  121. out.write("</ENTRY>");
  122. out.write(lineSep);
  123. }
  124. out.write("</KILLRING>");
  125. out.write(lineSep);
  126. out.finish();
  127. }
  128. catch(Exception e)
  129. {
  130. Log.log(Log.ERROR,KillRing.class,e);
  131. }
  132. finally
  133. {
  134. IOUtilities.closeQuietly(out);
  135. }
  136. } //}}}
  137. //{{{ Private members
  138. private SettingsXML killringXML;
  139. //{{{ KillRingHandler class
  140. private static class KillRingHandler extends DefaultHandler
  141. {
  142. public List<String> list = new LinkedList<String>();
  143. @Override
  144. public InputSource resolveEntity(String publicId, String systemId)
  145. {
  146. return XMLUtilities.findEntity(systemId, "killring.dtd", getClass());
  147. }
  148. @Override
  149. public void startElement(String uri, String localName,
  150. String qName, Attributes attrs)
  151. {
  152. inEntry = qName.equals("ENTRY");
  153. }
  154. @Override
  155. public void endElement(String uri, String localName, String name)
  156. {
  157. if(name.equals("ENTRY"))
  158. {
  159. list.add(charData.toString());
  160. inEntry = false;
  161. charData.setLength(0);
  162. }
  163. }
  164. @Override
  165. public void characters(char[] ch, int start, int length)
  166. {
  167. if (inEntry)
  168. charData.append(ch, start, length);
  169. }
  170. @Override
  171. public void processingInstruction(String target, String data)
  172. {
  173. if ("illegal-xml-character".equals(target))
  174. {
  175. char ch;
  176. try
  177. {
  178. ch = (char)Integer.parseInt(data.trim());
  179. }
  180. catch (Exception e)
  181. {
  182. Log.log(Log.ERROR, this,
  183. "Failed to get character from PI"
  184. + "\"" + target + "\""
  185. + " with \"" + data + "\""
  186. + ": " + e);
  187. return;
  188. }
  189. characters(new char[] {ch}, 0, 1);
  190. }
  191. }
  192. private final StringBuilder charData = new StringBuilder();
  193. private boolean inEntry;
  194. } //}}}
  195. //}}}
  196. }