diff -r dac5fa0ac971 -r 2a368e8e0a80 src/Tools/jEdit/src/jedit/document_model.scala --- a/src/Tools/jEdit/src/jedit/document_model.scala Sat Aug 07 14:45:26 2010 +0200 +++ b/src/Tools/jEdit/src/jedit/document_model.scala Sat Aug 07 16:15:52 2010 +0200 @@ -151,7 +151,7 @@ def init(session: Session, buffer: Buffer, thy_name: String): Document_Model = { - Swing_Thread.assert() + Swing_Thread.require() val model = new Document_Model(session, buffer, thy_name) buffer.setProperty(key, model) model.activate() @@ -160,7 +160,7 @@ def apply(buffer: Buffer): Option[Document_Model] = { - Swing_Thread.assert() + Swing_Thread.require() buffer.getProperty(key) match { case model: Document_Model => Some(model) case _ => None @@ -169,7 +169,7 @@ def exit(buffer: Buffer) { - Swing_Thread.assert() + Swing_Thread.require() apply(buffer) match { case None => error("No document model for buffer: " + buffer) case Some(model) => @@ -209,8 +209,10 @@ /* snapshot */ - def snapshot(): Change.Snapshot = - Swing_Thread.now { session.current_change().snapshot(thy_name, edits_buffer.toList) } + def snapshot(): Change.Snapshot = { + Swing_Thread.require() + session.current_change().snapshot(thy_name, edits_buffer.toList) + } /* buffer listener */ @@ -246,7 +248,7 @@ val start = buffer.getLineStartOffset(line) val stop = start + line_segment.count - val snapshot = Document_Model.this.snapshot() + val snapshot = Swing_Thread.now { Document_Model.this.snapshot() } /* FIXME for (text_area <- Isabelle.jedit_text_areas(buffer)