annotate etc/auctex/style/dinbrief.el @ 50:ee648375d8d6 r19-16b91

Import from CVS: tag r19-16b91
author cvs
date Mon, 13 Aug 2007 08:56:41 +0200
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
50
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
1 ;;; dinbrief.el - Special code for LaTeX-Style dinbrief.
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
2
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
3 ;; Contributed by Werner Fink <tex@itap.physik.uni-stuttgart.de>
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
4 ;; Please direct comments to him.
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
5
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
6 ;;; Commentary:
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
7
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
8 ;; LaTeX-Style: dinbrief.sty
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
9 ;; Server: rusinfo.rus.uni-stuttgart.de
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
10 ;; Directory: /pub/soft/tex/macros/latex/contrib/letters
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
11
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
12 ;;; Code:
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
13
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
14 (TeX-add-style-hook "dinbrief"
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
15 (function
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
16 (lambda ()
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
17 (LaTeX-add-environments
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
18 '("letter" LaTeX-recipient-hook))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
19 (TeX-add-symbols
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
20 '("Absender" "Absender: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
21 '("Postvermerk" "Postvermerk: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
22 '("Datum" "Datum: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
23 '("Betreff" "Betreff: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
24 '("Behandlungsvermerk" "Behandlungsvermerk: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
25 '("Verteiler" "Verteiler: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
26 "makelabel" "Retourlabel"
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
27 '("Anlagen" "Anlagen: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
28 '("Fenster" "Fenster \(ja/nein\): ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
29 '("Retouradresse" "Retouradresse: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
30 '("signature" "Unterschrift: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
31 '("opening" "Anrede: ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
32 '("closing" "Schlu\"s: ")))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
33
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
34 (defun LaTeX-recipient-hook (environment)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
35 "Insert ENVIRONMENT and prompt for recipient and address."
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
36 (let ((sender (read-input "Absender: " (user-full-name)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
37 (recipient (read-input "Empf\"anger: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
38 (address (read-input "Anschrift: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
39 (postvermerk (read-input "Postvermerk: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
40 (date (read-input "Datum: " (LaTeX-today)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
41 (betreff (read-input "Betreff: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
42 (vermerk (read-input "Behandlungsvermerk: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
43 (verteil (read-input "Verteiler: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
44 (anlage (read-input "Anlagen: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
45 (opening (read-input "Anrede: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
46 (closing (read-input "Schlu\"s: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
47 (fenster (read-input "Fenster \(ja/nein\): "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
48 (signature (read-input "Unterschrift: "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
49 )
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
50
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
51 (if (not (zerop (length sender)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
52 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
53 (insert TeX-esc "Absender" TeX-grop sender TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
54 (newline-and-indent)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
55 (if (not (zerop (length postvermerk)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
56 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
57 (insert TeX-esc "Postvermerk" TeX-grop postvermerk TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
58 (newline-and-indent)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
59 (if (not (zerop (length betreff)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
60 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
61 (insert TeX-esc "Betreff" TeX-grop betreff TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
62 (newline-and-indent)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
63 (if (not (zerop (length vermerk)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
64 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
65 (insert TeX-esc "Behandlungsvermerk" TeX-grop vermerk TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
66 (newline-and-indent)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
67 (if (not (zerop (length verteil)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
68 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
69 (insert TeX-esc "Verteiler" TeX-grop verteil TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
70 (newline-and-indent)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
71 (if (not (zerop (length anlage)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
72 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
73 (insert TeX-esc "Anlagen" TeX-grop anlage TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
74 (newline-and-indent)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
75 (if (string= fenster "ja")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
76 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
77 (insert TeX-esc "Fenster")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
78 (let ((retouradr (read-input "Retouradresse: " (user-full-name))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
79 (newline-and-indent)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
80 (if (not (zerop (length retouradr)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
81 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
82 (insert TeX-esc "Retouradresse" TeX-grop retouradr TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
83 (newline-and-indent))))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
84 (if (not (zerop (length signature)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
85 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
86 (insert TeX-esc "signature" TeX-grop signature TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
87 (newline-and-indent)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
88 (if (not (zerop (length date)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
89 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
90 (insert TeX-esc "Datum" TeX-grop date TeX-grcl)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
91 (newline-and-indent)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
92 (newline-and-indent)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
93
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
94 (let ((indentation (current-column)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
95 (LaTeX-insert-environment
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
96 environment
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
97 (concat TeX-grop recipient
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
98 (if (not (zerop (length address)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
99 (concat
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
100 (if (not (zerop (length recipient)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
101 (concat " " TeX-esc TeX-esc " "))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
102 address))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
103 TeX-grcl))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
104 (save-excursion ; Fix indentation of address
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
105 (if (search-backward TeX-grcl nil 'move)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
106 (let ((addr-end (point-marker)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
107 (if (search-backward TeX-grop nil 'move)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
108 (let ((addr-column (current-column)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
109 (while (search-forward
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
110 (concat TeX-esc TeX-esc)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
111 (marker-position addr-end) 'move)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
112 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
113 (newline)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
114 (indent-to addr-column))))))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
115 (insert "\n")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
116 (indent-to indentation))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
117 (insert TeX-esc "opening"
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
118 TeX-grop
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
119 (if (zerop (length opening))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
120 (concat TeX-esc " ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
121 opening)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
122 TeX-grcl "\n")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
123
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
124 (indent-relative-maybe)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
125 (save-excursion
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
126 (insert "\n" TeX-esc "closing"
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
127 TeX-grop
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
128 (if (zerop (length closing))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
129 (concat TeX-esc " ")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
130 closing)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
131 TeX-grcl "\n")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
132 (indent-relative-maybe))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
133
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
134 (defun LaTeX-today nil
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
135 "Return a string representing todays date according to flavor."
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
136 (interactive)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
137 (let ((ctime-string (current-time-string))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
138 (month-alist '(("Jan" . "Januar")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
139 ("Feb" . "Februar")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
140 ("Mar" . "M\\\"arz")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
141 ("Apr" . "April")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
142 ("May" . "Mai")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
143 ("Jun" . "Juni")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
144 ("Jul" . "Juli")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
145 ("Aug" . "August")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
146 ("Sep" . "September")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
147 ("Oct" . "Oktober")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
148 ("Nov" . "November")
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
149 ("Dec" . "Dezember"))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
150 (string-match
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
151 "^\\S-+\\s-+\\(\\S-+\\)\\s-+\\(\\S-+\\)\\s-+\\S-+\\s-+\\(\\S-+\\)"
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
152 ctime-string)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
153 (let ((year (substring ctime-string (match-beginning 3) (match-end 3)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
154 (month (substring ctime-string (match-beginning 1) (match-end 1)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
155 (day (substring ctime-string (match-beginning 2) (match-end 2))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
156 (if (assoc month month-alist)
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
157 (progn
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
158 (setq month (cdr (assoc month month-alist)))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
159 (if (> 2 (length day))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
160 (setq day (concat "0" day)))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
161 (format "Stuttgart, den %s. %s %s" day month year))))
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
162
ee648375d8d6 Import from CVS: tag r19-16b91
cvs
parents:
diff changeset
163 ;;; dinbrief.el ends here