Update of /project/climacs/cvsroot/climacs
In directory clnet:/tmp/cvs-serv8855
Modified Files:
html-syntax.lisp ttcn3-syntax.lisp
Log Message:
TTCN3 syntax and HTML syntax should work now, but they have not been
fully tested.
--- /project/climacs/cvsroot/climacs/html-syntax.lisp 2006/11/12 16:06:06 1.36
+++ /project/climacs/cvsroot/climacs/html-syntax.lisp 2006/11/13 09:01:52 1.37
@@ -53,24 +53,28 @@
(attributes :initform nil :initarg :attributes)
(end :initarg :end)))
-(defmethod display-parse-tree ((entity html-start-tag) (syntax html-syntax) pane)
+(defgeneric display-parse-tree (parse-symbol pane drei syntax))
+
+(defmethod display-parse-tree ((entity html-start-tag) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (start name attributes end) entity
- (display-parse-tree start syntax pane)
- (display-parse-tree name syntax pane)
+ (display-parse-tree start pane drei syntax)
+ (display-parse-tree name pane drei syntax)
(unless (null attributes)
- (display-parse-tree attributes syntax pane))
- (display-parse-tree end syntax pane)))
+ (display-parse-tree attributes pane drei syntax))
+ (display-parse-tree end pane drei syntax)))
(defclass html-end-tag (html-tag)
((start :initarg :start)
(name :initarg :name)
(end :initarg :end)))
-(defmethod display-parse-tree ((entity html-end-tag) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity html-end-tag) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (start name attributes end) entity
- (display-parse-tree start syntax pane)
- (display-parse-tree name syntax pane)
- (display-parse-tree end syntax pane)))
+ (display-parse-tree start pane drei syntax)
+ (display-parse-tree name pane drei syntax)
+ (display-parse-tree end pane drei syntax)))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;
@@ -170,14 +174,16 @@
(make-instance ',nonempty-name
:items ,name :item ,item-name)))
- (defmethod display-parse-tree ((entity ,empty-name) (syntax html-syntax) pane)
+ (defmethod display-parse-tree ((entity ,empty-name) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(declare (ignore pane))
nil)
- (defmethod display-parse-tree ((entity ,nonempty-name) (syntax html-syntax) pane)
+ (defmethod display-parse-tree ((entity ,nonempty-name) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (items item) entity
- (display-parse-tree items syntax pane)
- (display-parse-tree item syntax pane))))))
+ (display-parse-tree items pane drei syntax)
+ (display-parse-tree item pane drei syntax))))))
(defmacro define-nonempty-list (name item-name)
(let ((empty-name (gensym))
@@ -199,14 +205,16 @@
(make-instance ',nonempty-name
:items ,name :item ,item-name)))
- (defmethod display-parse-tree ((entity ,empty-name) (syntax html-syntax) pane)
+ (defmethod display-parse-tree ((entity ,empty-name) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(declare (ignore pane))
nil)
- (defmethod display-parse-tree ((entity ,nonempty-name) (syntax html-syntax) pane)
+ (defmethod display-parse-tree ((entity ,nonempty-name) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (items item) entity
- (display-parse-tree items syntax pane)
- (display-parse-tree item syntax pane))))))
+ (display-parse-tree items pane drei syntax)
+ (display-parse-tree item pane drei syntax))))))
;;;;;;;;;;;;;;; string
@@ -226,12 +234,13 @@
(end delimiter (word-is end "\"")))
:start start :lexemes string-lexemes :end end))
-(defmethod display-parse-tree ((entity html-string) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity html-string) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (start lexemes end) entity
- (display-parse-tree start syntax pane)
+ (display-parse-tree start pane drei syntax)
(with-text-face (pane :italic)
- (display-parse-tree lexemes syntax pane))
- (display-parse-tree end syntax pane)))
+ (display-parse-tree lexemes pane drei syntax))
+ (display-parse-tree end pane drei syntax)))
;;;;;;;;;;;;;;; attributes
@@ -239,10 +248,11 @@
((name :initarg :name)
(equals :initarg :equals)))
-(defmethod display-parse-tree :before ((entity html-attribute) (syntax html-syntax) pane)
+(defmethod display-parse-tree :before ((entity html-attribute) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (name equals) entity
- (display-parse-tree name syntax pane)
- (display-parse-tree equals syntax pane)))
+ (display-parse-tree name pane drei syntax)
+ (display-parse-tree equals pane drei syntax)))
(defclass common-attribute (html-attribute) ())
@@ -265,9 +275,10 @@
2))))
:name name :equals equals :lang lang))
-(defmethod display-parse-tree ((entity lang-attr) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity lang-attr) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (lang) entity
- (display-parse-tree lang syntax pane)))
+ (display-parse-tree lang pane drei syntax)))
;;;;;;;;;;;;;;; dir attribute
@@ -282,9 +293,10 @@
(word-is dir "ltr")))))
:name name :equals equals :dir dir))
-(defmethod display-parse-tree ((entity dir-attr) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity dir-attr) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (dir) entity
- (display-parse-tree dir syntax pane)))
+ (display-parse-tree dir pane drei syntax)))
;;;;;;;;;;;;;;; href attribute
@@ -298,9 +310,10 @@
(href html-string))
:name name :equals equals :href href))
-(defmethod display-parse-tree ((entity href-attr) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity href-attr) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (href) entity
- (display-parse-tree href syntax pane)))
+ (display-parse-tree href pane drei syntax)))
;;;;;;;;;;;;;;; title
@@ -311,9 +324,10 @@
(add-html-rule (title-item -> (word) :item word))
(add-html-rule (title-item -> (delimiter) :item delimiter))
-(defmethod display-parse-tree ((entity title-item) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity title-item) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (item) entity
- (display-parse-tree item syntax pane)))
+ (display-parse-tree item pane drei syntax)))
(define-list title-items title-item)
@@ -325,12 +339,13 @@
(add-html-rule (title -> (<title> title-items </title>)
:<title> <title> :items title-items :</title> </title>))
-(defmethod display-parse-tree ((entity title) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity title) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<title> items </title>) entity
- (display-parse-tree <title> syntax pane)
+ (display-parse-tree <title> pane drei syntax)
(with-text-face (pane :bold)
- (display-parse-tree items syntax pane))
- (display-parse-tree </title> syntax pane)))
+ (display-parse-tree items pane drei syntax))
+ (display-parse-tree </title> pane drei syntax)))
;;;;;;;;;;;;;;; inline-element, block-level-element
@@ -348,9 +363,10 @@
(add-html-rule ($inline -> (word) :contents word))
(add-html-rule ($inline -> (delimiter) :contents delimiter))
-(defmethod display-parse-tree ((entity $inline) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity $inline) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (contents) entity
- (display-parse-tree contents syntax pane)))
+ (display-parse-tree contents pane drei syntax)))
(define-list $inlines $inline)
@@ -364,9 +380,10 @@
:predict-test (lambda (token)
(typep token 'start-tag-start)))
-(defmethod display-parse-tree ((entity $flow) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity $flow) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (contents) entity
- (display-parse-tree contents syntax pane)))
+ (display-parse-tree contents pane drei syntax)))
(define-list $flows $flow)
@@ -377,12 +394,13 @@
(contents :initarg :contents)
(end :initarg :end)))
-(defmethod display-parse-tree ((entity heading) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity heading) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (start contents end) entity
- (display-parse-tree start syntax pane)
+ (display-parse-tree start pane drei syntax)
(with-text-face (pane :bold)
- (display-parse-tree contents syntax pane))
- (display-parse-tree end syntax pane)))
+ (display-parse-tree contents pane drei syntax))
+ (display-parse-tree end pane drei syntax)))
(defmacro define-heading (class-name tag-string start-tag-name end-tag-name)
`(progn
@@ -409,9 +427,10 @@
(add-html-rule (<a>-attribute -> (href-attr) :attribute href-attr))
-(defmethod display-parse-tree ((entity <a>-attribute) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity <a>-attribute) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (attribute) entity
- (display-parse-tree attribute syntax pane)))
+ (display-parse-tree attribute pane drei syntax)))
(define-list <a>-attributes <a>-attribute)
@@ -434,12 +453,13 @@
(add-html-rule (a-element -> (<a> $inlines </a>)
:<a> <a> :items $inlines :</a> </a>))
-(defmethod display-parse-tree ((entity a-element) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity a-element) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<a> items </a>) entity
- (display-parse-tree <a> syntax pane)
+ (display-parse-tree <a> pane drei syntax)
(with-text-face (pane :bold)
- (display-parse-tree items syntax pane))
- (display-parse-tree </a> syntax pane)))
+ (display-parse-tree items pane drei syntax))
+ (display-parse-tree </a> pane drei syntax)))
;;;;;;;;;;;;;;; br element
@@ -450,9 +470,10 @@
(add-html-rule (br-element -> (<br>) :<br> <br>))
-(defmethod display-parse-tree ((entity br-element) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity br-element) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<br>) entity
- (display-parse-tree <br> syntax pane)))
+ (display-parse-tree <br> pane drei syntax)))
;;;;;;;;;;;;;;; p element
@@ -475,11 +496,12 @@
(add-html-rule (p-element -> (<p> $inlines </p>)
:<p> <p> :contents $inlines :</p> </p>))
-(defmethod display-parse-tree ((entity p-element) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity p-element) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<p> contents </p>) entity
- (display-parse-tree <p> syntax pane)
- (display-parse-tree contents syntax pane)
- (display-parse-tree </p> syntax pane)))
+ (display-parse-tree <p> pane drei syntax)
+ (display-parse-tree contents pane drei syntax)
+ (display-parse-tree </p> pane drei syntax)))
;;;;;;;;;;;;;;; li element
@@ -507,12 +529,13 @@
(add-html-rule (li-element -> (<li> $flows)
:<li> <li> :items $flows :</li> nil))
-(defmethod display-parse-tree ((entity li-element) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity li-element) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<li> items </li>) entity
- (display-parse-tree <li> syntax pane)
- (display-parse-tree items syntax pane)
+ (display-parse-tree <li> pane drei syntax)
+ (display-parse-tree items pane drei syntax)
(when </li>
- (display-parse-tree </li> syntax pane))))
+ (display-parse-tree </li> pane drei syntax))))
;;;;;;;;;;;;;;; ul element
@@ -540,11 +563,12 @@
(add-html-rule (ul-element -> (<ul> li-elements </ul>)
:<ul> <ul> :items li-elements :</ul> </ul>))
-(defmethod display-parse-tree ((entity ul-element) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity ul-element) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<ul> items </ul>) entity
- (display-parse-tree <ul> syntax pane)
- (display-parse-tree items syntax pane)
- (display-parse-tree </ul> syntax pane)))
+ (display-parse-tree <ul> pane drei syntax)
+ (display-parse-tree items pane drei syntax)
+ (display-parse-tree </ul> pane drei syntax)))
;;;;;;;;;;;;;;; hr element
@@ -555,9 +579,10 @@
(add-html-rule (hr-element -> (<hr>) :<hr> <hr>))
-(defmethod display-parse-tree ((entity hr-element) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity hr-element) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<hr>) entity
- (display-parse-tree <hr> syntax pane)))
+ (display-parse-tree <hr> pane drei syntax)))
;;;;;;;;;;;;;;; body element
@@ -566,9 +591,10 @@
(add-html-rule (body-item -> ((element block-level-element)) :item element))
-(defmethod display-parse-tree ((entity body-item) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity body-item) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (item) entity
- (display-parse-tree item syntax pane)))
+ (display-parse-tree item pane drei syntax)))
(define-list body-items body-item)
@@ -580,11 +606,12 @@
(add-html-rule (body -> (<body> body-items </body>)
:<body> <body> :items body-items :</body> </body>))
-(defmethod display-parse-tree ((entity body) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity body) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<body> items </body>) entity
- (display-parse-tree <body> syntax pane)
- (display-parse-tree items syntax pane)
- (display-parse-tree </body> syntax pane)))
+ (display-parse-tree <body> pane drei syntax)
+ (display-parse-tree items pane drei syntax)
+ (display-parse-tree </body> pane drei syntax)))
;;;;;;;;;;;;;;; head
@@ -596,20 +623,22 @@
(add-html-rule (head -> (<head> title </head>)
:<head> <head> :title title :</head> </head>))
-(defmethod display-parse-tree ((entity head) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity head) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (<head> title </head>) entity
- (display-parse-tree <head> syntax pane)
- (display-parse-tree title syntax pane)
- (display-parse-tree </head> syntax pane)))
+ (display-parse-tree <head> pane drei syntax)
+ (display-parse-tree title pane drei syntax)
+ (display-parse-tree </head> pane drei syntax)))
;;;;;;;;;;;;;;; html
(defclass <html>-attribute (html-nonterminal)
((attribute :initarg :attribute)))
-(defmethod display-parse-tree ((entity <html>-attribute) (syntax html-syntax) pane)
+(defmethod display-parse-tree ((entity <html>-attribute) (pane clim-stream-pane)
+ (drei drei) (syntax html-syntax))
(with-slots (attribute) entity
- (display-parse-tree attribute syntax pane)))
+ (display-parse-tree attribute pane drei syntax)))
(add-html-rule (<html>-attribute -> (lang-attr) :attribute lang-attr))
(add-html-rule (<html>-attribute -> (dir-attr) :attribute dir-attr))
@@ -636,12 +665,13 @@
(add-html-rule (html -> (<html> head body </html>)
:<html> <html> :head head :body body :</html> </html>))
[103 lines skipped]
--- /project/climacs/cvsroot/climacs/ttcn3-syntax.lisp 2006/11/12 16:06:06 1.8
+++ /project/climacs/cvsroot/climacs/ttcn3-syntax.lisp 2006/11/13 09:01:52 1.9
@@ -26,7 +26,7 @@
(:export))
(in-package :climacs-ttcn3-syntax)
-(defgeneric display-parse-tree (entity syntax pane))
+(defgeneric display-parse-tree (parse-symbol pane drei syntax))
(defclass ttcn3-parse-tree (parse-tree) ())
@@ -158,14 +158,16 @@
(make-instance ',nonempty-name
:items ,name :item ,item-name))) *ttcn3-grammar*)
- (defmethod display-parse-tree ((entity ,empty-name) (syntax ttcn3-syntax) pane)
+ (defmethod display-parse-tree ((entity ,empty-name) (pane clim-stream-pane)
+ (drei drei) (syntax ttcn3-syntax))
(declare (ignore pane))
nil)
- (defmethod display-parse-tree ((entity ,nonempty-name) (syntax ttcn3-syntax) pane)
+ (defmethod display-parse-tree ((entity ,nonempty-name) (pane clim-stream-pane)
+ (drei drei) (syntax ttcn3-syntax))
(with-slots (items item) entity
- (display-parse-tree items syntax pane)
- (display-parse-tree item syntax pane)))))
+ (display-parse-tree items drei pane syntax)
+ (display-parse-tree item drei pane syntax)))))
(defmacro define-simple-list (name item-name)
(let ((empty-name (gensym))
@@ -213,7 +215,8 @@
(add-rule (grammar-rule (,name -> ((word identifier (word-is word ,(first rule-body)))) :word word))
,grammar)
,@(if start-p `((add-rule (grammar-rule (,terminal -> (,name) :item ,name)) ,grammar)))
- (defmethod display-parse-tree :around ((entity ,name) (syntax ,syntax) pane)
+ (defmethod display-parse-tree :around ((entity ,name) (pane clim-stream-pane)
+ (drei drei) (syntax ,syntax))
(with-drawing-options (pane :ink +blue-violet+)
(call-next-method)))))
((and (eql (length rule-body) 1)
@@ -223,8 +226,9 @@
,@(loop for alt in (cdr (first rule-body))
collect `(add-rule (grammar-rule (,name -> ((item ,alt)) :item item)) ,grammar))
,@(if start-p `((add-rule (grammar-rule (,terminal -> (,name) :item ,name)) ,grammar)))
- (defmethod display-parse-tree ((entity ,name) (syntax ,syntax) pane)
- (display-parse-tree (slot-value entity 'item) syntax pane))))
+ (defmethod display-parse-tree ((entity ,name) (pane clim-stream-pane)
+ (drei drei) (syntax ,syntax))
+ (display-parse-tree (slot-value entity 'item) pane drei syntax))))
((and (eql (length rule-body) 1)
(typep (first rule-body) 'cons)
(eq (first (first rule-body)) 'nonempty-list-of))
@@ -247,11 +251,12 @@
appending `(,(intern (symbol-name component) :keyword)
,component)))) ,grammar)
,@(if start-p `((add-rule (grammar-rule (,terminal -> (,name) :item ,name)) ,grammar)))
- (defmethod display-parse-tree ((entity ,name) (syntax ,syntax) pane)
+ (defmethod display-parse-tree ((entity ,name) (pane clim-stream-pane)
+ (drei drei) (syntax ,syntax))
(with-slots ,rule-body
entity
,@(loop for component in rule-body collect
- `(display-parse-tree ,component syntax pane))))))
+ `(display-parse-tree ,component pane drei syntax))))))
(t (error "Unrecognized rule body ~S for rule ~S~%" rule-body
name)))))
`(progn
@@ -321,11 +326,13 @@
(or identifier number-form)))
-(defmethod display-parse-tree ((entity ttcn3-terminal) (syntax ttcn3-syntax) pane)
+(defmethod display-parse-tree ((entity ttcn3-terminal) (pane clim-stream-pane)
+ (drei drei) (syntax ttcn3-syntax))
(with-slots (item) entity
- (display-parse-tree item syntax pane)))
+ (display-parse-tree item pane drei syntax)))
-(defmethod display-parse-tree ((entity ttcn3-entry) (syntax ttcn3-syntax) pane)
+(defmethod display-parse-tree ((entity ttcn3-entry) (pane clim-stream-pane)
+ (drei drei) (syntax ttcn3-syntax))
(flet ((cache-test (t1 t2)
(and (eq t1 t2)
(eq (slot-value t1 'ink)
@@ -346,20 +353,21 @@
'string
:stream pane)))))
-(defgeneric display-parse-stack (symbol stack syntax pane))
+(defgeneric display-parse-stack (symbol stack pane drei syntax))
-(defmethod display-parse-stack (symbol stack (syntax ttcn3-syntax) pane)
+(defmethod display-parse-stack (symbol stack (pane clim-stream-pane)
+ (drei drei) (syntax ttcn3-syntax))
(let ((next (parse-stack-next stack)))
(unless (null next)
- (display-parse-stack (parse-stack-symbol next) next syntax pane))
+ (display-parse-stack (parse-stack-symbol next) next pane drei syntax))
(loop for parse-tree in (reverse (parse-stack-parse-trees stack))
- do (display-parse-tree parse-tree syntax pane))))
+ do (display-parse-tree parse-tree pane drei syntax))))
-(defun display-parse-state (state syntax pane)
+(defun display-parse-state (state pane drei syntax)
(let ((top (parse-stack-top state)))
(if (not (null top))
- (display-parse-stack (parse-stack-symbol top) top syntax pane)
- (display-parse-tree (target-parse-tree state) syntax pane))))
+ (display-parse-stack (parse-stack-symbol top) top pane drei syntax)
+ (display-parse-tree (target-parse-tree state) pane drei syntax))))
(defmethod update-syntax-for-display (buffer (syntax ttcn3-syntax) top bot)
(with-slots (parser lexer valid-parse) syntax
@@ -390,38 +398,40 @@
(defun handle-whitespace (pane buffer start end)
(let ((space-width (space-width pane))
- (tab-width (tab-width pane)))
- (loop while (and (< start end)
- (whitespacep (syntax buffer)
- (buffer-object buffer start)))
- do (ecase (buffer-object buffer start)
- (#\Newline (terpri pane)
- (setf (aref *cursor-positions* (incf *current-line*))
- (multiple-value-bind (x y) (stream-cursor-position pane)
- (declare (ignore x))
- y)))
- (#\Space (stream-increment-cursor-position
- pane space-width 0))
- (#\Tab (let ((x (stream-cursor-position pane)))
- (stream-increment-cursor-position
- pane (- tab-width (mod x tab-width)) 0)))
- (#\Page nil))
- (incf start))))
+ (tab-width (tab-width pane)))
+ (with-sheet-medium (medium pane)
+ (with-accessors ((cursor-positions cursor-positions)) (syntax buffer)
+ (loop while (< start end)
+ do (case (buffer-object buffer start)
+ (#\Newline (record-line-vertical-offset pane (syntax buffer) (incf *current-line*))
+ (terpri pane)
+ (stream-increment-cursor-position
+ pane (first (aref cursor-positions 0)) 0))
+ ((#\Page #\Return #\Space) (stream-increment-cursor-position
+ pane space-width 0))
+ (#\Tab (let ((x (stream-cursor-position pane)))
+ (stream-increment-cursor-position
+ pane (- tab-width (mod x tab-width)) 0))))
+ (incf start))))))
-(defmethod display-parse-tree :before ((entity ttcn3-entry) (syntax ttcn3-syntax) pane)
+(defmethod display-parse-tree :before ((entity ttcn3-entry) (pane clim-stream-pane)
+ (drei drei) (syntax ttcn3-syntax))
(handle-whitespace pane (buffer pane) *white-space-start* (start-offset entity))
(setf *white-space-start* (end-offset entity)))
-(defmethod display-parse-tree :around ((entity ttcn3-parse-tree) syntax pane)
+(defmethod display-parse-tree :around ((entity ttcn3-parse-tree) pane drei syntax)
(with-slots (top bot) pane
(when (and (end-offset entity) (mark> (end-offset entity) top))
(call-next-method))))
-(defmethod redisplay-pane-with-syntax ((pane drei-pane) (syntax ttcn3-syntax) current-p)
+(defmethod display-drei-contents ((pane clim-stream-pane) (drei drei) (syntax ttcn3-syntax))
(with-slots (top bot) pane
- (setf *cursor-positions* (make-array (1+ (number-of-lines-in-region top bot)))
- *current-line* 0
- (aref *cursor-positions* 0) (stream-cursor-position pane))
+ (with-accessors ((cursor-positions cursor-positions)) syntax
+ (setf cursor-positions (make-array (1+ (number-of-lines-in-region top bot))
+ :initial-element nil)
+ *current-line* 0
+ (aref cursor-positions 0) (multiple-value-list
+ (stream-cursor-position pane))))
(with-slots (lexer) syntax
(let ((average-token-size (max (float (/ (size (buffer pane)) (nb-lexemes lexer)))
1.0)))
@@ -440,19 +450,15 @@
(loop until (or (mark<= (end-offset (lexeme lexer (1- start-token-index))) top)
(not (parse-state-empty-p
(slot-value (lexeme lexer (1- start-token-index)) 'state))))
- do (decf start-token-index))
+ do (decf start-token-index))
(let ((*white-space-start* (offset top)))
;; display the parse tree if any
(unless (parse-state-empty-p (slot-value (lexeme lexer (1- start-token-index)) 'state))
(display-parse-state (slot-value (lexeme lexer (1- start-token-index)) 'state)
- syntax
- pane))
+ pane drei syntax))
;; display the lexemes
(with-drawing-options (pane :ink (make-rgb-color 0.7 0.7 0.7))
(loop while (< start-token-index end-token-index)
do (let ((token (lexeme lexer start-token-index)))
- (display-parse-tree token syntax pane))
- (incf start-token-index))))))))
- (when (region-visible-p pane) (display-region pane syntax))
- (display-cursor pane syntax current-p)))
-
+ (display-parse-tree token pane drei syntax))
+ (incf start-token-index))))))))))