Mercurial > emacs
annotate lisp/forms-d2.el @ 80479:45332330ce1b
*** empty log message ***
author | Jason Rumney <jasonr@gnu.org> |
---|---|
date | Thu, 10 Apr 2008 09:42:29 +0000 |
parents | 73661ddc7ac7 |
children | 606f2d163a64 1e3a407766b9 |
rev | line source |
---|---|
47726
33d53d287ee4
Add "no-byte-compile: t" in first line.
Juanma Barranquero <lekktu@gmail.com>
parents:
38436
diff
changeset
|
1 ;;; forms-d2.el --- demo forms-mode -*- no-byte-compile: t -*- |
25867 | 2 |
74679
829062b6492b
Copy copyright header from forms.el (at rms instruction).
Glenn Morris <rgm@gnu.org>
parents:
64542
diff
changeset
|
3 ;; Copyright (C) 1991, 1994, 1995, 1996, 1997, 2001, 2002, 2003, |
79721 | 4 ;; 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. |
74679
829062b6492b
Copy copyright header from forms.el (at rms instruction).
Glenn Morris <rgm@gnu.org>
parents:
64542
diff
changeset
|
5 |
25867 | 6 ;; Author: Johan Vromans <jvromans@squirrel.nl> |
7 ;; Created: 1989 | |
8 | |
38436
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
25867
diff
changeset
|
9 ;; This file is part of GNU Emacs. |
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
25867
diff
changeset
|
10 |
78235
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
11 ;; GNU Emacs is free software; you can redistribute it and/or modify |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
12 ;; it under the terms of the GNU General Public License as published by |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
13 ;; the Free Software Foundation; either version 3, or (at your option) |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
14 ;; any later version. |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
15 |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
16 ;; GNU Emacs is distributed in the hope that it will be useful, |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
19 ;; GNU General Public License for more details. |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
20 |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
21 ;; You should have received a copy of the GNU General Public License |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
23 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
24 ;; Boston, MA 02110-1301, USA. |
8b0dabde9595
Add missing license notice (GPLv3 or later).
Glenn Morris <rgm@gnu.org>
parents:
75347
diff
changeset
|
25 |
38436
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
25867
diff
changeset
|
26 ;;; Commentary: |
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
25867
diff
changeset
|
27 |
25867 | 28 ;; This sample forms exploit most of the features of forms mode. |
29 | |
38436
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
25867
diff
changeset
|
30 ;;; Code: |
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
25867
diff
changeset
|
31 |
25867 | 32 ;; Set the name of the data file. |
33 (setq forms-file "forms-d2.dat") | |
34 | |
35 ;; Use 'forms-enumerate' to set field names and number thereof. | |
36 (setq forms-number-of-fields | |
37 (forms-enumerate | |
38 '(arch-newsgroup ; 1 | |
39 arch-volume ; 2 | |
40 arch-issue ; and ... | |
41 arch-article ; ... so | |
42 arch-shortname ; ... ... on | |
43 arch-parts | |
44 arch-from | |
45 arch-longname | |
46 arch-keywords | |
47 arch-date | |
48 arch-remarks))) | |
49 | |
50 ;; The following functions are used by this form for layout purposes. | |
51 ;; | |
52 (defun arch-tocol (target &optional fill) | |
64542
24c6e1c8e0cb
(arch-rj): Fix typo in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
52401
diff
changeset
|
53 "Produces a string to skip to column TARGET. Prepends newline if needed. |
25867 | 54 The optional FILL should be a character, used to fill to the column." |
55 (if (null fill) | |
64542
24c6e1c8e0cb
(arch-rj): Fix typo in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
52401
diff
changeset
|
56 (setq fill ?\s)) |
25867 | 57 (if (< target (current-column)) |
58 (concat "\n" (make-string target fill)) | |
59 (make-string (- target (current-column)) fill))) | |
60 ;; | |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47726
diff
changeset
|
61 (defun arch-rj (target field &optional fill) |
25867 | 62 "Produces a string to skip to column TARGET minus the width of field FIELD. |
64542
24c6e1c8e0cb
(arch-rj): Fix typo in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
52401
diff
changeset
|
63 Prepends newline if needed. The optional FILL should be a character, |
25867 | 64 used to fill to the column." |
65 (arch-tocol (- target (length (nth field forms-fields))) fill)) | |
66 | |
67 ;; Record filters. | |
68 ;; | |
69 (defun arch-new-record-filter (the-record) | |
70 "Form a new record with some defaults." | |
71 (aset the-record arch-from (user-full-name)) | |
72 (aset the-record arch-date (current-time-string)) | |
73 the-record ; return it | |
74 ) | |
75 (setq forms-new-record-filter 'arch-new-record-filter) | |
76 | |
77 ;; The format list. | |
78 (setq forms-format-list | |
79 (list | |
80 "====== Public Domain Software Archive ======\n\n" | |
81 arch-shortname | |
82 " - " arch-longname | |
83 "\n\n" | |
84 "Article: " arch-newsgroup | |
85 "/" arch-article | |
86 " " | |
87 '(arch-tocol 40) | |
88 "Issue: " arch-issue | |
89 " " | |
90 '(arch-rj 73 10) | |
91 "Date: " arch-date | |
92 "\n\n" | |
93 "Submitted by: " arch-from | |
94 "\n" | |
95 '(arch-tocol 79 ?-) | |
96 "\n" | |
97 "Keywords: " arch-keywords | |
98 "\n\n" | |
99 "Parts: " arch-parts | |
100 "\n\n====== Remarks ======\n\n" | |
101 arch-remarks | |
102 )) | |
103 | |
104 ;; That's all, folks! | |
38436
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
25867
diff
changeset
|
105 |
52401 | 106 ;;; arch-tag: 8e5d5dac-7abf-4722-ab5e-03eb749beaca |
38436
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
25867
diff
changeset
|
107 ;;; forms-d2.el ends here |