/[cmucl]/src/hemlock/indent.lisp
ViewVC logotype

Contents of /src/hemlock/indent.lisp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.4 - (show annotations)
Mon Oct 31 04:50:12 1994 UTC (19 years, 5 months ago) by ram
Branch: MAIN
CVS Tags: sparc-tramp-assem-base, double-double-array-base, post-merge-intl-branch, release-19b-pre1, release-19b-pre2, merged-unicode-utf16-extfmt-2009-06-11, double-double-init-sparc-2, unicode-utf16-extfmt-2009-03-27, double-double-base, snapshot-2007-09, snapshot-2007-08, snapshot-2008-08, snapshot-2008-09, ppc_gencgc_snap_2006-01-06, sse2-packed-2008-11-12, snapshot-2008-05, snapshot-2008-06, snapshot-2008-07, snapshot-2007-05, snapshot-2008-01, snapshot-2008-02, snapshot-2008-03, intl-branch-working-2010-02-19-1000, snapshot-2006-11, snapshot-2006-10, double-double-init-sparc, snapshot-2006-12, unicode-string-buffer-impl-base, sse2-base, release-20b-pre1, release-20b-pre2, unicode-string-buffer-base, RELEASE_18d, sse2-packed-base, sparc-tramp-assem-2010-07-19, amd64-dd-start, snapshot-2003-10, snapshot-2004-10, release-18e-base, release-19f-pre1, snapshot-2008-12, snapshot-2008-11, intl-2-branch-base, snapshot-2004-08, snapshot-2004-09, remove_negative_zero_not_zero, snapshot-2007-01, snapshot-2007-02, snapshot-2004-05, snapshot-2004-06, snapshot-2004-07, release-19e, release-19d, GIT-CONVERSION, double-double-init-ppc, release-19c, dynamic-extent-base, unicode-utf16-sync-2008-12, LINKAGE_TABLE, release-19c-base, cross-sol-x86-merged, label-2009-03-16, release-19f-base, PRE_LINKAGE_TABLE, merge-sse2-packed, mod-arith-base, sparc_gencgc_merge, merge-with-19f, snapshot-2004-12, snapshot-2004-11, intl-branch-working-2010-02-11-1000, RELEASE_18a, RELEASE_18b, RELEASE_18c, unicode-snapshot-2009-05, unicode-snapshot-2009-06, amd64-merge-start, ppc_gencgc_snap_2005-12-17, double-double-init-%make-sparc, unicode-utf16-sync-2008-07, release-18e-pre2, unicode-utf16-sync-2008-09, unicode-utf16-extfmts-sync-2008-12, prm-before-macosx-merge-tag, cold-pcl-base, RELEASE_20b, snapshot-2008-04, snapshot-2003-11, snapshot-2005-07, unicode-utf16-sync-label-2009-03-16, RELEASE_19f, snapshot-2007-03, release-20a-base, cross-sol-x86-base, unicode-utf16-char-support-2009-03-26, unicode-utf16-char-support-2009-03-25, release-19a-base, unicode-utf16-extfmts-pre-sync-2008-11, snapshot-2008-10, sparc_gencgc, snapshot-2007-04, snapshot-2010-12, snapshot-2010-11, unicode-utf16-sync-2008-11, snapshot-2007-07, snapshot-2011-09, snapshot-2011-06, snapshot-2011-07, snapshot-2011-04, snapshot-2007-06, snapshot-2011-02, snapshot-2011-03, snapshot-2011-01, snapshot-2003-12, release-19a-pre1, release-19a-pre3, release-19a-pre2, pre-merge-intl-branch, release-19a, UNICODE-BASE, double-double-array-checkpoint, double-double-reader-checkpoint-1, release-19d-base, release-19e-pre1, double-double-irrat-end, release-19e-pre2, snapshot-2010-05, snapshot-2010-04, snapshot-2010-07, snapshot-2010-06, snapshot-2010-01, snapshot-2010-03, snapshot-2010-02, release-19d-pre2, release-19d-pre1, snapshot-2010-08, release-18e, double-double-init-checkpoint-1, double-double-reader-base, label-2009-03-25, snapshot-2005-03, release-19b-base, cross-sol-x86-2010-12-20, double-double-init-x86, sse2-checkpoint-2008-10-01, intl-branch-2010-03-18-1300, snapshot-2005-11, double-double-sparc-checkpoint-1, snapshot-2004-04, sse2-merge-with-2008-11, sse2-merge-with-2008-10, snapshot-2005-10, RELEASE_20a, snapshot-2005-12, release-20a-pre1, snapshot-2005-01, snapshot-2009-11, snapshot-2009-12, unicode-utf16-extfmt-2009-06-11, portable-clx-import-2009-06-16, unicode-utf16-string-support, release-19c-pre1, cross-sparc-branch-base, release-19e-base, intl-branch-base, double-double-irrat-start, snapshot-2005-06, snapshot-2005-05, snapshot-2005-04, ppc_gencgc_snap_2005-05-14, snapshot-2005-02, unicode-utf16-base, portable-clx-base, snapshot-2005-09, snapshot-2005-08, lisp-executable-base, snapshot-2009-08, snapshot-2007-12, snapshot-2007-10, snapshot-2007-11, snapshot-2009-02, snapshot-2009-01, snapshot-2009-07, snapshot-2009-05, snapshot-2009-04, snapshot-2006-02, snapshot-2006-03, release-18e-pre1, snapshot-2006-01, snapshot-2006-06, snapshot-2006-07, snapshot-2006-04, snapshot-2006-05, pre-telent-clx, snapshot-2006-08, snapshot-2006-09, HEAD
Branch point for: release-19b-branch, double-double-reader-branch, double-double-array-branch, mod-arith-branch, RELEASE-19F-BRANCH, portable-clx-branch, sparc_gencgc_branch, cross-sparc-branch, RELEASE-20B-BRANCH, RELENG_18, unicode-string-buffer-branch, sparc-tramp-assem-branch, dynamic-extent, UNICODE-BRANCH, release-19d-branch, ppc_gencgc_branch, sse2-packed-branch, lisp-executable, RELEASE-20A-BRANCH, amd64-dd-branch, double-double-branch, unicode-string-buffer-impl-branch, intl-branch, release-18e-branch, cold-pcl, unicode-utf16-branch, cross-sol-x86-branch, release-19e-branch, sse2-branch, release-19a-branch, release-19c-branch, intl-2-branch, unicode-utf16-extfmt-branch
Changes since 1.3: +1 -3 lines
Fix headed boilerplate.
1 ;;; -*- Log: hemlock.log; Package: Hemlock -*-
2 ;;;
3 ;;; **********************************************************************
4 ;;; This code was written as part of the CMU Common Lisp project at
5 ;;; Carnegie Mellon University, and has been placed in the public domain.
6 ;;;
7 (ext:file-comment
8 "$Header: /tiger/var/lib/cvsroots/cmucl/src/hemlock/indent.lisp,v 1.4 1994/10/31 04:50:12 ram Rel $")
9 ;;;
10 ;;; **********************************************************************
11 ;;;
12 ;;; Hemlock indentation commands
13 ;;;
14 ;;; Written by Bill Maddox and Bill Chiles
15 ;;;
16 (in-package "HEMLOCK")
17
18
19
20 (defhvar "Spaces per Tab"
21 "The number of spaces a tab is equivalent to. NOTE: This is not incorporated
22 everywhere in Hemlock yet, so do not change it."
23 :value 8)
24
25 (defun indent-using-tabs (mark column)
26 "Inserts at mark a maximum number of tabs and a minimum number of spaces to
27 move mark to column. This assumes mark is at the beginning of a line."
28 (multiple-value-bind (tabs spaces) (floor column (value spaces-per-tab))
29 (dotimes (i tabs) (insert-character mark #\tab))
30 (dotimes (i spaces) (insert-character mark #\space))))
31
32 (defhvar "Indent with Tabs"
33 "Function that takes a mark and a number of spaces and inserts tabs and spaces
34 to indent that number of spaces using \"Spaces per Tab\"."
35 :value #'indent-using-tabs)
36
37
38 (defun tab-to-tab-stop (mark)
39 (insert-character mark #\tab))
40
41 (defhvar "Indent Function"
42 "Indentation function which is invoked by \"Indent\" command.
43 It takes a :left-inserting mark that may be moved."
44 :value #'tab-to-tab-stop)
45
46
47 (defun generic-indent (mark)
48 (let* ((line (mark-line mark))
49 (prev (do ((line (line-previous line) (line-previous line)))
50 ((or (null line) (not (blank-line-p line))) line))))
51 (unless prev (editor-error))
52 (line-start mark prev)
53 (find-attribute mark :space #'zerop)
54 (let ((indentation (mark-column mark)))
55 (line-start mark line)
56 (delete-horizontal-space mark)
57 (funcall (value indent-with-tabs) mark indentation))))
58
59
60 (defcommand "Indent New Line" (p)
61 "Moves point to a new blank line and indents it.
62 Any whitespace before point is deleted. The value of \"Indent Function\"
63 is used for indentation unless there is a Fill Prefix, in which case it is
64 used. Any argument is passed onto \"New Line\"."
65 "Moves point to a new blank line and indents it.
66 Any whitespace before point is deleted. The value of \"Indent Function\"
67 is used for indentation unless there is a Fill Prefix, in which case it is
68 used. Any argument is passed onto \"New Line\"."
69 (let ((point (current-point))
70 (prefix (value fill-prefix)))
71 (delete-horizontal-space point)
72 (new-line-command p)
73 (if prefix
74 (insert-string point prefix)
75 (funcall (value indent-function) point))))
76
77
78 (defcommand "Indent" (p)
79 "Invokes function held by the Hemlock variable \"Indent Function\",
80 moving point past region if called with argument."
81 "Invokes function held by the Hemlock variable \"Indent Function\"
82 moving point past region if called with argument."
83 (let ((point (current-point)))
84 (with-mark ((mark point :left-inserting))
85 (cond ((or (not p) (zerop p))
86 (funcall (value indent-function) mark))
87 (t
88 (if (plusp p)
89 (unless (line-offset point (1- p))
90 (buffer-end point))
91 (unless (line-offset mark (1+ p))
92 (buffer-start mark)))
93 (indent-region-for-commands (region mark point))
94 (find-attribute (line-start point) :whitespace #'zerop))))))
95
96 (defcommand "Indent Region" (p)
97 "Invokes function held by Hemlock variable \"Indent Function\" on every
98 line between point and mark, inclusively."
99 "Invokes function held by Hemlock variable \"Indent Function\" on every
100 line between point and mark, inclusively."
101 (declare (ignore p))
102 (let* ((region (current-region)))
103 (with-mark ((start (region-start region) :left-inserting)
104 (end (region-end region) :left-inserting))
105 (indent-region-for-commands (region start end)))))
106
107 (defun indent-region-for-commands (region)
108 "Indents region undoably with INDENT-REGION."
109 (let* ((start (region-start region))
110 (end (region-end region))
111 (undo-region (copy-region (region (line-start start) (line-end end)))))
112 (indent-region region)
113 (make-region-undo :twiddle "Indent"
114 (region (line-start (copy-mark start :left-inserting))
115 (line-end (copy-mark end :right-inserting)))
116 undo-region)))
117
118 (defun indent-region (region)
119 "Invokes function held by Hemlock variable \"Indent Function\" on every
120 line of region."
121 (let ((indent-function (value indent-function)))
122 (with-mark ((start (region-start region) :left-inserting)
123 (end (region-end region)))
124 (line-start start)
125 (line-start end)
126 (loop (when (mark= start end)
127 (funcall indent-function start)
128 (return))
129 (funcall indent-function start)
130 (line-offset start 1 0)))))
131
132 (defcommand "Center Line" (p)
133 "Centers current line using \"Fill Column\". If an argument is supplied,
134 it is used instead of the \"Fill Column\"."
135 "Centers current line using fill-column."
136 (let* ((indent-function (value indent-with-tabs))
137 (region (if (region-active-p)
138 (current-region)
139 (region (current-point) (current-point))))
140 (end (region-end region)))
141 (with-mark ((temp (region-start region) :left-inserting))
142 (loop
143 (when (mark> temp end) (return))
144 (delete-horizontal-space (line-end temp))
145 (delete-horizontal-space (line-start temp))
146 (let* ((len (line-length (mark-line temp)))
147 (spaces (- (or p (value fill-column)) len)))
148 (if (and (plusp spaces)
149 (not (zerop len)))
150 (funcall indent-function temp (ceiling spaces 2)))
151 (unless (line-offset temp 1) (return))
152 (line-start temp))))))
153
154
155 (defcommand "Quote Tab" (p)
156 "Insert tab character."
157 "Insert tab character."
158 (if (and p (> p 1))
159 (insert-string (current-point) (make-string p :initial-element #\tab))
160 (insert-character (current-point) #\tab)))
161
162
163 (defcommand "Open Line" (p)
164 "Inserts a newline into the buffer without moving the point."
165 "Inserts a newline into the buffer without moving the point.
166 With argument, inserts p newlines."
167 (let ((point (current-point))
168 (count (if p p 1)))
169 (if (not (minusp count))
170 (dotimes (i count)
171 (insert-character point #\newline)
172 (mark-before point))
173 (editor-error))))
174
175
176 (defcommand "New Line" (p)
177 "Moves the point to a new blank line.
178 A newline is inserted if the next two lines are not already blank.
179 With an argument, repeats p times."
180 "Moves the point to a new blank line."
181 (let ((point (current-point))
182 (count (if p p 1)))
183 (if (not (minusp count))
184 (do* ((next (line-next (mark-line point))
185 (line-next (mark-line point)))
186 (i 1 (1+ i)))
187 ((> i count))
188 (cond ((and (blank-after-p point)
189 next (blank-line-p next)
190 (let ((after (line-next next)))
191 (or (not after) (blank-line-p after))))
192 (line-start point next)
193 (let ((len (line-length next)))
194 (unless (zerop len)
195 (delete-characters point len))))
196 (t
197 (insert-character point #\newline))))
198 (editor-error))))
199
200
201 (defattribute "Space"
202 "This attribute is used by the indentation commands to determine which
203 characters are treated as space."
204 '(mod 2) 0)
205
206 (setf (character-attribute :space #\space) 1)
207 (setf (character-attribute :space #\tab) 1)
208
209 (defun delete-horizontal-space (mark)
210 "Deletes all :space characters on either side of mark."
211 (with-mark ((start mark))
212 (reverse-find-attribute start :space #'zerop)
213 (find-attribute mark :space #'zerop)
214 (delete-region (region start mark))))
215
216
217
218 (defcommand "Delete Indentation" (p)
219 "Join current line with the previous one, deleting excess whitespace.
220 All whitespace is replaced with a single space, unless it is at the beginning
221 of a line, immmediately following a \"(\", or immediately preceding a \")\",
222 in which case the whitespace is merely deleted. If the preceeding character
223 is a sentence terminator, two spaces are left instead of one. If a prefix
224 argument is given, the following line is joined with the current line."
225 "Join current line with the previous one, deleting excess whitespace."
226 (with-mark ((m (current-point) :right-inserting))
227 (when p (line-offset m 1))
228 (line-start m)
229 (unless (delete-characters m -1) (editor-error "No previous line."))
230 (delete-horizontal-space m)
231 (let ((prev (previous-character m)))
232 (when (and prev (char/= prev #\newline))
233 (cond ((not (zerop (character-attribute :sentence-terminator prev)))
234 (insert-string m " "))
235 ((not (or (eq (character-attribute :lisp-syntax prev) :open-paren)
236 (eq (character-attribute :lisp-syntax (next-character m))
237 :close-paren)))
238 (insert-character m #\space)))))))
239
240
241 (defcommand "Delete Horizontal Space" (p)
242 "Delete spaces and tabs surrounding the point."
243 "Delete spaces and tabs surrounding the point."
244 (declare (ignore p))
245 (delete-horizontal-space (current-point)))
246
247 (defcommand "Just One Space" (p)
248 "Leave one space.
249 Surrounding space is deleted, and then one space is inserted.
250 with prefix argument insert that number of spaces."
251 "Delete surrounding space and insert P spaces."
252 (let ((point (current-point)))
253 (delete-horizontal-space point)
254 (dotimes (i (or p 1)) (insert-character point #\space))))
255
256 (defcommand "Back to Indentation" (p)
257 "Move point to the first non-whitespace character on the line."
258 "Move point to the first non-whitespace character on the line."
259 (declare (ignore p))
260 (let ((point (current-point)))
261 (line-start point)
262 (find-attribute point :whitespace #'zerop)))
263
264 (defcommand "Indent Rigidly" (p)
265 "Indent the region rigidly by p spaces.
266 Each line in the region is moved p spaces to the right (left if p is
267 negative). When moving a line to the left, tabs are converted to spaces."
268 "Indent the region rigidly p spaces to the right (left if p is negative)."
269 (let ((p (or p (value spaces-per-tab)))
270 (region (current-region)))
271 (with-mark ((mark1 (region-start region) :left-inserting)
272 (mark2 (region-end region) :left-inserting))
273 (line-start mark1)
274 (line-start mark2)
275 (do ()
276 ((mark= mark1 mark2))
277 (cond ((empty-line-p mark1))
278 ((blank-after-p mark1)
279 (delete-characters mark1 (line-length (mark-line mark1))))
280 (t (find-attribute mark1 :whitespace #'zerop)
281 (let ((new-column (+ p (mark-column mark1))))
282 (delete-characters mark1 (- (mark-charpos mark1)))
283 (if (plusp new-column)
284 (funcall (value indent-with-tabs) mark1 new-column)))))
285 (line-offset mark1 1 0)))))

  ViewVC Help
Powered by ViewVC 1.1.5