annotate lisp/forms.el @ 17846:c427501449a1

(display_text_line): Move the code to fill out the line with the newline's face to the end of the newline code. Add changes (commented out) to record ellipsis positions in charstarts.
author Richard M. Stallman <rms@gnu.org>
date Fri, 16 May 1997 07:32:59 +0000
parents 6bd77cce44a6
children 2df40b8771ac
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
13337
84acc3adcd63 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 13317
diff changeset
1 ;;; forms.el --- Forms mode: edit a file as a form to fill in
84acc3adcd63 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 13317
diff changeset
2
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
3 ;; Copyright (C) 1991, 1994, 1995, 1996 Free Software Foundation, Inc.
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
4
13317
877d62af45a9 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 12847
diff changeset
5 ;; Author: Johan Vromans <jvromans@squirrel.nl>
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
6
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
7 ;; This file is part of GNU Emacs.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
8
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
9 ;; GNU Emacs is free software; you can redistribute it and/or modify
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
10 ;; it under the terms of the GNU General Public License as published by
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
11 ;; the Free Software Foundation; either version 2, or (at your option)
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
12 ;; any later version.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
13
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
14 ;; GNU Emacs is distributed in the hope that it will be useful,
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
15 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
16 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
17 ;; GNU General Public License for more details.
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
18
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
19 ;; You should have received a copy of the GNU General Public License
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
20 ;; along with GNU Emacs; see the file COPYING. If not, write to the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
21 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
22 ;; Boston, MA 02111-1307, USA.
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
23
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
24 ;;; Commentary:
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
25
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
26 ;; Visit a file using a form.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
27 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
28 ;; === Naming conventions
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
29 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
30 ;; The names of all variables and functions start with 'forms-'.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
31 ;; Names which start with 'forms--' are intended for internal use, and
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
32 ;; should *NOT* be used from the outside.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
33 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
34 ;; All variables are buffer-local, to enable multiple forms visits
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
35 ;; simultaneously.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
36 ;; Variable `forms--mode-setup' is local to *ALL* buffers, for it
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
37 ;; controls if forms-mode has been enabled in a buffer.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
38 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
39 ;; === How it works ===
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
40 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
41 ;; Forms mode means visiting a data file which is supposed to consist
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
42 ;; of records each containing a number of fields. The records are
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
43 ;; separated by a newline, the fields are separated by a user-defined
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
44 ;; field separator (default: TAB).
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
45 ;; When shown, a record is transferred to an Emacs buffer and
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
46 ;; presented using a user-defined form. One record is shown at a
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
47 ;; time.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
48 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
49 ;; Forms mode is a composite mode. It involves two files, and two
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
50 ;; buffers.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
51 ;; The first file, called the control file, defines the name of the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
52 ;; data file and the forms format. This file buffer will be used to
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
53 ;; present the forms.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
54 ;; The second file holds the actual data. The buffer of this file
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
55 ;; will be buried, for it is never accessed directly.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
56 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
57 ;; Forms mode is invoked using M-x forms-find-file control-file .
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
58 ;; Alternatively `forms-find-file-other-window' can be used.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
59 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
60 ;; You may also visit the control file, and switch to forms mode by hand
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
61 ;; with M-x forms-mode .
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
62 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
63 ;; Automatic mode switching is supported if you specify
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
64 ;; "-*- forms -*-" in the first line of the control file.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
65 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
66 ;; The control file is visited, evaluated using `eval-current-buffer',
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
67 ;; and should set at least the following variables:
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
68 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
69 ;; forms-file [string]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
70 ;; The name of the data file.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
71 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
72 ;; forms-number-of-fields [integer]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
73 ;; The number of fields in each record.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
74 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
75 ;; forms-format-list [list]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
76 ;; Formatting instructions.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
77 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
78 ;; `forms-format-list' should be a list, each element containing
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
79 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
80 ;; - a string, e.g. "hello". The string is inserted in the forms
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
81 ;; "as is".
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
82 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
83 ;; - an integer, denoting a field number.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
84 ;; The contents of this field are inserted at this point.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
85 ;; Fields are numbered starting with number one.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
86 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
87 ;; - a function call, e.g. (insert "text").
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
88 ;; This function call is dynamically evaluated and should return a
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
89 ;; string. It should *NOT* have side-effects on the forms being
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
90 ;; constructed. The current fields are available to the function
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
91 ;; in the variable `forms-fields', they should *NOT* be modified.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
92 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
93 ;; - a lisp symbol, that must evaluate to one of the above.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
94 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
95 ;; Optional variables which may be set in the control file:
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
96 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
97 ;; forms-field-sep [string, default TAB]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
98 ;; The field separator used to separate the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
99 ;; fields in the data file. It may be a string.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
100 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
101 ;; forms-read-only [bool, default nil]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
102 ;; Non-nil means that the data file is visited
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
103 ;; read-only (view mode) as opposed to edit mode.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
104 ;; If no write access to the data file is
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
105 ;; possible, view mode is enforced.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
106 ;;
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
107 ;; forms-check-number-of-fields [bool, default t]
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
108 ;; If non-nil, a warning will be issued whenever
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
109 ;; a record is found that does not have the number
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
110 ;; of fields specified by `forms-number-of-fields'.
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
111 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
112 ;; forms-multi-line [string, default "^K"]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
113 ;; If non-null the records of the data file may
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
114 ;; contain fields that can span multiple lines in
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
115 ;; the form.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
116 ;; This variable denotes the separator character
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
117 ;; to be used for this purpose. Upon display, all
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
118 ;; occurrences of this character are translated
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
119 ;; to newlines. Upon storage they are translated
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
120 ;; back to the separator character.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
121 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
122 ;; forms-forms-scroll [bool, default nil]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
123 ;; Non-nil means: rebind locally the commands that
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
124 ;; perform `scroll-up' or `scroll-down' to use
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
125 ;; `forms-next-field' resp. `forms-prev-field'.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
126 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
127 ;; forms-forms-jump [bool, default nil]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
128 ;; Non-nil means: rebind locally the commands that
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
129 ;;
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
130 ;; forms-insert-after [bool, default nil]
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
131 ;; Non-nil means: inserts of new records go after
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
132 ;; current record, also initial position is at last
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
133 ;; record.
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
134 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
135 ;; forms-read-file-filter [symbol, default nil]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
136 ;; If not nil: this should be the name of a
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
137 ;; function that is called after the forms data file
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
138 ;; has been read. It can be used to transform
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
139 ;; the contents of the file into a format more suitable
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
140 ;; for forms-mode processing.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
141 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
142 ;; forms-write-file-filter [symbol, default nil]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
143 ;; If not nil: this should be the name of a
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
144 ;; function that is called before the forms data file
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
145 ;; is written (saved) to disk. It can be used to undo
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
146 ;; the effects of `forms-read-file-filter', if any.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
147 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
148 ;; forms-new-record-filter [symbol, default nil]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
149 ;; If not nil: this should be the name of a
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
150 ;; function that is called when a new
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
151 ;; record is created. It can be used to fill in
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
152 ;; the new record with default fields, for example.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
153 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
154 ;; forms-modified-record-filter [symbol, default nil]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
155 ;; If not nil: this should be the name of a
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
156 ;; function that is called when a record has
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
157 ;; been modified. It is called after the fields
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
158 ;; are parsed. It can be used to register
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
159 ;; modification dates, for example.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
160 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
161 ;; forms-use-text-properties [bool, see text for default]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
162 ;; This variable controls if forms mode should use
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
163 ;; text properties to protect the form text from being
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
164 ;; modified (using text-property `read-only').
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
165 ;; Also, the read-write fields are shown using a
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
166 ;; distinct face, if possible.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
167 ;; As of emacs 19.29, the `intangible' text property
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
168 ;; is used to prevent moving into read-only fields.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
169 ;; This variable defaults to t if running Emacs 19
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
170 ;; with text properties.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
171 ;; The default face to show read-write fields is
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
172 ;; copied from face `region'.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
173 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
174 ;; forms-ro-face [symbol, default 'default]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
175 ;; This is the face that is used to show
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
176 ;; read-only text on the screen.If used, this
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
177 ;; variable should be set to a symbol that is a
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
178 ;; valid face.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
179 ;; E.g.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
180 ;; (make-face 'my-face)
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
181 ;; (setq forms-ro-face 'my-face)
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
182 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
183 ;; forms-rw-face [symbol, default 'region]
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
184 ;; This is the face that is used to show
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
185 ;; read-write text on the screen.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
186 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
187 ;; After evaluating the control file, its buffer is cleared and used
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
188 ;; for further processing.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
189 ;; The data file (as designated by `forms-file') is visited in a buffer
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
190 ;; `forms--file-buffer' which will not normally be shown.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
191 ;; Great malfunctioning may be expected if this file/buffer is modified
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
192 ;; outside of this package while it is being visited!
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
193 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
194 ;; Normal operation is to transfer one line (record) from the data file,
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
195 ;; split it into fields (into `forms--the-record-list'), and display it
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
196 ;; using the specs in `forms-format-list'.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
197 ;; A format routine `forms--format' is built upon startup to format
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
198 ;; the records according to `forms-format-list'.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
199 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
200 ;; When a form is changed the record is updated as soon as this form
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
201 ;; is left. The contents of the form are parsed using information
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
202 ;; obtained from `forms-format-list', and the fields which are
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
203 ;; deduced from the form are modified. Fields not shown on the forms
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
204 ;; retain their original values. The newly formed record then
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
205 ;; replaces the contents of the old record in `forms--file-buffer'.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
206 ;; A parse routine `forms--parser' is built upon startup to parse
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
207 ;; the records.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
208 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
209 ;; Two exit functions exist: `forms-exit' and `forms-exit-no-save'.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
210 ;; `forms-exit' saves the data to the file, if modified.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
211 ;; `forms-exit-no-save` does not. However, if `forms-exit-no-save'
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
212 ;; is executed and the file buffer has been modified, Emacs will ask
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
213 ;; questions anyway.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
214 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
215 ;; Other functions provided by forms mode are:
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
216 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
217 ;; paging (forward, backward) by record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
218 ;; jumping (first, last, random number)
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
219 ;; searching
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
220 ;; creating and deleting records
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
221 ;; reverting the form (NOT the file buffer)
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
222 ;; switching edit <-> view mode v.v.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
223 ;; jumping from field to field
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
224 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
225 ;; As an documented side-effect: jumping to the last record in the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
226 ;; file (using forms-last-record) will adjust forms--total-records if
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
227 ;; needed.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
228 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
229 ;; The forms buffer can be in on eof two modes: edit mode or view
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
230 ;; mode. View mode is a read-only mode, you cannot modify the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
231 ;; contents of the buffer.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
232 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
233 ;; Edit mode commands:
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
234 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
235 ;; TAB forms-next-field
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
236 ;; \C-c TAB forms-next-field
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
237 ;; \C-c < forms-first-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
238 ;; \C-c > forms-last-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
239 ;; \C-c ? describe-mode
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
240 ;; \C-c \C-k forms-delete-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
241 ;; \C-c \C-q forms-toggle-read-only
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
242 ;; \C-c \C-o forms-insert-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
243 ;; \C-c \C-l forms-jump-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
244 ;; \C-c \C-n forms-next-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
245 ;; \C-c \C-p forms-prev-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
246 ;; \C-c \C-r forms-search-backward
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
247 ;; \C-c \C-s forms-search-forward
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
248 ;; \C-c \C-x forms-exit
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
249 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
250 ;; Read-only mode commands:
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
251 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
252 ;; SPC forms-next-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
253 ;; DEL forms-prev-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
254 ;; ? describe-mode
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
255 ;; \C-q forms-toggle-read-only
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
256 ;; l forms-jump-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
257 ;; n forms-next-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
258 ;; p forms-prev-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
259 ;; r forms-search-backward
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
260 ;; s forms-search-forward
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
261 ;; x forms-exit
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
262 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
263 ;; Of course, it is also possible to use the \C-c prefix to obtain the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
264 ;; same command keys as in edit mode.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
265 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
266 ;; The following bindings are available, independent of the mode:
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
267 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
268 ;; [next] forms-next-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
269 ;; [prior] forms-prev-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
270 ;; [begin] forms-first-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
271 ;; [end] forms-last-record
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
272 ;; [S-TAB] forms-prev-field
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
273 ;; [backtab] forms-prev-field
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
274 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
275 ;; For convenience, TAB is always bound to `forms-next-field', so you
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
276 ;; don't need the C-c prefix for this command.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
277 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
278 ;; As mentioned above (see `forms-forms-scroll' and `forms-forms-jump')
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
279 ;; the bindings of standard functions `scroll-up', `scroll-down',
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
280 ;; `beginning-of-buffer' and `end-of-buffer' can be locally replaced with
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
281 ;; forms mode functions next/prev record and first/last
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
282 ;; record.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
283 ;;
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
284 ;; `local-write-file hook' is defined to save the actual data file
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
285 ;; instead of the buffer data, `revert-file-hook' is defined to
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13984
diff changeset
286 ;; revert a forms to original.
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
287
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
288 ;;; Code:
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
289
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
290 ;;; Global variables and constants:
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
291
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
292 (provide 'forms) ;;; official
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
293 (provide 'forms-mode) ;;; for compatibility
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
294
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
295 (defconst forms-version (substring "$Revision: 2.20 $" 11 -2)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
296 "The version number of forms-mode (as string). The complete RCS id is:
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
297
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
298 $Id: forms.el,v 2.20 1996/03/01 20:31:29 jv Exp $")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
299
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
300 (defvar forms-mode-hooks nil
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
301 "Hook functions to be run upon entering Forms mode.")
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
302
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
303 ;;; Mandatory variables - must be set by evaluating the control file.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
304
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
305 (defvar forms-file nil
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
306 "Name of the file holding the data.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
307
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
308 (defvar forms-format-list nil
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
309 "List of formatting specifications.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
310
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
311 (defvar forms-number-of-fields nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
312 "Number of fields per record.")
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
313
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
314 ;;; Optional variables with default values.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
315
12847
61961ca01260 (forms-check-number-of-fields): New vbl.
Richard M. Stallman <rms@gnu.org>
parents: 12508
diff changeset
316 (defvar forms-check-number-of-fields t
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
317 "*If non-nil, warn about records with wrong number of fields.")
12847
61961ca01260 (forms-check-number-of-fields): New vbl.
Richard M. Stallman <rms@gnu.org>
parents: 12508
diff changeset
318
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
319 (defvar forms-field-sep "\t"
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
320 "Field separator character (default TAB).")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
321
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
322 (defvar forms-read-only nil
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
323 "Non-nil means: visit the file in view (read-only) mode.
7639
67b7d1ea7b2e Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 7381
diff changeset
324 \(Defaults to the write access on the data file).")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
325
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
326 (defvar forms-multi-line "\C-k"
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
327 "If not nil: use this character to separate multi-line fields (default C-k).")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
328
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
329 (defvar forms-forms-scroll nil
3828
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
330 "*Non-nil means replace scroll-up/down commands in Forms mode.
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
331 The replacement commands performs forms-next/prev-record.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
332
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
333 (defvar forms-forms-jump nil
3828
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
334 "*Non-nil means redefine beginning/end-of-buffer in Forms mode.
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
335 The replacement commands performs forms-first/last-record.")
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
336
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
337 (defvar forms-read-file-filter nil
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
338 "The name of a function that is called after reading the data file.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
339 This can be used to change the contents of the file to something more
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
340 suitable for forms processing.")
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
341
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
342 (defvar forms-write-file-filter nil
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
343 "The name of a function that is called before writing the data file.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
344 This can be used to undo the effects of form-read-file-hook.")
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
345
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
346 (defvar forms-new-record-filter nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
347 "The name of a function that is called when a new record is created.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
348
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
349 (defvar forms-modified-record-filter nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
350 "The name of a function that is called when a record has been modified.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
351
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
352 (defvar forms-fields nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
353 "List with fields of the current forms. First field has number 1.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
354 This variable is for use by the filter routines only.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
355 The contents may NOT be modified.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
356
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
357 (defvar forms-use-text-properties (fboundp 'set-text-properties)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
358 "*Non-nil means: use emacs-19 text properties.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
359 Defaults to t if this emacs is capable of handling text properties.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
360
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
361 (defvar forms-insert-after nil
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
362 "*Non-nil means: inserts of new records go after current record.
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
363 Also, initial position is at last record.")
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
364
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
365 (defvar forms-ro-face 'default
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
366 "The face (a symbol) that is used to display read-only text on the screen.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
367
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
368 (defvar forms-rw-face 'region
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
369 "The face (a symbol) that is used to display read-write text on the screen.")
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
370
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
371 ;;; Internal variables.
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
372
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
373 (defvar forms--file-buffer nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
374 "Buffer which holds the file data")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
375
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
376 (defvar forms--total-records 0
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
377 "Total number of records in the data file.")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
378
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
379 (defvar forms--current-record 0
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
380 "Number of the record currently on the screen.")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
381
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
382 (defvar forms-mode-map nil
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
383 "Keymap for form buffer.")
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
384 (defvar forms-mode-ro-map nil
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
385 "Keymap for form buffer in view mode.")
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
386 (defvar forms-mode-edit-map nil
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
387 "Keymap for form buffer in edit mode.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
388
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
389 (defvar forms--markers nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
390 "Field markers in the screen.")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
391
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
392 (defvar forms--dyntexts nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
393 "Dynamic texts (resulting from function calls) on the screen.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
394
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
395 (defvar forms--the-record-list nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
396 "List of strings of the current record, as parsed from the file.")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
397
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
398 (defvar forms--search-regexp nil
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
399 "Last regexp used by forms-search functions.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
400
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
401 (defvar forms--format nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
402 "Formatting routine.")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
403
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
404 (defvar forms--parser nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
405 "Forms parser routine.")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
406
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
407 (defvar forms--mode-setup nil
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
408 "To keep track of forms-mode being set-up.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
409 (make-variable-buffer-local 'forms--mode-setup)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
410
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
411 (defvar forms--dynamic-text nil
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
412 "Array that holds dynamic texts to insert between fields.")
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
413
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
414 (defvar forms--elements nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
415 "Array with the order in which the fields are displayed.")
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
416
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
417 (defvar forms--ro-face nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
418 "Face used to represent read-only data on the screen.")
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
419
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
420 (defvar forms--rw-face nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
421 "Face used to represent read-write data on the screen.")
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
422
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
423 ;;;###autoload
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
424 (defun forms-mode (&optional primary)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
425 "Major mode to visit files in a field-structured manner using a form.
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
426
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
427 Commands: Equivalent keys in read-only mode:
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
428 TAB forms-next-field TAB
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
429 \\C-c TAB forms-next-field
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
430 \\C-c < forms-first-record <
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
431 \\C-c > forms-last-record >
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
432 \\C-c ? describe-mode ?
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
433 \\C-c \\C-k forms-delete-record
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
434 \\C-c \\C-q forms-toggle-read-only q
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
435 \\C-c \\C-o forms-insert-record
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
436 \\C-c \\C-l forms-jump-record l
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
437 \\C-c \\C-n forms-next-record n
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
438 \\C-c \\C-p forms-prev-record p
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
439 \\C-c \\C-r forms-search-reverse r
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
440 \\C-c \\C-s forms-search-forward s
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
441 \\C-c \\C-x forms-exit x
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
442 "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
443 (interactive)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
444
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
445 ;; This is not a simple major mode, as usual. Therefore, forms-mode
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
446 ;; takes an optional argument `primary' which is used for the
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
447 ;; initial set-up. Normal use would leave `primary' to nil.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
448 ;; A global buffer-local variable `forms--mode-setup' has the same
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
449 ;; effect but makes it possible to auto-invoke forms-mode using
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
450 ;; `find-file'.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
451 ;; Note: although it seems logical to have `make-local-variable'
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
452 ;; executed where the variable is first needed, I have deliberately
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
453 ;; placed all calls in this function.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
454
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
455 ;; Primary set-up: evaluate buffer and check if the mandatory
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
456 ;; variables have been set.
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
457 (if (or primary (not forms--mode-setup))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
458 (progn
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
459 ;;(message "forms: setting up...")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
460 (kill-all-local-variables)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
461
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
462 ;; Make mandatory variables.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
463 (make-local-variable 'forms-file)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
464 (make-local-variable 'forms-number-of-fields)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
465 (make-local-variable 'forms-format-list)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
466
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
467 ;; Make optional variables.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
468 (make-local-variable 'forms-field-sep)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
469 (make-local-variable 'forms-read-only)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
470 (make-local-variable 'forms-multi-line)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
471 (make-local-variable 'forms-forms-scroll)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
472 (make-local-variable 'forms-forms-jump)
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
473 (make-local-variable 'forms-insert-after)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
474 (make-local-variable 'forms-use-text-properties)
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
475
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
476 ;; Filter functions.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
477 (make-local-variable 'forms-read-file-filter)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
478 (make-local-variable 'forms-write-file-filter)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
479 (make-local-variable 'forms-new-record-filter)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
480 (make-local-variable 'forms-modified-record-filter)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
481
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
482 ;; Make sure no filters exist.
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
483 (setq forms-read-file-filter nil)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
484 (setq forms-write-file-filter nil)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
485 (setq forms-new-record-filter nil)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
486 (setq forms-modified-record-filter nil)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
487
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
488 ;; If running Emacs 19 under X, setup faces to show read-only and
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
489 ;; read-write fields.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
490 (if (fboundp 'make-face)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
491 (progn
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
492 (make-local-variable 'forms-ro-face)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
493 (make-local-variable 'forms-rw-face)))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
494
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
495 ;; eval the buffer, should set variables
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
496 ;;(message "forms: processing control file...")
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
497 ;; If enable-local-eval is not set to t the user is asked first.
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
498 (if (or (eq enable-local-eval t)
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
499 (yes-or-no-p
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
500 (concat "Evaluate lisp code in buffer "
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
501 (buffer-name) " to display forms ")))
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
502 (eval-current-buffer)
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
503 (error "`enable-local-eval' inhibits buffer evaluation"))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
504
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
505 ;; Check if the mandatory variables make sense.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
506 (or forms-file
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
507 (error (concat "Forms control file error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
508 "'forms-file' has not been set")))
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
509
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
510 ;; Check forms-field-sep first, since it can be needed to
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
511 ;; construct a default format list.
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
512 (or (stringp forms-field-sep)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
513 (error (concat "Forms control file error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
514 "'forms-field-sep' is not a string")))
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
515
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
516 (if forms-number-of-fields
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
517 (or (and (numberp forms-number-of-fields)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
518 (> forms-number-of-fields 0))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
519 (error (concat "Forms control file error: "
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
520 "'forms-number-of-fields' must be a number > 0")))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
521 (or (null forms-format-list)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
522 (error (concat "Forms control file error: "
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
523 "'forms-number-of-fields' has not been set"))))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
524
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
525 (or forms-format-list
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
526 (forms--intuit-from-file))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
527
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
528 (if forms-multi-line
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
529 (if (and (stringp forms-multi-line)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
530 (eq (length forms-multi-line) 1))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
531 (if (string= forms-multi-line forms-field-sep)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
532 (error (concat "Forms control file error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
533 "'forms-multi-line' is equal to 'forms-field-sep'")))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
534 (error (concat "Forms control file error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
535 "'forms-multi-line' must be nil or a one-character string"))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
536 (or (fboundp 'set-text-properties)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
537 (setq forms-use-text-properties nil))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
538
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
539 ;; Validate and process forms-format-list.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
540 ;;(message "forms: pre-processing format list...")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
541 (forms--process-format-list)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
542
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
543 ;; Build the formatter and parser.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
544 ;;(message "forms: building formatter...")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
545 (make-local-variable 'forms--format)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
546 (make-local-variable 'forms--markers)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
547 (make-local-variable 'forms--dyntexts)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
548 (make-local-variable 'forms--elements)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
549 ;;(message "forms: building parser...")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
550 (forms--make-format)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
551 (make-local-variable 'forms--parser)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
552 (forms--make-parser)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
553 ;;(message "forms: building parser... done.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
554
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
555 ;; Check if record filters are defined.
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
556 (if (and forms-new-record-filter
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
557 (not (fboundp forms-new-record-filter)))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
558 (error (concat "Forms control file error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
559 "'forms-new-record-filter' is not a function")))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
560
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
561 (if (and forms-modified-record-filter
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
562 (not (fboundp forms-modified-record-filter)))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
563 (error (concat "Forms control file error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
564 "'forms-modified-record-filter' is not a function")))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
565
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
566 ;; The filters acces the contents of the forms using `forms-fields'.
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
567 (make-local-variable 'forms-fields)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
568
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
569 ;; Dynamic text support.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
570 (make-local-variable 'forms--dynamic-text)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
571
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
572 ;; Prevent accidental overwrite of the control file and autosave.
7381
9e7dd6d12e1f (forms-mode): Set visited file name to nil to prevent overwrite and autosave.
Karl Heuer <kwzh@gnu.org>
parents: 6561
diff changeset
573 (set-visited-file-name nil)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
574
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
575 ;; Prepare this buffer for further processing.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
576 (setq buffer-read-only nil)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
577 (erase-buffer)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
578
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
579 ;;(message "forms: setting up... done.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
580 ))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
581
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
582 ;; initialization done
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
583 (setq forms--mode-setup t)
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
584
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
585 ;; Copy desired faces to the actual variables used by the forms formatter.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
586 (if (fboundp 'make-face)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
587 (progn
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
588 (make-local-variable 'forms--ro-face)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
589 (make-local-variable 'forms--rw-face)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
590 (if forms-read-only
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
591 (progn
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
592 (setq forms--ro-face forms-ro-face)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
593 (setq forms--rw-face forms-ro-face))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
594 (setq forms--ro-face forms-ro-face)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
595 (setq forms--rw-face forms-rw-face))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
596
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
597 ;; Make more local variables.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
598 (make-local-variable 'forms--file-buffer)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
599 (make-local-variable 'forms--total-records)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
600 (make-local-variable 'forms--current-record)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
601 (make-local-variable 'forms--the-record-list)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
602 (make-local-variable 'forms--search-regexp)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
603
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
604 ; The keymaps are global, so multiple forms mode buffers can share them.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
605 ;(make-local-variable 'forms-mode-map)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
606 ;(make-local-variable 'forms-mode-ro-map)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
607 ;(make-local-variable 'forms-mode-edit-map)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
608 (if forms-mode-map ; already defined
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
609 nil
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
610 ;;(message "forms: building keymap...")
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
611 (forms--mode-commands)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
612 ;;(message "forms: building keymap... done.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
613 )
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
614
6561
eafeaeff6fa5 (forms-mode): Set major mode before finding forms-file. (This gives
Karl Heuer <kwzh@gnu.org>
parents: 4867
diff changeset
615 ;; set the major mode indicator
eafeaeff6fa5 (forms-mode): Set major mode before finding forms-file. (This gives
Karl Heuer <kwzh@gnu.org>
parents: 4867
diff changeset
616 (setq major-mode 'forms-mode)
eafeaeff6fa5 (forms-mode): Set major mode before finding forms-file. (This gives
Karl Heuer <kwzh@gnu.org>
parents: 4867
diff changeset
617 (setq mode-name "Forms")
eafeaeff6fa5 (forms-mode): Set major mode before finding forms-file. (This gives
Karl Heuer <kwzh@gnu.org>
parents: 4867
diff changeset
618
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
619 ;; find the data file
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
620 (setq forms--file-buffer (find-file-noselect forms-file))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
621
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
622 ;; Pre-transform.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
623 (let ((read-file-filter forms-read-file-filter)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
624 (write-file-filter forms-write-file-filter))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
625 (if read-file-filter
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
626 (save-excursion
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
627 (set-buffer forms--file-buffer)
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
628 (let ((inhibit-read-only t)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
629 (file-modified (buffer-modified-p)))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
630 (run-hooks 'read-file-filter)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
631 (if (not file-modified) (set-buffer-modified-p nil)))
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
632 (if write-file-filter
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
633 (progn
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
634 (make-variable-buffer-local 'local-write-file-hooks)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
635 (setq local-write-file-hooks (list write-file-filter)))))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
636 (if write-file-filter
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
637 (save-excursion
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
638 (set-buffer forms--file-buffer)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
639 (make-variable-buffer-local 'local-write-file-hooks)
12508
2b4958c6268a (forms-mode): treat local-write-file-hooks as a list.
Johan Vromans <jvromans@squirrel.nl>
parents: 12303
diff changeset
640 (setq local-write-file-hooks (list write-file-filter))))))
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
641
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
642 ;; count the number of records, and set see if it may be modified
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
643 (let (ro)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
644 (setq forms--total-records
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
645 (save-excursion
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
646 (prog1
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
647 (progn
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
648 ;;(message "forms: counting records...")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
649 (set-buffer forms--file-buffer)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
650 (bury-buffer (current-buffer))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
651 (setq ro buffer-read-only)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
652 (count-lines (point-min) (point-max)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
653 ;;(message "forms: counting records... done.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
654 )))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
655 (if ro
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
656 (setq forms-read-only t)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
657
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
658 ;;(message "forms: proceeding setup...")
4867
3349947f33e6 (forms--set-minor-mode): Rewrite so that describe-mode
Richard M. Stallman <rms@gnu.org>
parents: 4790
diff changeset
659
3349947f33e6 (forms--set-minor-mode): Rewrite so that describe-mode
Richard M. Stallman <rms@gnu.org>
parents: 4790
diff changeset
660 ;; Since we aren't really implementing a minor mode, we hack the modeline
3349947f33e6 (forms--set-minor-mode): Rewrite so that describe-mode
Richard M. Stallman <rms@gnu.org>
parents: 4790
diff changeset
661 ;; directly to get the text " View " into forms-read-only form buffers. For
3349947f33e6 (forms--set-minor-mode): Rewrite so that describe-mode
Richard M. Stallman <rms@gnu.org>
parents: 4790
diff changeset
662 ;; that reason, this variable must be buffer only.
3349947f33e6 (forms--set-minor-mode): Rewrite so that describe-mode
Richard M. Stallman <rms@gnu.org>
parents: 4790
diff changeset
663 (make-local-variable 'minor-mode-alist)
3349947f33e6 (forms--set-minor-mode): Rewrite so that describe-mode
Richard M. Stallman <rms@gnu.org>
parents: 4790
diff changeset
664 (setq minor-mode-alist (list (list 'forms-read-only " View")))
3349947f33e6 (forms--set-minor-mode): Rewrite so that describe-mode
Richard M. Stallman <rms@gnu.org>
parents: 4790
diff changeset
665
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
666 ;;(message "forms: proceeding setup (keymaps)...")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
667 (forms--set-keymaps)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
668 ;;(message "forms: proceeding setup (commands)...")
3827
4089cf0e3f06 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 3697
diff changeset
669 (forms--change-commands)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
670
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
671 ;;(message "forms: proceeding setup (buffer)...")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
672 (set-buffer-modified-p nil)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
673
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
674 (if (= forms--total-records 0)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
675 ;;(message "forms: proceeding setup (new file)...")
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
676 (progn
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
677 (insert
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
678 "GNU Emacs Forms Mode version " forms-version "\n\n"
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
679 (if (file-exists-p forms-file)
14356
0c88041fc50a (forms-mode, forms-toggle-read-only): Fix message text.
Karl Heuer <kwzh@gnu.org>
parents: 14315
diff changeset
680 (concat "No records available in file `" forms-file "'\n\n")
0c88041fc50a (forms-mode, forms-toggle-read-only): Fix message text.
Karl Heuer <kwzh@gnu.org>
parents: 14315
diff changeset
681 (format "Creating new file `%s'\nwith %d field%s per record\n\n"
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
682 forms-file forms-number-of-fields
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
683 (if (= 1 forms-number-of-fields) "" "s")))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
684 "Use " (substitute-command-keys "\\[forms-insert-record]")
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
685 " to create new records.\n")
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
686 (setq forms--current-record 1)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
687 (setq buffer-read-only t)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
688 (set-buffer-modified-p nil))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
689
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
690 ;; setup the first (or current) record to show
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
691 (if (< forms--current-record 1)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
692 (setq forms--current-record 1))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
693 (forms-jump-record forms--current-record)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
694 )
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
695
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
696 (if forms-insert-after
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
697 (forms-last-record)
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
698 (forms-first-record))
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
699
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
700 ;; user customising
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
701 ;;(message "forms: proceeding setup (user hooks)...")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
702 (run-hooks 'forms-mode-hooks)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
703 ;;(message "forms: setting up... done.")
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
704
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
705 ;; be helpful
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
706 (forms--help)
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
707 )
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
708
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
709 (defun forms--process-format-list ()
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
710 ;; Validate `forms-format-list' and set some global variables.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
711 ;; Symbols in the list are evaluated, and consecutive strings are
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
712 ;; concatenated.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
713 ;; Array `forms--elements' is constructed that contains the order
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
714 ;; of the fields on the display. This array is used by
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
715 ;; `forms--parser-using-text-properties' to extract the fields data
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
716 ;; from the form on the screen.
13984
c045b6e55d08 (forms-toggle-read-only, forms-enumerate): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 13569
diff changeset
717 ;; Upon completion, `forms-format-list' is guaranteed correct, so
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
718 ;; `forms--make-format' and `forms--make-parser' do not need to perform
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
719 ;; any checks.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
720
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
721 ;; Verify that `forms-format-list' is not nil.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
722 (or forms-format-list
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
723 (error (concat "Forms control file error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
724 "'forms-format-list' has not been set")))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
725 ;; It must be a list.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
726 (or (listp forms-format-list)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
727 (error (concat "Forms control file error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
728 "'forms-format-list' is not a list")))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
729
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
730 ;; Assume every field is painted once.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
731 ;; `forms--elements' will grow if needed.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
732 (setq forms--elements (make-vector forms-number-of-fields nil))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
733
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
734 (let ((the-list forms-format-list) ; the list of format elements
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
735 (this-item 0) ; element in list
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
736 (prev-item nil)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
737 (field-num 0)) ; highest field number
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
738
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
739 (setq forms-format-list nil) ; gonna rebuild
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
740
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
741 (while the-list
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
742
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
743 (let ((el (car-safe the-list))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
744 (rem (cdr-safe the-list)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
745
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
746 ;; If it is a symbol, eval it first.
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
747 (if (and (symbolp el)
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
748 (boundp el))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
749 (setq el (eval el)))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
750
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
751 (cond
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
752
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
753 ;; Try string ...
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
754 ((stringp el)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
755 (if (stringp prev-item) ; try to concatenate strings
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
756 (setq prev-item (concat prev-item el))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
757 (if prev-item
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
758 (setq forms-format-list
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
759 (append forms-format-list (list prev-item) nil)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
760 (setq prev-item el)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
761
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
762 ;; Try numeric ...
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
763 ((numberp el)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
764
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
765 ;; Validate range.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
766 (if (or (<= el 0)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
767 (> el forms-number-of-fields))
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
768 (error (concat "Forms format error: "
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
769 "field number %d out of range 1..%d")
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
770 el forms-number-of-fields))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
771
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
772 ;; Store forms order.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
773 (if (> field-num (length forms--elements))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
774 (setq forms--elements (vconcat forms--elements (1- el)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
775 (aset forms--elements field-num (1- el)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
776 (setq field-num (1+ field-num))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
777
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
778 (if prev-item
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
779 (setq forms-format-list
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
780 (append forms-format-list (list prev-item) nil)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
781 (setq prev-item el))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
782
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
783 ;; Try function ...
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
784 ((listp el)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
785
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
786 ;; Validate.
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
787 (or (fboundp (car-safe el))
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
788 (error (concat "Forms format error: "
14421
319064f5de2e (forms--process-format-list): Fix error format string.
Karl Heuer <kwzh@gnu.org>
parents: 14356
diff changeset
789 "not a function %S")
319064f5de2e (forms--process-format-list): Fix error format string.
Karl Heuer <kwzh@gnu.org>
parents: 14356
diff changeset
790 (car-safe el)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
791
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
792 ;; Shift.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
793 (if prev-item
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
794 (setq forms-format-list
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
795 (append forms-format-list (list prev-item) nil)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
796 (setq prev-item el))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
797
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
798 ;; else
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
799 (t
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
800 (error (concat "Forms format error: "
14421
319064f5de2e (forms--process-format-list): Fix error format string.
Karl Heuer <kwzh@gnu.org>
parents: 14356
diff changeset
801 "invalid element %S")
319064f5de2e (forms--process-format-list): Fix error format string.
Karl Heuer <kwzh@gnu.org>
parents: 14356
diff changeset
802 el)))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
803
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
804 ;; Advance to next element of the list.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
805 (setq the-list rem)))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
806
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
807 ;; Append last item.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
808 (if prev-item
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
809 (progn
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
810 (setq forms-format-list
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
811 (append forms-format-list (list prev-item) nil))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
812 ;; Append a newline if the last item is a field.
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
813 ;; This prevents parsing problems.
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
814 ;; Also it makes it possible to insert an empty last field.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
815 (if (numberp prev-item)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
816 (setq forms-format-list
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
817 (append forms-format-list (list "\n") nil))))))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
818
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
819 (forms--debug 'forms-format-list
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
820 'forms--elements))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
821
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
822 ;; Special treatment for read-only segments.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
823 ;;
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
824 ;; If text is inserted between two read-only segments, it inherits the
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
825 ;; read-only properties. This is not what we want.
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
826 ;; To solve this, read-only segments get the `insert-in-front-hooks'
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
827 ;; property set with a function that temporarily switches the properties
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
828 ;; of the first character of the segment to read-write, so the new
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
829 ;; text gets the right properties.
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
830 ;; The `post-command-hook' is used to restore the original properties.
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
831
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
832 (defvar forms--iif-start nil
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
833 "Record start of modification command.")
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
834 (defvar forms--iif-properties nil
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
835 "Original properties of the character being overridden.")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
836
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
837 (defun forms--iif-hook (begin end)
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
838 "`insert-in-front-hooks' function for read-only segments."
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
839
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
840 ;; Note start location. By making it a marker that points one
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
841 ;; character beyond the actual location, it is guaranteed to move
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
842 ;; correctly if text is inserted.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
843 (or forms--iif-start
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
844 (setq forms--iif-start (copy-marker (1+ (point)))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
845
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
846 ;; Check if there is special treatment required.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
847 (if (or (<= forms--iif-start 2)
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
848 (get-text-property (- forms--iif-start 2)
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
849 'read-only))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
850 (progn
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
851 ;; Fetch current properties.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
852 (setq forms--iif-properties
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
853 (text-properties-at (1- forms--iif-start)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
854
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
855 ;; Replace them.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
856 (let ((inhibit-read-only t))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
857 (set-text-properties
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
858 (1- forms--iif-start) forms--iif-start
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
859 (list 'face forms--rw-face 'front-sticky '(face))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
860
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
861 ;; Enable `post-command-hook' to restore the properties.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
862 (setq post-command-hook
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
863 (append (list 'forms--iif-post-command-hook) post-command-hook)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
864
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
865 ;; No action needed. Clear marker.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
866 (setq forms--iif-start nil)))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
867
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
868 (defun forms--iif-post-command-hook ()
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
869 "`post-command-hook' function for read-only segments."
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
870
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
871 ;; Disable `post-command-hook'.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
872 (setq post-command-hook
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
873 (delq 'forms--iif-hook-post-command-hook post-command-hook))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
874
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
875 ;; Restore properties.
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
876 (if forms--iif-start
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
877 (let ((inhibit-read-only t))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
878 (set-text-properties
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
879 (1- forms--iif-start) forms--iif-start
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
880 forms--iif-properties)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
881
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
882 ;; Cleanup.
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
883 (setq forms--iif-start nil))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
884
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
885 (defvar forms--marker)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
886 (defvar forms--dyntext)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
887
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
888 (defun forms--make-format ()
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
889 "Generate `forms--format' using the information in `forms-format-list'."
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
890
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
891 ;; The real work is done using a mapcar of `forms--make-format-elt' on
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
892 ;; `forms-format-list'.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
893 ;; This function sets up the necessary environment, and decides
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
894 ;; which function to mapcar.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
895
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
896 (let ((forms--marker 0)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
897 (forms--dyntext 0))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
898 (setq
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
899 forms--format
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
900 (if forms-use-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
901 (` (lambda (arg)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
902 (let ((inhibit-read-only t))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
903 (,@ (apply 'append
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
904 (mapcar 'forms--make-format-elt-using-text-properties
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
905 forms-format-list)))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
906 ;; Prevent insertion before the first text.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
907 (,@ (if (numberp (car forms-format-list))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
908 nil
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
909 '((add-text-properties (point-min) (1+ (point-min))
11557
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
910 '(front-sticky (read-only intangible))))))
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
911 ;; Prevent insertion after the last text.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
912 (remove-text-properties (1- (point)) (point)
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
913 '(rear-nonsticky)))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
914 (setq forms--iif-start nil)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
915 (` (lambda (arg)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
916 (,@ (apply 'append
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
917 (mapcar 'forms--make-format-elt forms-format-list)))))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
918
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
919 ;; We have tallied the number of markers and dynamic texts,
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
920 ;; so we can allocate the arrays now.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
921 (setq forms--markers (make-vector forms--marker nil))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
922 (setq forms--dyntexts (make-vector forms--dyntext nil)))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
923 (forms--debug 'forms--format))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
924
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
925 (defun forms--make-format-elt-using-text-properties (el)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
926 "Helper routine to generate format function."
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
927
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
928 ;; The format routine `forms--format' will look like
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
929 ;;
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
930 ;; ;; preamble
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
931 ;; (lambda (arg)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
932 ;; (let ((inhibit-read-only t))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
933 ;;
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
934 ;; ;; A string, e.g. "text: ".
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
935 ;; (set-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
936 ;; (point)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
937 ;; (progn (insert "text: ") (point))
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
938 ;; (list 'face forms--ro-face
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
939 ;; 'read-only 1
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
940 ;; 'insert-in-front-hooks 'forms--iif-hook
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
941 ;; 'rear-nonsticky '(read-only face insert-in-front-hooks)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
942 ;;
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
943 ;; ;; A field, e.g. 6.
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
944 ;; (let ((here (point)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
945 ;; (aset forms--markers 0 (point-marker))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
946 ;; (insert (elt arg 5))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
947 ;; (or (= (point) here)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
948 ;; (set-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
949 ;; here (point)
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
950 ;; (list 'face forms--rw-face
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
951 ;; 'front-sticky '(face))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
952 ;;
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
953 ;; ;; Another string, e.g. "\nmore text: ".
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
954 ;; (set-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
955 ;; (point)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
956 ;; (progn (insert "\nmore text: ") (point))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
957 ;; (list 'face forms--ro-face
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
958 ;; 'read-only 2
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
959 ;; 'insert-in-front-hooks 'forms--iif-hook
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
960 ;; 'rear-nonsticky '(read-only face insert-in-front-hooks)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
961 ;;
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
962 ;; ;; A function, e.g. (tocol 40).
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
963 ;; (set-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
964 ;; (point)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
965 ;; (progn
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
966 ;; (insert (aset forms--dyntexts 0 (tocol 40)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
967 ;; (point))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
968 ;; (list 'face forms--ro-face
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
969 ;; 'read-only 2
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
970 ;; 'insert-in-front-hooks 'forms--iif-hook
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
971 ;; 'rear-nonsticky '(read-only face insert-in-front-hooks)))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
972 ;;
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
973 ;; ;; Prevent insertion before the first text.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
974 ;; (add-text-properties (point-min) (1+ (point-min))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
975 ;; '(front-sticky (read-only))))))
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
976 ;; ;; Prevent insertion after the last text.
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
977 ;; (remove-text-properties (1- (point)) (point)
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
978 ;; '(rear-nonsticky)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
979 ;;
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
980 ;; ;; wrap up
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
981 ;; (setq forms--iif-start nil)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
982 ;; ))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
983
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
984 (cond
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
985 ((stringp el)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
986
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
987 (` ((set-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
988 (point) ; start at point
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
989 (progn ; until after insertion
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
990 (insert (, el))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
991 (point))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
992 (list 'face forms--ro-face ; read-only appearance
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
993 'read-only (,@ (list (1+ forms--marker)))
11557
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
994 'intangible t
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
995 'insert-in-front-hooks '(forms--iif-hook)
11557
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
996 'rear-nonsticky '(face read-only insert-in-front-hooks
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
997 intangible))))))
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
998
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
999 ((numberp el)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1000 (` ((let ((here (point)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1001 (aset forms--markers
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1002 (, (prog1 forms--marker
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1003 (setq forms--marker (1+ forms--marker))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1004 (point-marker))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1005 (insert (elt arg (, (1- el))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1006 (or (= (point) here)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1007 (set-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1008 here (point)
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
1009 (list 'face forms--rw-face
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
1010 'front-sticky '(face))))))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1011
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1012 ((listp el)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1013 (` ((set-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1014 (point)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1015 (progn
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1016 (insert (aset forms--dyntexts
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1017 (, (prog1 forms--dyntext
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1018 (setq forms--dyntext (1+ forms--dyntext))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1019 (, el)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1020 (point))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1021 (list 'face forms--ro-face
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
1022 'read-only (,@ (list (1+ forms--marker)))
11557
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
1023 'intangible t
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
1024 'insert-in-front-hooks '(forms--iif-hook)
11557
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
1025 'rear-nonsticky '(read-only face insert-in-front-hooks
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
1026 intangible))))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1027
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1028 ;; end of cond
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1029 ))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1030
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1031 (defun forms--make-format-elt (el)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1032 "Helper routine to generate format function."
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1033
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1034 ;; If we're not using text properties, the format routine
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1035 ;; `forms--format' will look like
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1036 ;;
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1037 ;; (lambda (arg)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1038 ;; ;; a string, e.g. "text: "
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1039 ;; (insert "text: ")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1040 ;; ;; a field, e.g. 6
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1041 ;; (aset forms--markers 0 (point-marker))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1042 ;; (insert (elt arg 5))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1043 ;; ;; another string, e.g. "\nmore text: "
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1044 ;; (insert "\nmore text: ")
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1045 ;; ;; a function, e.g. (tocol 40)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1046 ;; (insert (aset forms--dyntexts 0 (tocol 40)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1047 ;; ... )
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1048
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1049 (cond
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1050 ((stringp el)
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1051 (` ((insert (, el)))))
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1052 ((numberp el)
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1053 (prog1
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1054 (` ((aset forms--markers (, forms--marker) (point-marker))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1055 (insert (elt arg (, (1- el))))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1056 (setq forms--marker (1+ forms--marker))))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1057 ((listp el)
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1058 (prog1
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1059 (` ((insert (aset forms--dyntexts (, forms--dyntext) (, el)))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1060 (setq forms--dyntext (1+ forms--dyntext))))))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1061
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1062 (defvar forms--field)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1063 (defvar forms--recordv)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1064 (defvar forms--seen-text)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1065
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1066 (defun forms--make-parser ()
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1067 "Generate `forms--parser' from the information in `forms-format-list'."
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1068
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1069 ;; If we can use text properties, we simply set it to
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1070 ;; `forms--parser-using-text-properties'.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1071 ;; Otherwise, the function is constructed using a mapcar of
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1072 ;; `forms--make-parser-elt on `forms-format-list'.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1073
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1074 (setq
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1075 forms--parser
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1076 (if forms-use-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1077 (function forms--parser-using-text-properties)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1078 (let ((forms--field nil)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1079 (forms--seen-text nil)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1080 (forms--dyntext 0))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1081
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1082 ;; Note: we add a nil element to the list passed to `mapcar',
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1083 ;; see `forms--make-parser-elt' for details.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1084 (` (lambda nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1085 (let (here)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1086 (goto-char (point-min))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1087 (,@ (apply 'append
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1088 (mapcar
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1089 'forms--make-parser-elt
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1090 (append forms-format-list (list nil)))))))))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1091
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1092 (forms--debug 'forms--parser))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1093
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1094 (defun forms--parser-using-text-properties ()
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1095 "Extract field info from forms when using text properties."
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1096
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1097 ;; Using text properties, we can simply jump to the markers, and
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1098 ;; extract the information up to the following read-only segment.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1099
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1100 (let ((i 0)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1101 here there)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1102 (while (< i (length forms--markers))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1103 (goto-char (setq here (aref forms--markers i)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1104 (if (get-text-property here 'read-only)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1105 (aset forms--recordv (aref forms--elements i) nil)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1106 (if (setq there
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1107 (next-single-property-change here 'read-only))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1108 (aset forms--recordv (aref forms--elements i)
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
1109 (buffer-substring-no-properties here there))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1110 (aset forms--recordv (aref forms--elements i)
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
1111 (buffer-substring-no-properties here (point-max)))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1112 (setq i (1+ i)))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1113
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1114 (defun forms--make-parser-elt (el)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1115 "Helper routine to generate forms parser function."
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1116
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1117 ;; The parse routine will look like:
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1118 ;;
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1119 ;; (lambda nil
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1120 ;; (let (here)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1121 ;; (goto-char (point-min))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1122 ;;
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1123 ;; ;; "text: "
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1124 ;; (if (not (looking-at "text: "))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1125 ;; (error "Parse error: cannot find \"text: \""))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1126 ;; (forward-char 6) ; past "text: "
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1127 ;;
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1128 ;; ;; 6
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1129 ;; ;; "\nmore text: "
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1130 ;; (setq here (point))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1131 ;; (if (not (search-forward "\nmore text: " nil t nil))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1132 ;; (error "Parse error: cannot find \"\\nmore text: \""))
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
1133 ;; (aset forms--recordv 5 (buffer-substring-no-properties here (- (point) 12)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1134 ;;
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1135 ;; ;; (tocol 40)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1136 ;; (let ((forms--dyntext (car-safe forms--dynamic-text)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1137 ;; (if (not (looking-at (regexp-quote forms--dyntext)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1138 ;; (error "Parse error: not looking at \"%s\"" forms--dyntext))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1139 ;; (forward-char (length forms--dyntext))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1140 ;; (setq forms--dynamic-text (cdr-safe forms--dynamic-text)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1141 ;; ...
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1142 ;; ;; final flush (due to terminator sentinel, see below)
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
1143 ;; (aset forms--recordv 7 (buffer-substring-no-properties (point) (point-max)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1144
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1145 (cond
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1146 ((stringp el)
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1147 (prog1
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1148 (if forms--field
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1149 (` ((setq here (point))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1150 (if (not (search-forward (, el) nil t nil))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1151 (error "Parse error: cannot find \"%s\"" (, el)))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1152 (aset forms--recordv (, (1- forms--field))
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
1153 (buffer-substring-no-properties here
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1154 (- (point) (, (length el)))))))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1155 (` ((if (not (looking-at (, (regexp-quote el))))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1156 (error "Parse error: not looking at \"%s\"" (, el)))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1157 (forward-char (, (length el))))))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1158 (setq forms--seen-text t)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1159 (setq forms--field nil)))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1160 ((numberp el)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1161 (if forms--field
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1162 (error "Cannot parse adjacent fields %d and %d"
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1163 forms--field el)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1164 (setq forms--field el)
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1165 nil))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1166 ((null el)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1167 (if forms--field
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1168 (` ((aset forms--recordv (, (1- forms--field))
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
1169 (buffer-substring-no-properties (point) (point-max)))))))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1170 ((listp el)
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1171 (prog1
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1172 (if forms--field
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1173 (` ((let ((here (point))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1174 (forms--dyntext (aref forms--dyntexts (, forms--dyntext))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1175 (if (not (search-forward forms--dyntext nil t nil))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1176 (error "Parse error: cannot find \"%s\"" forms--dyntext))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1177 (aset forms--recordv (, (1- forms--field))
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
1178 (buffer-substring-no-properties here
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1179 (- (point) (length forms--dyntext)))))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1180 (` ((let ((forms--dyntext (aref forms--dyntexts (, forms--dyntext))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1181 (if (not (looking-at (regexp-quote forms--dyntext)))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1182 (error "Parse error: not looking at \"%s\"" forms--dyntext))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1183 (forward-char (length forms--dyntext))))))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1184 (setq forms--dyntext (1+ forms--dyntext))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1185 (setq forms--seen-text t)
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1186 (setq forms--field nil)))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1187 ))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1188
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1189 (defun forms--intuit-from-file ()
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1190 "Get number of fields and a default form using the data file."
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1191
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1192 ;; If `forms-number-of-fields' is not set, get it from the data file.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1193 (if (null forms-number-of-fields)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1194
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1195 ;; Need a file to do this.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1196 (if (not (file-exists-p forms-file))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1197 (error "Need existing file or explicit 'forms-number-of-records'.")
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1198
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1199 ;; Visit the file and extract the first record.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1200 (setq forms--file-buffer (find-file-noselect forms-file))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1201 (let ((read-file-filter forms-read-file-filter)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1202 (the-record))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1203 (setq the-record
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1204 (save-excursion
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1205 (set-buffer forms--file-buffer)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1206 (let ((inhibit-read-only t))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1207 (run-hooks 'read-file-filter))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1208 (goto-char (point-min))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1209 (forms--get-record)))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1210
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1211 ;; This may be overkill, but try to avoid interference with
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1212 ;; the normal processing.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1213 (kill-buffer forms--file-buffer)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1214
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1215 ;; Count the number of fields in `the-record'.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1216 (let (the-result
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1217 (start-pos 0)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1218 found-pos
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1219 (field-sep-length (length forms-field-sep)))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1220 (setq forms-number-of-fields 1)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1221 (while (setq found-pos
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1222 (string-match forms-field-sep the-record start-pos))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1223 (progn
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1224 (setq forms-number-of-fields (1+ forms-number-of-fields))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1225 (setq start-pos (+ field-sep-length found-pos))))))))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1226
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1227 ;; Construct default format list.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1228 (setq forms-format-list (list "Forms file \"" forms-file "\".\n\n"))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1229 (let ((i 0))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1230 (while (<= (setq i (1+ i)) forms-number-of-fields)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1231 (setq forms-format-list
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1232 (append forms-format-list
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1233 (list (format "%4d: " i) i "\n"))))))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1234
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1235 (defun forms--set-keymaps ()
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1236 "Set the keymaps used in this mode."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1237
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1238 (use-local-map (if forms-read-only
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1239 forms-mode-ro-map
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1240 forms-mode-edit-map)))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1241
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1242 (defun forms--mode-commands ()
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1243 "Fill the Forms mode keymaps."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1244
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1245 ;; `forms-mode-map' is always accessible via \C-c prefix.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1246 (setq forms-mode-map (make-keymap))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1247 (define-key forms-mode-map "\t" 'forms-next-field)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1248 (define-key forms-mode-map "\C-k" 'forms-delete-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1249 (define-key forms-mode-map "\C-q" 'forms-toggle-read-only)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1250 (define-key forms-mode-map "\C-o" 'forms-insert-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1251 (define-key forms-mode-map "\C-l" 'forms-jump-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1252 (define-key forms-mode-map "\C-n" 'forms-next-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1253 (define-key forms-mode-map "\C-p" 'forms-prev-record)
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1254 (define-key forms-mode-map "\C-r" 'forms-search-backward)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1255 (define-key forms-mode-map "\C-s" 'forms-search-forward)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1256 (define-key forms-mode-map "\C-x" 'forms-exit)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1257 (define-key forms-mode-map "<" 'forms-first-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1258 (define-key forms-mode-map ">" 'forms-last-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1259 (define-key forms-mode-map "\C-?" 'forms-prev-record)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1260
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1261 ;; `forms-mode-ro-map' replaces the local map when in read-only mode.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1262 (setq forms-mode-ro-map (make-keymap))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1263 (suppress-keymap forms-mode-ro-map)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1264 (define-key forms-mode-ro-map "\C-c" forms-mode-map)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1265 (define-key forms-mode-ro-map "\t" 'forms-next-field)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1266 (define-key forms-mode-ro-map "q" 'forms-toggle-read-only)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1267 (define-key forms-mode-ro-map "l" 'forms-jump-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1268 (define-key forms-mode-ro-map "n" 'forms-next-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1269 (define-key forms-mode-ro-map "p" 'forms-prev-record)
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1270 (define-key forms-mode-ro-map "r" 'forms-search-backward)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1271 (define-key forms-mode-ro-map "s" 'forms-search-forward)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1272 (define-key forms-mode-ro-map "x" 'forms-exit)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1273 (define-key forms-mode-ro-map "<" 'forms-first-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1274 (define-key forms-mode-ro-map ">" 'forms-last-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1275 (define-key forms-mode-ro-map "?" 'describe-mode)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1276 (define-key forms-mode-ro-map " " 'forms-next-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1277 (forms--mode-commands1 forms-mode-ro-map)
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1278 (forms--mode-menu-ro forms-mode-ro-map)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1279
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1280 ;; This is the normal, local map.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1281 (setq forms-mode-edit-map (make-keymap))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1282 (define-key forms-mode-edit-map "\t" 'forms-next-field)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1283 (define-key forms-mode-edit-map "\C-c" forms-mode-map)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1284 (forms--mode-commands1 forms-mode-edit-map)
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1285 (forms--mode-menu-edit forms-mode-edit-map)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1286 )
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1287
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1288 (defun forms--mode-menu-ro (map)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1289 ;;; Menu initialisation
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1290 ; (define-key map [menu-bar] (make-sparse-keymap))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1291 (define-key map [menu-bar forms]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1292 (cons "Forms" (make-sparse-keymap "Forms")))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1293 (define-key map [menu-bar forms menu-forms-exit]
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1294 '("Exit Forms Mode" . forms-exit))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1295 (define-key map [menu-bar forms menu-forms-sep1]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1296 '("----"))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1297 (define-key map [menu-bar forms menu-forms-save]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1298 '("Save Data" . forms-save-buffer))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1299 (define-key map [menu-bar forms menu-forms-print]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1300 '("Print Data" . forms-print))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1301 (define-key map [menu-bar forms menu-forms-describe]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1302 '("Describe Mode" . describe-mode))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1303 (define-key map [menu-bar forms menu-forms-toggle-ro]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1304 '("Toggle View/Edit" . forms-toggle-read-only))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1305 (define-key map [menu-bar forms menu-forms-jump-record]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1306 '("Jump" . forms-jump-record))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1307 (define-key map [menu-bar forms menu-forms-search-backward]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1308 '("Search Backward" . forms-search-backward))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1309 (define-key map [menu-bar forms menu-forms-search-forward]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1310 '("Search Forward" . forms-search-forward))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1311 (define-key map [menu-bar forms menu-forms-delete-record]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1312 '("Delete" . forms-delete-record))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1313 (define-key map [menu-bar forms menu-forms-insert-record]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1314 '("Insert" . forms-insert-record))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1315 (define-key map [menu-bar forms menu-forms-sep2]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1316 '("----"))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1317 (define-key map [menu-bar forms menu-forms-last-record]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1318 '("Last Record" . forms-last-record))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1319 (define-key map [menu-bar forms menu-forms-first-record]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1320 '("First Record" . forms-first-record))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1321 (define-key map [menu-bar forms menu-forms-prev-record]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1322 '("Previous Record" . forms-prev-record))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1323 (define-key map [menu-bar forms menu-forms-next-record]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1324 '("Next Record" . forms-next-record))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1325 (define-key map [menu-bar forms menu-forms-sep3]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1326 '("----"))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1327 (define-key map [menu-bar forms menu-forms-prev-field]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1328 '("Previous Field" . forms-prev-field))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1329 (define-key map [menu-bar forms menu-forms-next-field]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1330 '("Next Field" . forms-next-field))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1331 (put 'forms-insert-record 'menu-enable '(not forms-read-only))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1332 (put 'forms-delete-record 'menu-enable '(not forms-read-only))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1333 )
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1334 (defun forms--mode-menu-edit (map)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1335 ;;; Menu initialisation
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1336 ; (define-key map [menu-bar] (make-sparse-keymap))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1337 (define-key map [menu-bar forms]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1338 (cons "Forms" (make-sparse-keymap "Forms")))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1339 (define-key map [menu-bar forms menu-forms-edit--exit]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1340 '("Exit" . forms-exit))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1341 (define-key map [menu-bar forms menu-forms-edit-sep1]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1342 '("----"))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1343 (define-key map [menu-bar forms menu-forms-edit-save]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1344 '("Save Data" . forms-save-buffer))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1345 (define-key map [menu-bar forms menu-forms-edit-print]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1346 '("Print Data" . forms-print))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1347 (define-key map [menu-bar forms menu-forms-edit-describe]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1348 '("Describe Mode" . describe-mode))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1349 (define-key map [menu-bar forms menu-forms-edit-toggle-ro]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1350 '("Toggle View/Edit" . forms-toggle-read-only))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1351 (define-key map [menu-bar forms menu-forms-edit-jump-record]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1352 '("Jump" . forms-jump-record))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1353 (define-key map [menu-bar forms menu-forms-edit-search-backward]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1354 '("Search Backward" . forms-search-backward))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1355 (define-key map [menu-bar forms menu-forms-edit-search-forward]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1356 '("Search Forward" . forms-search-forward))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1357 (define-key map [menu-bar forms menu-forms-edit-delete-record]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1358 '("Delete" . forms-delete-record))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1359 (define-key map [menu-bar forms menu-forms-edit-insert-record]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1360 '("Insert" . forms-insert-record))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1361 (define-key map [menu-bar forms menu-forms-edit-sep2]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1362 '("----"))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1363 (define-key map [menu-bar forms menu-forms-edit-last-record]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1364 '("Last Record" . forms-last-record))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1365 (define-key map [menu-bar forms menu-forms-edit-first-record]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1366 '("First Record" . forms-first-record))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1367 (define-key map [menu-bar forms menu-forms-edit-prev-record]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1368 '("Previous Record" . forms-prev-record))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1369 (define-key map [menu-bar forms menu-forms-edit-next-record]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1370 '("Next Record" . forms-next-record))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1371 (define-key map [menu-bar forms menu-forms-edit-sep3]
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1372 '("----"))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1373 (define-key map [menu-bar forms menu-forms-edit-prev-field]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1374 '("Previous Field" . forms-prev-field))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1375 (define-key map [menu-bar forms menu-forms-edit-next-field]
12031
a59559009d7e (forms--mode-menu-ro, forms--mode-menu-edit): Fix capitalization in menu bar.
Karl Heuer <kwzh@gnu.org>
parents: 11645
diff changeset
1376 '("Next Field" . forms-next-field))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1377 (put 'forms-insert-record 'menu-enable '(not forms-read-only))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1378 (put 'forms-delete-record 'menu-enable '(not forms-read-only))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1379 )
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1380
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1381 (defun forms--mode-commands1 (map)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1382 "Helper routine to define keys."
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1383 (define-key map [TAB] 'forms-next-field)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1384 (define-key map [S-tab] 'forms-prev-field)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1385 (define-key map [next] 'forms-next-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1386 (define-key map [prior] 'forms-prev-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1387 (define-key map [begin] 'forms-first-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1388 (define-key map [last] 'forms-last-record)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1389 (define-key map [backtab] 'forms-prev-field)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1390 )
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1391
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1392 ;;; Changed functions
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1393
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1394 (defun forms--change-commands ()
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1395 "Localize some commands for Forms mode."
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1396
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1397 ;; scroll-down -> forms-prev-record
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1398 ;; scroll-up -> forms-next-record
3828
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1399 (if forms-forms-scroll
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1400 (progn
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1401 (substitute-key-definition 'scroll-up 'forms-next-record
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1402 (current-local-map)
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1403 (current-global-map))
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1404 (substitute-key-definition 'scroll-down 'forms-prev-record
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1405 (current-local-map)
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1406 (current-global-map))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1407 ;;
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1408 ;; beginning-of-buffer -> forms-first-record
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1409 ;; end-of-buffer -> forms-end-record
3828
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1410 (if forms-forms-jump
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1411 (progn
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1412 (substitute-key-definition 'beginning-of-buffer 'forms-first-record
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1413 (current-local-map)
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1414 (current-global-map))
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1415 (substitute-key-definition 'end-of-buffer 'forms-last-record
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1416 (current-local-map)
c9f18a7140f9 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 3827
diff changeset
1417 (current-global-map))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1418 ;;
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1419 ;; Save buffer
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1420 (local-set-key "\C-x\C-s" 'forms-save-buffer)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1421 ;;
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1422 ;; We have our own revert function - use it.
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1423 (make-local-variable 'revert-buffer-function)
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1424 (setq revert-buffer-function 'forms--revert-buffer)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1425
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1426 t)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1427
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1428 (defun forms--help ()
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1429 "Initial help for Forms mode."
14315
ab041898078d (forms--help, forms-search-forward, forms-search-backward): Pass proper format string to message.
Karl Heuer <kwzh@gnu.org>
parents: 14169
diff changeset
1430 (message "%s" (substitute-command-keys (concat
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1431 "\\[forms-next-record]:next"
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1432 " \\[forms-prev-record]:prev"
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1433 " \\[forms-first-record]:first"
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1434 " \\[forms-last-record]:last"
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1435 " \\[describe-mode]:help"))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1436
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1437 (defun forms--trans (subj arg rep)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1438 "Translate in SUBJ all chars ARG into char REP. ARG and REP should
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1439 be single-char strings."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1440 (let ((i 0)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1441 (x (length subj))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1442 (re (regexp-quote arg))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1443 (k (string-to-char rep)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1444 (while (setq i (string-match re subj i))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1445 (aset subj i k)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1446 (setq i (1+ i)))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1447
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1448 (defun forms--exit (query &optional save)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1449 "Internal exit from forms mode function."
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1450
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1451 (let ((buf (buffer-name forms--file-buffer)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1452 (forms--checkmod)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1453 (if (and save
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1454 (buffer-modified-p forms--file-buffer))
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1455 (forms-save-buffer))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1456 (save-excursion
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1457 (set-buffer forms--file-buffer)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1458 (delete-auto-save-file-if-necessary)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1459 (kill-buffer (current-buffer)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1460 (if (get-buffer buf) ; not killed???
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1461 (if save
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1462 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1463 (beep)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1464 (message "Problem saving buffers?")))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1465 (delete-auto-save-file-if-necessary)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1466 (kill-buffer (current-buffer)))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1467
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1468 (defun forms--get-record ()
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1469 "Fetch the current record from the file buffer."
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1470
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1471 ;; This function is executed in the context of the `forms--file-buffer'.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1472
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1473 (or (bolp)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1474 (beginning-of-line nil))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1475 (let ((here (point)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1476 (prog2
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1477 (end-of-line)
13569
438ebe3b6f8d Use `buffer-substring-no-properties' instead of `buffer-substring' to
Johan Vromans <jvromans@squirrel.nl>
parents: 13337
diff changeset
1478 (buffer-substring-no-properties here (point))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1479 (goto-char here))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1480
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1481 (defun forms--show-record (the-record)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1482 "Format THE-RECORD and display it in the current buffer."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1483
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1484 ;; Split the-record.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1485 (let (the-result
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1486 (start-pos 0)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1487 found-pos
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1488 (field-sep-length (length forms-field-sep)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1489 (if forms-multi-line
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1490 (forms--trans the-record forms-multi-line "\n"))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1491 ;; Add an extra separator (makes splitting easy).
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1492 (setq the-record (concat the-record forms-field-sep))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1493 (while (setq found-pos (string-match forms-field-sep the-record start-pos))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1494 (let ((ent (substring the-record start-pos found-pos)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1495 (setq the-result
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1496 (append the-result (list ent)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1497 (setq start-pos (+ field-sep-length found-pos))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1498 (setq forms--the-record-list the-result))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1499
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1500 (setq buffer-read-only nil)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1501 (if forms-use-text-properties
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1502 (let ((inhibit-read-only t))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1503 (set-text-properties (point-min) (point-max) nil)))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1504 (erase-buffer)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1505
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1506 ;; Verify the number of fields, extend forms--the-record-list if needed.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1507 (if (= (length forms--the-record-list) forms-number-of-fields)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1508 nil
12847
61961ca01260 (forms-check-number-of-fields): New vbl.
Richard M. Stallman <rms@gnu.org>
parents: 12508
diff changeset
1509 (if (null forms-check-number-of-fields)
61961ca01260 (forms-check-number-of-fields): New vbl.
Richard M. Stallman <rms@gnu.org>
parents: 12508
diff changeset
1510 nil
61961ca01260 (forms-check-number-of-fields): New vbl.
Richard M. Stallman <rms@gnu.org>
parents: 12508
diff changeset
1511 (beep)
61961ca01260 (forms-check-number-of-fields): New vbl.
Richard M. Stallman <rms@gnu.org>
parents: 12508
diff changeset
1512 (message "Warning: this record has %d fields instead of %d"
61961ca01260 (forms-check-number-of-fields): New vbl.
Richard M. Stallman <rms@gnu.org>
parents: 12508
diff changeset
1513 (length forms--the-record-list) forms-number-of-fields))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1514 (if (< (length forms--the-record-list) forms-number-of-fields)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1515 (setq forms--the-record-list
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1516 (append forms--the-record-list
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1517 (make-list
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1518 (- forms-number-of-fields
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1519 (length forms--the-record-list))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1520 "")))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1521
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1522 ;; Call the formatter function.
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1523 (setq forms-fields (append (list nil) forms--the-record-list nil))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1524 (funcall forms--format forms--the-record-list)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1525
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1526 ;; Prepare.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1527 (goto-char (point-min))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1528 (set-buffer-modified-p nil)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1529 (setq buffer-read-only forms-read-only)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1530 (setq mode-line-process
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1531 (concat " " forms--current-record "/" forms--total-records)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1532
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1533 (defun forms--parse-form ()
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1534 "Parse contents of form into list of strings."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1535 ;; The contents of the form are parsed, and a new list of strings
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1536 ;; is constructed.
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1537 ;; A vector with the strings from the original record is
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1538 ;; constructed, which is updated with the new contents. Therefore
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1539 ;; fields which were not in the form are not modified.
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1540 ;; Finally, the vector is transformed into a list for further processing.
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1541
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1542 (let (forms--recordv)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1543
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1544 ;; Build the vector.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1545 (setq forms--recordv (vconcat forms--the-record-list))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1546
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1547 ;; Parse the form and update the vector.
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1548 (let ((forms--dynamic-text forms--dynamic-text))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1549 (funcall forms--parser))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1550
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1551 (if forms-modified-record-filter
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1552 ;; As a service to the user, we add a zeroth element so she
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1553 ;; can use the same indices as in the forms definition.
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1554 (let ((the-fields (vconcat [nil] forms--recordv)))
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1555 (setq the-fields (funcall forms-modified-record-filter the-fields))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1556 (cdr (append the-fields nil)))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1557
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1558 ;; Transform to a list and return.
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1559 (append forms--recordv nil))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1560
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1561 (defun forms--update ()
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1562 "Update current record with contents of form.
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1563 As a side effect: sets `forms--the-record-list'."
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1564
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1565 (if forms-read-only
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1566 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1567 (message "Read-only buffer!")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1568 (beep))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1569
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1570 (let (the-record)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1571 ;; Build new record.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1572 (setq forms--the-record-list (forms--parse-form))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1573 (setq the-record
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1574 (mapconcat 'identity forms--the-record-list forms-field-sep))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1575
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1576 (if (string-match (regexp-quote forms-field-sep)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1577 (mapconcat 'identity forms--the-record-list ""))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1578 (error "Field separator occurs in record - update refused!"))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1579
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1580 ;; Handle multi-line fields, if allowed.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1581 (if forms-multi-line
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1582 (forms--trans the-record "\n" forms-multi-line))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1583
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1584 ;; A final sanity check before updating.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1585 (if (string-match "\n" the-record)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1586 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1587 (message "Multi-line fields in this record - update refused!")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1588 (beep))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1589
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1590 (save-excursion
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1591 (set-buffer forms--file-buffer)
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
1592 ;; Use delete-region instead of kill-region, to avoid
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
1593 ;; adding junk to the kill-ring.
8352
9e9987dda110 (forms--update): Undo change made mistakenly.
Richard M. Stallman <rms@gnu.org>
parents: 8344
diff changeset
1594 (delete-region (save-excursion (beginning-of-line) (point))
9e9987dda110 (forms--update): Undo change made mistakenly.
Richard M. Stallman <rms@gnu.org>
parents: 8344
diff changeset
1595 (save-excursion (end-of-line) (point)))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1596 (insert the-record)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1597 (beginning-of-line))))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1598
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1599 (defun forms--checkmod ()
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1600 "Check if this form has been modified, and call forms--update if so."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1601 (if (buffer-modified-p nil)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1602 (let ((here (point)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1603 (forms--update)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1604 (set-buffer-modified-p nil)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1605 (goto-char here))))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1606
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1607 ;;; Start and exit
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1608
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1609 ;;;###autoload
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1610 (defun forms-find-file (fn)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1611 "Visit a file in Forms mode."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1612 (interactive "fForms file: ")
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1613 (let ((enable-local-eval t)
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1614 (enable-local-variables t))
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1615 (find-file-read-only fn)
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1616 (or forms--mode-setup (forms-mode t))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1617
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1618 ;;;###autoload
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1619 (defun forms-find-file-other-window (fn)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1620 "Visit a file in Forms mode in other window."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1621 (interactive "fFbrowse file in other window: ")
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1622 (let ((enable-local-eval t)
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1623 (enable-local-variables t))
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1624 (find-file-other-window fn)
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1625 (or forms--mode-setup (forms-mode t))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1626
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1627 (defun forms-exit (query)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1628 "Normal exit from Forms mode. Modified buffers are saved."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1629 (interactive "P")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1630 (forms--exit query t))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1631
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1632 (defun forms-exit-no-save (query)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1633 "Exit from Forms mode without saving buffers."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1634 (interactive "P")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1635 (forms--exit query nil))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1636
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1637 ;;; Navigating commands
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1638
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1639 (defun forms-next-record (arg)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1640 "Advance to the ARGth following record."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1641 (interactive "P")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1642 (forms-jump-record (+ forms--current-record (prefix-numeric-value arg)) t))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1643
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1644 (defun forms-prev-record (arg)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1645 "Advance to the ARGth previous record."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1646 (interactive "P")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1647 (forms-jump-record (- forms--current-record (prefix-numeric-value arg)) t))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1648
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1649 (defun forms-jump-record (arg &optional relative)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1650 "Jump to a random record."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1651 (interactive "NRecord number: ")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1652
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1653 ;; Verify that the record number is within range.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1654 (if (or (> arg forms--total-records)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1655 (<= arg 0))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1656 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1657 (beep)
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1658 ;; Don't give the message if just paging.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1659 (if (not relative)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1660 (message "Record number %d out of range 1..%d"
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1661 arg forms--total-records))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1662 )
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1663
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1664 ;; Flush.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1665 (forms--checkmod)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1666
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1667 ;; Calculate displacement.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1668 (let ((disp (- arg forms--current-record))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1669 (cur forms--current-record))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1670
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1671 ;; `forms--show-record' needs it now.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1672 (setq forms--current-record arg)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1673
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1674 ;; Get the record and show it.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1675 (forms--show-record
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1676 (save-excursion
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1677 (set-buffer forms--file-buffer)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1678 (beginning-of-line)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1679
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1680 ;; Move, and adjust the amount if needed (shouldn't happen).
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1681 (if relative
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1682 (if (zerop disp)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1683 nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1684 (setq cur (+ cur disp (- (forward-line disp)))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1685 (setq cur (+ cur disp (- (goto-line arg)))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1686
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1687 (forms--get-record)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1688
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1689 ;; This shouldn't happen.
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1690 (if (/= forms--current-record cur)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1691 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1692 (setq forms--current-record cur)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1693 (beep)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1694 (message "Stuck at record %d" cur))))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1695
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1696 (defun forms-first-record ()
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1697 "Jump to first record."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1698 (interactive)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1699 (forms-jump-record 1))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1700
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1701 (defun forms-last-record ()
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1702 "Jump to last record.
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1703 As a side effect: re-calculates the number of records in the data file."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1704 (interactive)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1705 (let
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1706 ((numrec
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1707 (save-excursion
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1708 (set-buffer forms--file-buffer)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1709 (count-lines (point-min) (point-max)))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1710 (if (= numrec forms--total-records)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1711 nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1712 (beep)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1713 (setq forms--total-records numrec)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1714 (message "Warning: number of records changed to %d" forms--total-records)))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1715 (forms-jump-record forms--total-records))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
1716
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1717 ;;; Other commands
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1718
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1719 (defun forms-toggle-read-only (arg)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1720 "Toggles read-only mode of a forms mode buffer.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1721 With an argument, enables read-only mode if the argument is positive.
13984
c045b6e55d08 (forms-toggle-read-only, forms-enumerate): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 13569
diff changeset
1722 Otherwise enables edit mode if the visited file is writable."
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1723
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1724 (interactive "P")
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1725
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1726 (if (if arg
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1727 ;; Negative arg means switch it off.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1728 (<= (prefix-numeric-value arg) 0)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1729 ;; No arg means toggle.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1730 forms-read-only)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1731
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1732 ;; Enable edit mode, if possible.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1733 (let ((ro forms-read-only))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1734 (if (save-excursion
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1735 (set-buffer forms--file-buffer)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1736 buffer-read-only)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1737 (progn
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1738 (setq forms-read-only t)
14356
0c88041fc50a (forms-mode, forms-toggle-read-only): Fix message text.
Karl Heuer <kwzh@gnu.org>
parents: 14315
diff changeset
1739 (message "No write access to `%s'" forms-file)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1740 (beep))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1741 (setq forms-read-only nil))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1742 (if (equal ro forms-read-only)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1743 nil
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1744 (forms-mode)))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1745
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1746 ;; Enable view mode.
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1747 (if forms-read-only
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1748 nil
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1749 (forms--checkmod) ; sync
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1750 (setq forms-read-only t)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1751 (forms-mode))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1752
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1753 ;; Sample:
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1754 ;; (defun my-new-record-filter (the-fields)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1755 ;; ;; numbers are relative to 1
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1756 ;; (aset the-fields 4 (current-time-string))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1757 ;; (aset the-fields 6 (user-login-name))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1758 ;; the-list)
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1759 ;; (setq forms-new-record-filter 'my-new-record-filter)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1760
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1761 (defun forms-insert-record (arg)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1762 "Create a new record before the current one.
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1763 With ARG: store the record after the current one.
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1764 If `forms-new-record-filter' contains the name of a function,
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1765 it is called to fill (some of) the fields with default values.
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1766 If `forms-insert-after is non-nil, the default behavior is to insert
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1767 after the current record."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1768
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1769 (interactive "P")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1770
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1771 (if forms-read-only
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1772 (error ""))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1773
14732
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1774 (let (ln the-list the-record)
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1775
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1776 (if (or (and arg forms-insert-after)
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1777 (and (not arg) (not forms-insert-after)))
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1778 (setq ln forms--current-record)
6bd77cce44a6 (forms-insert-after): New variable. Non-nil means: inserts of new
Johan Vromans <jvromans@squirrel.nl>
parents: 14421
diff changeset
1779 (setq ln (1+ forms--current-record)))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1780
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1781 (forms--checkmod)
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1782 (if forms-new-record-filter
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1783 ;; As a service to the user, we add a zeroth element so she
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1784 ;; can use the same indices as in the forms definition.
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1785 (let ((the-fields (make-vector (1+ forms-number-of-fields) "")))
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1786 (setq the-fields (funcall forms-new-record-filter the-fields))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1787 (setq the-list (cdr (append the-fields nil))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1788 (setq the-list (make-list forms-number-of-fields "")))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1789
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1790 (setq the-record
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1791 (mapconcat
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1792 'identity
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1793 the-list
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1794 forms-field-sep))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1795
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1796 (save-excursion
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1797 (set-buffer forms--file-buffer)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1798 (goto-line ln)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1799 (open-line 1)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1800 (insert the-record)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1801 (beginning-of-line))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1802
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1803 (setq forms--current-record ln))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1804
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1805 (setq forms--total-records (1+ forms--total-records))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1806 (forms-jump-record forms--current-record))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1807
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1808 (defun forms-delete-record (arg)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
1809 "Deletes a record. With a prefix argument: don't ask."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1810 (interactive "P")
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1811
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1812 (if forms-read-only
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1813 (error ""))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1814
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1815 (forms--checkmod)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1816 (if (or arg
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1817 (y-or-n-p "Really delete this record? "))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1818 (let ((ln forms--current-record))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1819 (save-excursion
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1820 (set-buffer forms--file-buffer)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1821 (goto-line ln)
4723
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
1822 ;; Use delete-region instead of kill-region, to avoid
6a3f5f51897b Change typos in comments.
Richard M. Stallman <rms@gnu.org>
parents: 4121
diff changeset
1823 ;; adding junk to the kill-ring.
8272
8d790a29a13a (forms-delete-record): Handle deletion of last line
Richard M. Stallman <rms@gnu.org>
parents: 7863
diff changeset
1824 (delete-region (progn (beginning-of-line) (point))
8d790a29a13a (forms-delete-record): Handle deletion of last line
Richard M. Stallman <rms@gnu.org>
parents: 7863
diff changeset
1825 (progn (beginning-of-line 2) (point))))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1826 (setq forms--total-records (1- forms--total-records))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1827 (if (> forms--current-record forms--total-records)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1828 (setq forms--current-record forms--total-records))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1829 (forms-jump-record forms--current-record)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1830 (message ""))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1831
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1832 (defun forms-search-forward (regexp)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1833 "Search forward for record containing REGEXP."
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1834 (interactive
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1835 (list (read-string (concat "Search forward for"
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1836 (if forms--search-regexp
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1837 (concat " ("
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1838 forms--search-regexp
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1839 ")"))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1840 ": "))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1841 (if (equal "" regexp)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1842 (setq regexp forms--search-regexp))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1843 (forms--checkmod)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1844
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1845 (let (the-line the-record here
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1846 (fld-sep forms-field-sep))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1847 (if (save-excursion
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1848 (set-buffer forms--file-buffer)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1849 (setq here (point))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1850 (end-of-line)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1851 (if (null (re-search-forward regexp nil t))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1852 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1853 (goto-char here)
14356
0c88041fc50a (forms-mode, forms-toggle-read-only): Fix message text.
Karl Heuer <kwzh@gnu.org>
parents: 14315
diff changeset
1854 (message "\"%s\" not found" regexp)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1855 nil)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1856 (setq the-record (forms--get-record))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1857 (setq the-line (1+ (count-lines (point-min) (point))))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1858 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1859 (setq forms--current-record the-line)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1860 (forms--show-record the-record)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1861 (re-search-forward regexp nil t))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1862 (setq forms--search-regexp regexp))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1863
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1864 (defun forms-search-backward (regexp)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1865 "Search backward for record containing REGEXP."
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1866 (interactive
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1867 (list (read-string (concat "Search backward for"
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1868 (if forms--search-regexp
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1869 (concat " ("
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1870 forms--search-regexp
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1871 ")"))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1872 ": "))))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1873 (if (equal "" regexp)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1874 (setq regexp forms--search-regexp))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1875 (forms--checkmod)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1876
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1877 (let (the-line the-record here
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1878 (fld-sep forms-field-sep))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1879 (if (save-excursion
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1880 (set-buffer forms--file-buffer)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1881 (setq here (point))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1882 (beginning-of-line)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1883 (if (null (re-search-backward regexp nil t))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1884 (progn
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1885 (goto-char here)
14356
0c88041fc50a (forms-mode, forms-toggle-read-only): Fix message text.
Karl Heuer <kwzh@gnu.org>
parents: 14315
diff changeset
1886 (message "\"%s\" not found" regexp)
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1887 nil)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1888 (setq the-record (forms--get-record))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1889 (setq the-line (1+ (count-lines (point-min) (point))))))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1890 (progn
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1891 (setq forms--current-record the-line)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1892 (forms--show-record the-record)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1893 (re-search-forward regexp nil t))))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1894 (setq forms--search-regexp regexp))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1895
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1896 (defun forms-save-buffer (&optional args)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1897 "Forms mode replacement for save-buffer.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1898 It saves the data buffer instead of the forms buffer.
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1899 Calls `forms-write-file-filter' before writing out the data."
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1900 (interactive "p")
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1901 (forms--checkmod)
8344
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1902 (let ((read-file-filter forms-read-file-filter))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1903 (save-excursion
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1904 (set-buffer forms--file-buffer)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1905 (let ((inhibit-read-only t))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1906 (save-buffer args)
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1907 (if read-file-filter
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1908 (run-hooks 'read-file-filter))
e206050c7d51 (forms-read-file-filter): new hook function to
Richard M. Stallman <rms@gnu.org>
parents: 8272
diff changeset
1909 (set-buffer-modified-p nil))))
7863
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1910 t)
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1911
c4adb7401604 (forms-mode): Plug security hole by disabling `eval-buffer' unless
Richard M. Stallman <rms@gnu.org>
parents: 7639
diff changeset
1912 (defun forms--revert-buffer (&optional arg noconfirm)
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1913 "Reverts current form to un-modified."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1914 (interactive "P")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1915 (if (or noconfirm
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1916 (yes-or-no-p "Revert form to unmodified? "))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1917 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1918 (set-buffer-modified-p nil)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1919 (forms-jump-record forms--current-record))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1920
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1921 (defun forms-next-field (arg)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1922 "Jump to ARG-th next field."
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1923 (interactive "p")
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1924
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1925 (let ((i 0)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1926 (here (point))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1927 there
11557
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
1928 (cnt 0)
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
1929 (inhibit-point-motion-hooks t))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1930
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1931 (if (zerop arg)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1932 (setq cnt 1)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1933 (setq cnt (+ cnt arg)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1934
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1935 (if (catch 'done
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
1936 (while (< i (length forms--markers))
276
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1937 (if (or (null (setq there (aref forms--markers i)))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1938 (<= there here))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1939 nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1940 (if (<= (setq cnt (1- cnt)) 0)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1941 (progn
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1942 (goto-char there)
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1943 (throw 'done t))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1944 (setq i (1+ i))))
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1945 nil
e7eb71cbf478 Initial revision
Brian Preble <rassilon@gnu.org>
parents:
diff changeset
1946 (goto-char (aref forms--markers 0)))))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
1947
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1948 (defun forms-prev-field (arg)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1949 "Jump to ARG-th previous field."
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1950 (interactive "p")
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1951
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1952 (let ((i (length forms--markers))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1953 (here (point))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1954 there
11557
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
1955 (cnt 0)
63406705a7e2 (forms--make-format-elt-using-text-properties)
Richard M. Stallman <rms@gnu.org>
parents: 10348
diff changeset
1956 (inhibit-point-motion-hooks t))
4790
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1957
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1958 (if (zerop arg)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1959 (setq cnt 1)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1960 (setq cnt (+ cnt arg)))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1961
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1962 (if (catch 'done
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1963 (while (> i 0)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1964 (setq i ( 1- i))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1965 (if (or (null (setq there (aref forms--markers i)))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1966 (>= there here))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1967 nil
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1968 (if (<= (setq cnt (1- cnt)) 0)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1969 (progn
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1970 (goto-char there)
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1971 (throw 'done t))))))
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1972 nil
b110036d90b0 Version 2.3.
Richard M. Stallman <rms@gnu.org>
parents: 4723
diff changeset
1973 (goto-char (aref forms--markers (1- (length forms--markers)))))))
10346
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1974
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1975 (defun forms-print ()
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1976 "Send the records to the printer with 'print-buffer', one record per page."
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1977 (interactive)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1978 (let ((inhibit-read-only t)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1979 (save-record forms--current-record)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1980 (nb-record 1)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1981 (record nil))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1982 (while (<= nb-record forms--total-records)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1983 (forms-jump-record nb-record)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1984 (setq record (buffer-string))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1985 (save-excursion
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1986 (set-buffer (get-buffer-create "*forms-print*"))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1987 (goto-char (buffer-end 1))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1988 (insert record)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1989 (setq buffer-read-only nil)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1990 (if (< nb-record forms--total-records)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1991 (insert "\n \n")))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1992 (setq nb-record (1+ nb-record)))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1993 (save-excursion
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1994 (set-buffer "*forms-print*")
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1995 (print-buffer)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1996 (set-buffer-modified-p nil)
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1997 (kill-buffer (current-buffer)))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1998 (forms-jump-record save-record)))
a6018b04fb9d Change forms-search to forms-search-forward, and add
Johan Vromans <jvromans@squirrel.nl>
parents: 8352
diff changeset
1999
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2000 ;;;
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2001 ;;; Special service
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2002 ;;;
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2003 (defun forms-enumerate (the-fields)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
2004 "Take a quoted list of symbols, and set their values to sequential numbers.
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
2005 The first symbol gets number 1, the second 2 and so on.
13984
c045b6e55d08 (forms-toggle-read-only, forms-enumerate): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 13569
diff changeset
2006 It returns the highest number.
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2007
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2008 Usage: (setq forms-number-of-fields
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2009 (forms-enumerate
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2010 '(field1 field2 field2 ...)))"
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2011
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2012 (let ((the-index 0))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2013 (while the-fields
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2014 (setq the-index (1+ the-index))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2015 (let ((el (car-safe the-fields)))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2016 (setq the-fields (cdr-safe the-fields))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2017 (set el the-index)))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2018 the-index))
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
2019
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2020 ;;; Debugging
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
2021
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2022 (defvar forms--debug nil
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2023 "*Enables forms-mode debugging if not nil.")
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2024
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2025 (defun forms--debug (&rest args)
3941
93a7a7b97030 Add e-mail address and version info.
Richard M. Stallman <rms@gnu.org>
parents: 3828
diff changeset
2026 "Internal debugging routine."
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2027 (if forms--debug
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2028 (let ((ret nil))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2029 (while args
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2030 (let ((el (car-safe args)))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2031 (setq args (cdr-safe args))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2032 (if (stringp el)
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2033 (setq ret (concat ret el))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2034 (setq ret (concat ret (prin1-to-string el) " = "))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2035 (if (boundp el)
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2036 (let ((vel (eval el)))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2037 (setq ret (concat ret (prin1-to-string vel) "\n")))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2038 (setq ret (concat ret "<unbound>" "\n")))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2039 (if (fboundp el)
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2040 (setq ret (concat ret (prin1-to-string (symbol-function el))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2041 "\n"))))))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2042 (save-excursion
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2043 (set-buffer (get-buffer-create "*forms-mode debug*"))
4121
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
2044 (if (zerop (buffer-size))
25d32add267c Rewritten by Vromans to use text properties.
Richard M. Stallman <rms@gnu.org>
parents: 3979
diff changeset
2045 (emacs-lisp-mode))
307
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2046 (goto-char (point-max))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2047 (insert ret)))))
7fede845e304 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 276
diff changeset
2048
3697
994bb6dc9249 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 307
diff changeset
2049 ;;; forms.el ends here.