annotate lisp/w3/css.el @ 14:9ee227acff29 r19-15b90

Import from CVS: tag r19-15b90
author cvs
date Mon, 13 Aug 2007 08:48:42 +0200
parents
children 0293115a14e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
14
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
1 ;;; css.el -- Cascading Style Sheet parser
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
2 ;; Author: wmperry
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
3 ;; Created: 1996/12/26 16:49:58
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
4 ;; Version: 1.18
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
5 ;; Keywords:
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
6
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
7 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
8 ;;; Copyright (c) 1996 by William M. Perry (wmperry@cs.indiana.edu)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
9 ;;; Copyright (c) 1996 Free Software Foundation, Inc.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
10 ;;;
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
11 ;;; This file is not part of GNU Emacs, but the same permissions apply.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
12 ;;;
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
13 ;;; GNU Emacs is free software; you can redistribute it and/or modify
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
14 ;;; it under the terms of the GNU General Public License as published by
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
15 ;;; the Free Software Foundation; either version 2, or (at your option)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
16 ;;; any later version.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
17 ;;;
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
18 ;;; GNU Emacs is distributed in the hope that it will be useful,
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
19 ;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
20 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
21 ;;; GNU General Public License for more details.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
22 ;;;
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
23 ;;; You should have received a copy of the GNU General Public License
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
24 ;;; along with GNU Emacs; see the file COPYING. If not, write to the
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
25 ;;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
26 ;;; Boston, MA 02111-1307, USA.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
27 ;;;
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
28 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
29
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
30 (eval-and-compile
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
31 (require 'cl)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
32 (require 'font)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
33 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
34
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
35 ;; CBI = Cant Be Implemented - due to limitations in emacs/xemacs
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
36 ;; NYI = Not Yet Implemented - due to limitations of space/time
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
37 ;; NYPI = Not Yet Partially Implemented - possible partial support, eventually
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
38
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
39 (defconst css-properties
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
40 '(;; Property name Inheritable? Type of data
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
41 [font-family nil string-list]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
42 [font-style nil string]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
43 [font-variant nil symbol-list]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
44 [font-weight nil weight]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
45 [font-size nil length]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
46 [font nil font]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
47 [color nil color]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
48 [background nil color]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
49 [word-spacing nil length] ; CBI
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
50 [letter-spacing nil length] ; CBI
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
51 [text-decoration nil symbol-list]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
52 [vertical-align nil symbol] ; CBI
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
53 [text-transform nil string]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
54 [text-align t symbol]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
55 [text-indent t length] ; NYI
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
56 [line-height t length] ; CBI
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
57 [margin nil margin]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
58 [margin-left nil margin]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
59 [margin-right nil margin]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
60 [margin-top nil margin]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
61 [margin-bottom nil margin]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
62 [padding nil padding]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
63 [padding-left nil padding]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
64 [padding-right nil padding]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
65 [padding-top nil padding]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
66 [padding-bottom nil padding]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
67 [border nil border]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
68 [border-left nil border]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
69 [border-right nil border]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
70 [border-top nil border]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
71 [border-bottom nil border]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
72 [width nil length] ; NYPI
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
73 [height nil length] ; NYPI
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
74 [float nil symbol]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
75 [clear nil symbol]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
76 [display nil symbol]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
77 [list-style t symbol] ;!! can't specify 'inside|outside'
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
78 [white-space t symbol]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
79
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
80 ;; These are for specifying speech properties
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
81 [voice-family t string]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
82 [gain t integer]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
83 [left-volume t integer]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
84 [right-volume t integer]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
85 [pitch t integer]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
86 [pitch-range t integer]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
87 [stress t integer]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
88 [richness t integer]
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
89 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
90 "A description of the various CSS properties and how to interpret them.")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
91
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
92 (mapcar
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
93 (lambda (entry)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
94 (put (aref entry 0) 'css-inherit (aref entry 1))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
95 (put (aref entry 0) 'css-type (aref entry 2)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
96 css-properties)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
97
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
98 (defconst css-weights
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
99 '(nil ;never used
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
100 :extra-light
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
101 :light
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
102 :demi-light
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
103 :medium
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
104 :normal
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
105 :demi-bold
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
106 :bold
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
107 :extra-bold
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
108 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
109 "List of CSS font weights.")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
110
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
111 (defvar css-syntax-table
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
112 (copy-syntax-table emacs-lisp-mode-syntax-table)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
113 "The syntax table for parsing stylesheets")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
114
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
115 (modify-syntax-entry ?' "\"" css-syntax-table)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
116 (modify-syntax-entry ?` "\"" css-syntax-table)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
117 (modify-syntax-entry ?{ "(" css-syntax-table)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
118 (modify-syntax-entry ?} ")" css-syntax-table)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
119
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
120 (eval-when-compile
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
121 (defvar css-scratch-val nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
122 (defvar css-scratch-id nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
123 (defvar css-scratch-class nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
124 (defvar css-scratch-possibles nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
125 (defvar css-scratch-current nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
126 (defvar css-scratch-classes nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
127 (defvar css-scratch-class-match nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
128 (defvar css-scratch-current-rule nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
129 (defvar css-scratch-current-value nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
130 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
131
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
132 (defconst css-running-xemacs
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
133 (string-match "XEmacs" (emacs-version))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
134 "Whether we are running in XEmacs or not.")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
135
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
136 (defvar css-ie-compatibility t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
137 "Whether we want to do Internet Explorer 3.0 compatible parsing of
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
138 CSS stylesheets.")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
139
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
140 (defsubst css-replace-regexp (regexp to-string)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
141 (goto-char (point-min))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
142 (while (re-search-forward regexp nil t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
143 (replace-match to-string t nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
144
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
145 (defun css-contextual-match (rule stack)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
146 (let ((ancestor)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
147 (p-args)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
148 (p-class)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
149 (matched t))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
150 (while rule
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
151 (setq ancestor (assq (caar rule) stack))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
152 (if (not ancestor)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
153 (setq rule nil
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
154 matched nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
155 (setq p-args (cdr ancestor)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
156 p-class (or (cdr-safe (assq 'class p-args)) t))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
157 (if (not (equal p-class (cdar rule)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
158 (setq matched nil
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
159 rule nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
160 (setq rule (cdr rule)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
161 matched))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
162
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
163 (defsubst css-get-internal (tag args)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
164 (declare (special tag sheet element-stack default))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
165 (setq css-scratch-id (or (cdr-safe (assq 'id args))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
166 (cdr-safe (assq 'name args)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
167 css-scratch-class (or (cdr-safe (assq 'class args)) t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
168 css-scratch-possibles (cl-gethash tag sheet))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
169 (while css-scratch-possibles
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
170 (setq css-scratch-current (car css-scratch-possibles)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
171 css-scratch-current-rule (car css-scratch-current)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
172 css-scratch-current-value (cdr css-scratch-current)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
173 css-scratch-classes (if (listp (car css-scratch-current-rule))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
174 (cdar css-scratch-current-rule)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
175 (cdr css-scratch-current-rule))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
176 css-scratch-class-match t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
177 css-scratch-possibles (cdr css-scratch-possibles))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
178 (if (eq t css-scratch-classes)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
179 (setq css-scratch-classes nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
180 (if (eq t css-scratch-class)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
181 (setq css-scratch-class nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
182 (while css-scratch-classes
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
183 (if (not (member (pop css-scratch-classes) css-scratch-class))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
184 (setq css-scratch-class-match nil
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
185 css-scratch-classes nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
186 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
187 ((and (listp (car css-scratch-current-rule)) css-scratch-class-match)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
188 ;; Contextual!
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
189 (setq css-scratch-current-rule (cdr css-scratch-current-rule))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
190 (if (css-contextual-match css-scratch-current-rule element-stack)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
191 (setq css-scratch-val
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
192 (append css-scratch-val css-scratch-current-value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
193 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
194 (css-scratch-class-match
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
195 (setq css-scratch-val (append css-scratch-val css-scratch-current-value))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
196 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
197 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
198 nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
199 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
200 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
201
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
202 (defsubst css-get (tag args &optional sheet element-stack)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
203 (setq css-scratch-val nil
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
204 css-scratch-class (or (cdr-safe (assq 'class args)) t))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
205
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
206 ;; check for things without the class
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
207 (if (listp css-scratch-class)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
208 (css-get-internal tag nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
209
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
210 ;; check for global class values
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
211 (css-get-internal '*document args)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
212
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
213 ;; Now check for things with the class - they will be stuck on the front
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
214 ;; of the list, which will mean we do the right thing
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
215 (css-get-internal tag args)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
216
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
217 ;; Defaults are up to the calling application to provide
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
218 css-scratch-val)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
219
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
220 (defun css-ancestor-get (info ancestors sheet)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
221 ;; Inheritable property, check ancestors
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
222 (let (cur)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
223 (while ancestors
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
224 (setq cur (car ancestors)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
225 css-scratch-val (css-get info (car cur) (cdr cur) sheet)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
226 ancestors (if css-scratch-val nil (cdr ancestors)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
227 css-scratch-val)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
228
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
229 (defun css-split-selector (tag)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
230 ;; Return a list
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
231 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
232 ((string-match " " tag) ; contextual
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
233 (let ((tags (split-string tag "[ \t]+"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
234 (result nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
235 (while tags
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
236 (setq result (cons (css-split-selector (car tags)) result)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
237 tags (cdr tags)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
238 result))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
239 ((string-match "[:\\.]" tag)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
240 (let ((tag (if (= (match-beginning 0) 0)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
241 '*document
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
242 (intern (downcase (substring tag 0 (match-beginning 0))))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
243 (rest (substring tag (match-beginning 0) nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
244 (classes nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
245 (while (string-match "^[:\\.][^:\\.]+" rest)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
246 (if (= ?. (aref rest 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
247 (setq classes (cons (substring rest 1 (match-end 0)) classes))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
248 (setq classes (cons (substring rest 0 (match-end 0)) classes)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
249 (setq rest (substring rest (match-end 0) nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
250 (setq classes (sort classes 'string-lessp))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
251 (cons tag classes)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
252 ((string-match "^#" tag) ; id selector
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
253 (cons '*document tag))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
254 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
255 (cons (intern (downcase tag)) t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
256 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
257 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
258 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
259
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
260 (defun css-applies-to (st nd)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
261 (let ((results nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
262 (save-pos nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
263 (narrow-to-region st nd)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
264 (goto-char st)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
265 (skip-chars-forward " \t\r\n")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
266 (while (not (eobp))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
267 (setq save-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
268 (skip-chars-forward "^,")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
269 (skip-chars-backward " \r\t\n")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
270 (setq results (cons (css-split-selector
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
271 (buffer-substring save-pos (point))) results))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
272 (skip-chars-forward ", \t\r\n"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
273 (widen)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
274 results))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
275
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
276 (defun css-split-font-shorthand (font)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
277 ;; [<font-weight> || <font-style>]? <font-size> [ / <line-height> ]? <font-family>
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
278 (let (weight size height family retval)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
279 (if (not (string-match " *\\([0-9.]+[^ /]+\\)" font))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
280 (error "Malformed font shorthand: %s" font))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
281 (setq weight (if (/= 0 (match-beginning 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
282 (substring font 0 (match-beginning 0)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
283 size (match-string 1 font)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
284 font (substring font (match-end 0) nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
285 (if (string-match " */ *\\([^ ]+\\) *" font)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
286 ;; they specified a line-height as well
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
287 (setq height (match-string 1 font)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
288 family (substring font (match-end 0) nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
289 (if (string-match "^[ \t]+" font)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
290 (setq family (substring font (match-end 0) nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
291 (setq family font)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
292 (if weight (setq retval (cons (cons 'font-weight weight) retval)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
293 (if size (setq retval (cons (cons 'font-size size) retval)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
294 (if height (setq retval (cons (cons 'line-height height) retval)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
295 (if family (setq retval (cons (cons 'font-family family) retval)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
296 retval))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
297
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
298 (defun css-expand-length (spec)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
299 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
300 ((not (stringp spec)) spec)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
301 ((string-equal spec "auto") nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
302 ((string-match "\([0-9]+\)%" spec) ; A percentage
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
303 nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
304 ((string-match "\([0-9]+\)e[mn]" spec) ; Character based
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
305 (string-to-int (substring spec (match-beginning 1) (match-end 1))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
306 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
307 (truncate (font-spatial-to-canonical spec)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
308 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
309 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
310
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
311 (defsubst css-unhex-char (x)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
312 (if (> x ?9)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
313 (if (>= x ?a)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
314 (+ 10 (- x ?a))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
315 (+ 10 (- x ?A)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
316 (- x ?0)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
317
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
318 (defsubst css-pow (x n)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
319 (apply '* (make-list n x)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
320
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
321 (defun css-unhex (x)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
322 (let ((ord (length x))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
323 (rval 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
324 (while (> ord 0)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
325 (setq rval (+ rval
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
326 (* (css-pow 16 (- (length x) ord))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
327 (css-unhex-char (aref x (1- ord)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
328 ord (1- ord)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
329 rval))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
330
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
331 (defun css-expand-color (color)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
332 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
333 ((string-match "^#" color)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
334 (let (r g b)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
335 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
336 ((string-match "^#...$" color)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
337 ;; 3-char rgb spec, expand out to six chars by replicating
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
338 ;; digits, not adding zeros.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
339 (setq r (css-unhex (make-string 2 (aref color 1)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
340 g (css-unhex (make-string 2 (aref color 2)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
341 b (css-unhex (make-string 2 (aref color 3)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
342 ((string-match "^#\\(..\\)\\(..\\)\\(..\\)$" color)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
343 (setq r (css-unhex (match-string 1 color))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
344 g (css-unhex (match-string 2 color))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
345 b (css-unhex (match-string 3 color))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
346 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
347 (setq color (substring color 1))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
348 (let* ((n (/ (length color) 3))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
349 (max (float (css-pow 16 n))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
350 (setq r (css-unhex (substring color 0 n))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
351 g (css-unhex (substring color n (* n 2)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
352 b (css-unhex (substring color (* n 2) (* n 3)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
353 r (round (* (/ r max) 255))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
354 g (round (* (/ g max) 255))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
355 b (round (* (/ b max) 255))))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
356 (setq color (vector 'rgb r g b))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
357 ((string-match "^rgb *( *\\([0-9]+\\)[, ]+\\([0-9]+\\)[, ]+\\([0-9]+\\) *) *$" color)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
358 ;; rgb(r,g,b) 0 - 255, cutting off at 255
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
359 (setq color (vector
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
360 'rgb
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
361 (min (string-to-int (match-string 1 color)) 255)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
362 (min (string-to-int (match-string 2 color)) 255)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
363 (min (string-to-int (match-string 3 color)) 255))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
364 ((string-match "^rgb *( *\\([0-9]+\\) *%[, ]+\\([0-9]+\\) *%[, ]+\\([0-9]+\\) *% *) *$" color)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
365 ;; rgb(r%,g%,b%) 0 - 100%, cutting off at 100%
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
366 (let ((r (min (string-to-number (match-string 1 color)) 100.0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
367 (g (min (string-to-number (match-string 2 color)) 100.0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
368 (b (min (string-to-number (match-string 3 color)) 100.0)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
369 (setq r (round (* r 2.55))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
370 g (round (* g 2.55))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
371 b (round (* b 2.55))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
372 color (vector 'rgb r g b))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
373 ((string-match "url *(\\([^ )]+\\) *)" color)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
374 ;; A picture in the background
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
375 (let ((pixmap (match-string 1 color))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
376 (attributes nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
377 (setq color (concat (substring color 0 (match-beginning 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
378 (substring color (match-end 0) nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
379 attributes (split-string color " "))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
380 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
381 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
382 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
383 ;; Hmmm... pass it through unmangled and hope the underlying
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
384 ;; windowing system can handle it.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
385 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
386 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
387 color
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
388 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
389
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
390 (defun css-expand-value (type value)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
391 (case type
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
392 ((symbol integer) ; Read it in
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
393 (setq value (read (downcase value))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
394 (symbol-list
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
395 (setq value (downcase value)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
396 value (split-string value "[ ,]+")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
397 value (mapcar 'intern value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
398 (string-list
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
399 (setq value (split-string value " *, *")))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
400 (color ; A color, possibly with URLs
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
401 (setq value (css-expand-color value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
402 (length ; Pixels, picas, ems, etc.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
403 (setq value (css-expand-length value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
404 (font ; Font shorthand
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
405 (setq value (css-split-font-shorthand value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
406 ((margin padding) ; length|percentage|auto {1,4}
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
407 (setq value (split-string value "[ ,]+"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
408 (if (/= 1 (length value))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
409 ;; More than one value - a shortcut
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
410 (let* ((top (intern (format "%s-top" type)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
411 (bottom (intern (format "%s-bottom" type)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
412 (left (intern (format "%s-left" type)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
413 (right (intern (format "%s-right" type))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
414 (setq top (cons top (css-expand-length (nth 0 value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
415 right (cons right (css-expand-length (nth 1 value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
416 bottom (cons bottom (css-expand-length (nth 2 value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
417 left (cons left (css-expand-length (nth 3 value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
418 value (list top right bottom left)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
419 (setq value (css-expand-length (car value)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
420 (border
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
421 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
422 ((member (downcase value) '("none" "dotted" "dashed" "solid"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
423 "double" "groove" "ridge" "inset" "outset"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
424 (setq value (intern (downcase value))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
425 ((string-match "^[0-9]+" value)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
426 (setq value (font-spatial-to-canonical value)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
427 (t nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
428 (weight ; normal|bold|bolder|lighter|[1-9]00
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
429 (if (string-match "^[0-9]+" value)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
430 (setq value (/ (read value) 100)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
431 value (or (nth value css-weights) :bold))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
432 (setq value (intern (downcase (concat ":" value))))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
433 (otherwise ; Leave it as is
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
434 t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
435 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
436 value
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
437 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
438
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
439 (defun css-parse-args (st &optional nd)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
440 ;; Return an assoc list of attribute/value pairs from a CSS style entry
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
441 (let (
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
442 name ; From name=
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
443 value ; its value
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
444 results ; Assoc list of results
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
445 name-pos ; Start of XXXX= position
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
446 val-pos ; Start of value position
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
447 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
448 (save-excursion
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
449 (if (stringp st)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
450 (progn
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
451 (set-buffer (get-buffer-create " *css-style-temp*"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
452 (set-syntax-table css-syntax-table)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
453 (erase-buffer)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
454 (insert st)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
455 (setq st (point-min)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
456 nd (point-max)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
457 (set-syntax-table css-syntax-table))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
458 (save-restriction
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
459 (narrow-to-region st nd)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
460 (goto-char (point-min))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
461 (while (not (eobp))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
462 (skip-chars-forward ";, \n\t")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
463 (setq name-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
464 (skip-chars-forward "^ \n\t:=,;")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
465 (downcase-region name-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
466 (setq name (intern (buffer-substring name-pos (point))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
467 (skip-chars-forward " \t\n")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
468 (if (not (eq (char-after (point)) ?:)) ; There is no value
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
469 (setq value nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
470 (skip-chars-forward " \t\n:")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
471 (setq val-pos (point)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
472 value
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
473 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
474 ((or (= (or (char-after val-pos) 0) ?\")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
475 (= (or (char-after val-pos) 0) ?'))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
476 (buffer-substring (1+ val-pos)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
477 (condition-case ()
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
478 (prog2
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
479 (forward-sexp 1)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
480 (1- (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
481 (skip-chars-forward "\""))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
482 (error
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
483 (skip-chars-forward "^ \t\n")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
484 (point)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
485 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
486 (buffer-substring val-pos
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
487 (progn
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
488 (if css-ie-compatibility
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
489 (skip-chars-forward "^;")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
490 (skip-chars-forward "^,;"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
491 (skip-chars-backward " \t")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
492 (point)))))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
493 (setq value (css-expand-value (get name 'css-type) value))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
494 (if (eq (get name 'css-type) 'font)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
495 (setq results (append value results))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
496 (setq results (cons (cons name value) results)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
497 (skip-chars-forward ";, \n\t"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
498 results))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
499
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
500 (defun css-handle-import ()
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
501 (let ((url nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
502 (save-pos (point)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
503 (if (looking-at "'\"")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
504 (condition-case ()
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
505 (forward-sexp 1)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
506 (error (skip-chars-forward "^ \t\r\n;")))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
507 (skip-chars-forward "^ \t\r\n;"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
508 (setq url (url-expand-file-name (buffer-substring save-pos (point))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
509 (skip-chars-forward "\"; \t\r\n")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
510 (setq save-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
511 (let ((url-working-buffer (generate-new-buffer-name " *styleimport*"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
512 (url-mime-accept-string
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
513 "text/css ; level=2")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
514 (sheet nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
515 (save-excursion
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
516 (set-buffer (get-buffer-create url-working-buffer))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
517 (setq url-be-asynchronous nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
518 (url-retrieve url)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
519 (css-clean-buffer)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
520 (setq sheet (buffer-string))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
521 (set-buffer-modified-p nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
522 (kill-buffer (current-buffer)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
523 (insert sheet)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
524 (goto-char save-pos))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
525
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
526 (defun css-clean-buffer ()
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
527 ;; Nuke comments, etc.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
528 (goto-char (point-min))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
529 (let ((save-pos nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
530 (while (search-forward "/*" nil t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
531 (setq save-pos (- (point) 2))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
532 (delete-region save-pos
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
533 (if (search-forward "*/" nil t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
534 (point)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
535 (end-of-line)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
536 (point)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
537 (goto-char (point-min))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
538 (delete-matching-lines "^[ \t\r]*$") ; Nuke blank lines
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
539 (css-replace-regexp "^[ \t\r]+" "") ; Nuke whitespace at beg. of line
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
540 (css-replace-regexp "[ \t\r]+$" "") ; Nuke whitespace at end of line
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
541 (goto-char (point-min)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
542
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
543 (defun css-active-device-types (&optional device)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
544 (let ((types (list 'normal 'default (if css-running-xemacs 'xemacs 'emacs)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
545 (type (device-type device)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
546 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
547 ((featurep 'emacspeak)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
548 (setq types (cons 'speech types)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
549 ((eq type 'tty)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
550 (if (and (fboundp 'tty-color-list)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
551 (/= 0 (length (tty-color-list))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
552 (setq types (cons 'ansi-tty types))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
553 (setq types (cons 'tty types))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
554 ((eq 'color (device-class))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
555 (if (not (device-bitplanes))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
556 (setq types (cons 'color types))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
557 (setq types
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
558 (append
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
559 (list (intern (format "%dbit-color"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
560 (device-bitplanes)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
561 (intern (format "%dbit"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
562 (device-bitplanes)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
563 'color) types))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
564 (if (= 24 (device-bitplanes))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
565 (setq types (cons 'truecolor types)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
566 ((eq 'grayscale (device-class))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
567 (setq types (append (list (intern (format "%dbit-grayscale"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
568 (device-bitplanes)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
569 'grayscale)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
570 types)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
571 ((eq 'mono (device-class))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
572 (setq types (append (list 'mono 'monochrome) types)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
573 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
574 (setq types (cons 'unknown types))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
575 types))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
576
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
577 (defmacro css-rule-specificity-internal (rule)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
578 (`
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
579 (progn
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
580 (setq tmp (cdr (, rule)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
581 (if (listp tmp)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
582 (while tmp
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
583 (if (= ?# (aref (car tmp) 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
584 (incf a)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
585 (incf b))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
586 (setq tmp (cdr tmp)))))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
587
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
588 (defsubst css-specificity (rule)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
589 ;; To find specificity, according to the september 1996 CSS draft
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
590 ;; a = # of ID attributes in the selector
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
591 ;; b = # of class attributes in the selector
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
592 ;; c = # of tag names in the selector
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
593 (let ((a 0) (b 0) (c 0) cur tmp)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
594 (if (not (listp (car rule)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
595 (css-rule-specificity-internal rule)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
596 (setq c (length rule))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
597 (while rule
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
598 (css-rule-specificity-internal (pop rule))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
599 (+ (* 100 a) (* 10 b) c)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
600 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
601 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
602
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
603 (defun css-copy-stylesheet (sheet)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
604 (let ((new (make-hash-table :size (hash-table-count sheet))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
605 (cl-maphash
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
606 (function
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
607 (lambda (k v)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
608 (cl-puthash k (copy-tree v) new))) sheet)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
609 new))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
610
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
611 (defsubst css-store-rule (attrs applies-to)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
612 (declare (special sheet))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
613 (let (rules cur tag node)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
614 (while applies-to
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
615 (setq cur (pop applies-to)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
616 tag (car cur))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
617 (if (listp tag)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
618 (setq tag (car tag)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
619 (setq rules (cl-gethash tag sheet))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
620 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
621 ((null rules)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
622 ;; First rule for this tag. Create new ruleset
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
623 (cl-puthash tag (list (cons cur attrs)) sheet))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
624 ((setq node (assoc cur rules))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
625 ;; Similar rule already exists, splice in our information
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
626 (setcdr node (append attrs (cdr node))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
627 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
628 ;; First rule for this particular combination of tag/ancestors/class.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
629 ;; Slap it onto the existing set of rules and push back into sheet.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
630 (setq rules (cons (cons cur attrs) rules))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
631 (cl-puthash tag rules sheet))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
632 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
633 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
634 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
635 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
636
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
637 (defun css-parse (fname &optional string inherit)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
638 (let (
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
639 (url-mime-accept-string
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
640 "text/css ; level=2")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
641 (save-pos nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
642 (applies-to nil) ; List of tags to apply style to
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
643 (attrs nil) ; List of name/value pairs
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
644 (att nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
645 (cur nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
646 (val nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
647 (device-type nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
648 (active-device-types (css-active-device-types (selected-device)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
649 (sheet inherit))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
650 (if (not sheet)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
651 (setq sheet (make-hash-table :size 13 :test 'eq)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
652 (save-excursion
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
653 (set-buffer (get-buffer-create
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
654 (generate-new-buffer-name " *style*")))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
655 (set-syntax-table css-syntax-table)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
656 (erase-buffer)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
657 (if fname (url-insert-file-contents fname))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
658 (goto-char (point-max))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
659 (if string (insert string))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
660 (css-clean-buffer)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
661 (goto-char (point-min))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
662 (while (not (eobp))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
663 (setq save-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
664 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
665 ;; *sigh* SGML comments are being used to 'hide' data inlined
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
666 ;; with the <style> tag from older browsers.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
667 ((or (looking-at "<!--+") ; begin
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
668 (looking-at "--+>")) ; end
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
669 (goto-char (match-end 0)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
670 ;; C++ style comments, and we are doing IE compatibility
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
671 ((and (looking-at "//") css-ie-compatibility)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
672 (end-of-line))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
673 ;; Pre-Processor directives
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
674 ((looking-at "[ \t\r]*@\\([^ \t\r\n]\\)")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
675 (let ((directive nil))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
676 (skip-chars-forward " @\t\r") ; Past any leading whitespace
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
677 (setq save-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
678 (skip-chars-forward "^ \t\r\n") ; Past the @ directive
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
679 (downcase-region save-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
680 (setq directive (buffer-substring save-pos (point)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
681 (skip-chars-forward " \t\r") ; Past any trailing whitespace
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
682 (setq save-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
683 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
684 ((string= directive "import")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
685 (css-handle-import))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
686 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
687 (message "Unknown directive in stylesheet: @%s" directive)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
688 ;; Giving us some output device information
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
689 ((looking-at "[ \t\r]*:\\([^: \n]+\\):")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
690 (downcase-region (match-beginning 1) (match-end 1))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
691 (setq device-type (intern (buffer-substring (match-beginning 1)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
692 (match-end 1))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
693 (goto-char (match-end 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
694 (if (not (memq device-type active-device-types))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
695 ;; Not applicable to us... skip the info
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
696 (progn
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
697 (if (re-search-forward ":[^:{ ]*:" nil t)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
698 (goto-char (match-beginning 0))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
699 (goto-char (point-max))))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
700 ;; Default is to treat it like a stylesheet declaration
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
701 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
702 (skip-chars-forward "^{")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
703 ;;(downcase-region save-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
704 (setq applies-to (css-applies-to save-pos (point)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
705 (skip-chars-forward "^{")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
706 (setq save-pos (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
707 (condition-case ()
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
708 (forward-sexp 1)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
709 (error (goto-char (point-max))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
710 (end-of-line)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
711 (skip-chars-backward "\r}")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
712 (subst-char-in-region save-pos (point) ?\n ? )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
713 (subst-char-in-region save-pos (point) ?\r ? )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
714 ;; This is for not choking on garbage at the end of the buffer.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
715 ;; I get bit by this every once in a while when going through my
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
716 ;; socks gateway.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
717 (if (eobp)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
718 nil
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
719 (setq attrs (css-parse-args (1+ save-pos) (point)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
720 (skip-chars-forward "}\r\n")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
721 (css-store-rule attrs applies-to))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
722 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
723 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
724 (skip-chars-forward " \t\r\n"))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
725 (set-buffer-modified-p nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
726 (kill-buffer (current-buffer)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
727 sheet)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
728 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
729
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
730 ;; Tools for pretty-printing an existing stylesheet.
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
731 (defun css-rule-name (rule)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
732 (cond
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
733 ((listp (car rule)) ; Contextual
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
734 (mapconcat 'css-rule-name
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
735 (reverse rule) " "))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
736 ((listp (cdr rule)) ; More than one class
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
737 (let ((classes (cdr rule))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
738 (rval (symbol-name (car rule))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
739 (while classes
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
740 (setq rval (concat rval
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
741 (if (= (aref (car classes) 0) ?:)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
742 (pop classes)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
743 (concat "." (pop classes))))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
744 rval))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
745 (t
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
746 (symbol-name (car rule)))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
747
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
748 (defun css-display (sheet)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
749 (with-output-to-temp-buffer "CSS Stylesheet"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
750 (set-buffer standard-output)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
751 (indented-text-mode)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
752 (insert "# Stylesheet auto-regenerated by css.el\n#\n"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
753 "# This is a mixture of the default stylesheet and any\n"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
754 "# styles specified by the document. The rules are in no\n"
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
755 "# particular order.\n\n")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
756 (let (tmp cur goal-col)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
757 (cl-maphash
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
758 (function
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
759 (lambda (k v)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
760 (while v
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
761 (setq cur (pop v))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
762 (insert (css-rule-name (car cur)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
763 (insert " { ")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
764 (setq goal-col (point))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
765 (insert "\n")
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
766 ;; Display the rules
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
767 (setq tmp (cdr cur))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
768 (let (prop val)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
769 (while tmp
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
770 (setq prop (caar tmp)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
771 val (cdar tmp)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
772 tmp (cdr tmp))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
773 (case (get prop 'css-type)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
774 (symbol-list
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
775 (setq val (mapconcat 'symbol-name val ",")))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
776 (weight
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
777 (setq val (substring (symbol-name val) 1 nil)))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
778 (otherwise
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
779 nil)
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
780 )
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
781 (insert (format " %s: %s;\n" prop val))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
782 (insert "}\n\n");
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
783 )))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
784 sheet))))
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
785
9ee227acff29 Import from CVS: tag r19-15b90
cvs
parents:
diff changeset
786 (provide 'css)