%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /usr/local/share/emacs/27.2/lisp/
Upload File :
Create Path :
Current File : //usr/local/share/emacs/27.2/lisp/svg.elc

;ELC
;;; Compiled
;;; in Emacs version 27.2
;;; with all optimizations.

;;; This file uses dynamic docstrings, first added in Emacs 19.29.

;;; This file does not contain utf-8 non-ASCII characters,
;;; and so can be loaded in Emacs versions earlier than 23.

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;


(byte-code "\300\301!\210\300\302!\210\300\303!\207" [require cl-lib xml dom] 2)
#@191 Create a new, empty SVG image with dimensions WIDTH x HEIGHT.
ARGS can be used to provide `stroke' and `stroke-width' parameters to
any further elements added.

(fn WIDTH HEIGHT &rest ARGS)
(defalias 'svg-create #[642 "\300\301\302B\303B\304\305\306\307\310\"?\205\311\312\313\n\"\"BBBB\"\207" [dom-node svg width height (version . "1.1") (xmlns . "http://www.w3.org/2000/svg") append plist-get :xmlns:xlink ((xmlns:xlink . "http://www.w3.org/1999/xlink")) svg--arguments nil] 14 (#$ . 490)])
#@129 Add a gradient with ID to SVG.
TYPE is `linear' or `radial'.
STOPS is a list of percentage/color pairs.

(fn SVG ID TYPE STOPS)
(defalias 'svg-gradient #[1028 "\300\301\302\303=\203\304\202\305\306B\307B\310\311\"$\"\207" [svg--def apply dom-node linear linearGradient radialGradient id ((x1 . 0) (x2 . 0) (y1 . 0) (y2 . 1)) mapcar #[257 "\300\301\302\303\304@\"B\305ABD\"\207" [dom-node stop offset format "%s%%" stop-color] 7 "\n\n(fn STOP)"]] 13 (#$ . 997)])
#@286 Create a rectangle on SVG, starting at position X/Y, of WIDTH/HEIGHT.
ARGS is a plist of modifiers.  Possible values are

:stroke-width PIXELS   The line width.
:stroke-color COLOR    The line color.
:gradient ID           The gradient ID to use.

(fn SVG X Y WIDTH HEIGHT &rest ARGS)
(defalias 'svg-rectangle #[1413 "\300\301\302\303B\304B\305B\306B\307\n\"BBBB\"\"\207" [svg--append dom-node rect width height x y svg--arguments] 17 (#$ . 1478)])
#@104 Create a circle of RADIUS on SVG.
X/Y denote the center of the circle.

(fn SVG X Y RADIUS &rest ARGS)
(defalias 'svg-circle #[1156 "\300\301\302\303B\304B\305B\306\f	\"BBB\"\"\207" [svg--append dom-node circle cx cy r svg--arguments] 15 (#$ . 1947)])
#@129 Create an ellipse of X-RADIUS/Y-RADIUS on SVG.
X/Y denote the center of the ellipse.

(fn SVG X Y X-RADIUS Y-RADIUS &rest ARGS)
(defalias 'svg-ellipse #[1413 "\300\301\302\303	B\304	B\305	B\306	B\307\n\"BBBB\"\"\207" [svg--append dom-node ellipse cx cy rx ry svg--arguments] 17 (#$ . 2215)])
#@91 Create a line starting in X1/Y1, ending at X2/Y2 on SVG.

(fn SVG X1 Y1 X2 Y2 &rest ARGS)
(defalias 'svg-line #[1413 "\300\301\302\303	B\304B\305\nB\306	B\307\n\"BBBB\"\"\207" [svg--append dom-node line x1 x2 y1 y2 svg--arguments] 17 (#$ . 2522)])
#@107 Create a polyline going through POINTS on SVG.
POINTS is a list of x/y pairs.

(fn SVG POINTS &rest ARGS)
(defalias 'svg-polyline #[642 "\300\301\302\303\304\305\306#B\307\"B\"\"\207" [svg--append dom-node polyline points mapconcat #[257 "\300\301@A#\207" [format "%s %s"] 5 "\n\n(fn PAIR)"] ", " svg--arguments] 12 (#$ . 2787)])
#@106 Create a polygon going through POINTS on SVG.
POINTS is a list of x/y pairs.

(fn SVG POINTS &rest ARGS)
(defalias 'svg-polygon #[642 "\300\301\302\303\304\305\306#B\307\"B\"\"\207" [svg--append dom-node polygon points mapconcat #[257 "\300\301@A#\207" [format "%s %s"] 5 "\n\n(fn PAIR)"] ", " svg--arguments] 12 (#$ . 3133)])
#@230 Insert IMAGE into the SVG structure.
IMAGE should be a file name if DATAP is nil, and a binary string
otherwise.  IMAGE-TYPE should be a MIME image type, like
"image/jpeg" or the like.

(fn SVG IMAGE IMAGE-TYPE DATAP &rest ARGS)
(defalias 'svg-embed #[1156 "\300\301\302\303\304			#B\305\n\"B\"\"\207" [svg--append dom-node image xlink:href svg--image-data svg--arguments] 14 (#$ . 3476)])
#@44 Add TEXT to SVG.

(fn SVG TEXT &rest ARGS)
(defalias 'svg-text #[642 "\300\301\302\303\"\304!#\"\207" [svg--append dom-node text svg--arguments svg--encode-text] 10 (#$ . 3879)])
#@13 

(fn TEXT)
(defalias 'svg--encode-text #[257 "\300\301!r\211q\210\302\303\304\305\306!\307\"\310$\216c\210\311\211\203;\211@eb\210\312@\313\314#\2034\315A\314\211\313$\210\202 A\266\202\202\210eb\210m\204ag\211\316W\203P\317u\210\202]\320\317!\210\321\322\323\"\324\261\210\210\202?\325 *\207" [generate-new-buffer " *temp*" make-byte-code 0 "\301\300!\205	\302\300!\207" vconcat vector [buffer-name kill-buffer] 2 (("&" . "&amp;") ("<" . "&lt;") (">" . "&gt;")) search-forward nil t replace-match 128 1 delete-char "&#" format "%d" ";" buffer-string] 9 (#$ . 4071)])
#@17 

(fn SVG NODE)
(defalias 'svg--append #[514 "\300\211@:\203\211@A@\262\202\211A@\262\236A\205;\301\302\303\300\211@:\2030\211@A@\262\2025\211A@\262\236A!\304Q\"\211\203H\211@A\241\210\202M\305\"\210\210\306!\207" [id dom-by-id "\\`" regexp-quote "\\'" dom-append-child svg-possibly-update-image] 9 (#$ . 4663)])
#@31 

(fn IMAGE IMAGE-TYPE DATAP)
(defalias 'svg--image-data #[771 "\300\301!r\211q\210\302\303\304\305\306!\307\"\310$\216\311\312!\210\203!c\210\202%\313!\210\314ed\315#\210eb\210\316\317\261\210\320 *\207" [generate-new-buffer " *temp*" make-byte-code 0 "\301\300!\205	\302\300!\207" vconcat vector [buffer-name kill-buffer] 2 set-buffer-multibyte nil insert-file-contents base64-encode-region t "data:" ";base64," buffer-string] 10 (#$ . 5002)])
#@17 

(fn SVG ARGS)
(defalias 'svg--arguments #[514 "\301\302\"\206\303\211@:\203\211@A@\262\202\211A@\262\236A\301\304\"\206>\305\211@:\2037\211@A@\262\202<\211A@\262\236A\301\306\"\307\203N\303BB\262\203Y\310BB\262\203d\311BB\262\301\312\"\203\200\313\314\315\316\317\311\320\321\301
\312\"\"B\257\"\262\307\211\211:\203\265\262\211A\262\242\262\211@\262\322>\204\255\323\324\325!\326\"\"BB\262AA\262\202\204\266\207" [obarray plist-get :stroke-width stroke-width :stroke-color stroke-color :fill-color nil stroke fill :gradient append (x1 . 0) (x2 . 0) (y1 . 0) (y2 . 1) format "url(#%s)" (:stroke-color :stroke-width :gradient :fill-color) intern substring symbol-name 1] 17 (#$ . 5463)])
#@16 

(fn SVG DEF)
(defalias 'svg--def #[514 "\300\301\302\"\206\303\302!\304\"\210\211\262\"\210\207" [dom-append-child dom-by-tag defs dom-node dom-add-child-before] 7 (#$ . 6217)])
#@112 Return an image object from SVG.
PROPS is passed on to `create-image' as its PROPS list.

(fn SVG &rest PROPS)
(defalias 'svg-image #[385 "\300\301\302\303!r\211q\210\304\305\306\307\310!\311\"\312$\216\313!\210\314 *\262\315\316%\207" [apply create-image generate-new-buffer " *temp*" make-byte-code 0 "\301\300!\205	\302\300!\207" vconcat vector [buffer-name kill-buffer] 2 svg-print buffer-string svg t] 11 (#$ . 6412)])
#@105 Insert SVG as an image at point.
If the SVG is later changed, the image will also be updated.

(fn SVG)
(defalias 'svg-insert-image #[257 "\300!\301 \302!\210\303\304#\207" [svg-image point-marker insert-image dom-set-attribute :image] 7 (#$ . 6848)])
#@12 

(fn SVG)
(defalias 'svg-possibly-update-image #[257 "\300\211@:\203\211@A@\262\202\211A@\262\236A\211\2055\301\302!!\2055r\302!q\210\303\211T\304\305!$)\207" [:image buffer-live-p marker-buffer put-text-property display svg-image] 8 (#$ . 7110)])
#@72 Convert DOM into a string containing the xml representation.

(fn DOM)
(defalias 'svg-print #[257 "\211;\203\211c\207\300\301@\"c\210\211A@\211\2034\211@\300\302@\"\303H\304U\204-\300\305@A#c\210A\266\202\202\210\306c\210\211AA\211\203O\211@\307c\210\310!\210A\266\202\202;\210\300\311@\"c\207" [format "<%s" "%s" 0 58 " %s=\"%s\"" ">" " " svg-print "</%s>"] 7 (#$ . 7379)])
#@60 Remove the element identified by ID from SVG.

(fn SVG ID)
(defalias 'svg-remove #[514 "\300\301\302!\303Q\"@\211\205\304\"\207" [dom-by-id "\\`" regexp-quote "\\'" dom-remove-node] 7 (#$ . 7776)])
#@97 Delete PROPERTY from PLIST.
This is in contrast to merely setting it to 0.

(fn PLIST PROPERTY)
(defalias 'svg--plist-delete #[514 "\300\203@=\204\301@A@#\262AA\262\202\211\207" [nil plist-put] 7 (#$ . 7986)])
#@36 

(fn COMMAND-SYMBOL COMMAND-ARGS)
(defalias 'svg--path-command-symbol #[514 "\300!\301\302\"\203\303\302\"\202\303\304\"\305\203\227\202!\226!\207" [symbol-name plist-member :relative plist-get :default-relative intern] 6 (#$ . 8217)])
#@29 

(fn RX RY X Y &rest ARGS)
(defalias 'svg--elliptical-arc-coordinates #[1156 "\300\301\"\206\n\302\300\303\"\203\304\202\302\300\305\"\203!\304\202\"\302\257\207" [plist-get :x-axis-rotation 0 :large-arc 1 :sweep] 12 (#$ . 8474)])
#@36 

(fn COORDINATES-LIST &rest ARGS)
(defalias 'svg--elliptical-arc-command #[385 "\300\301\"\302\303\304\305\"\"B\207" [svg--path-command-symbol a apply append mapcar #[257 "\300\301\"\207" [apply svg--elliptical-arc-coordinates] 4 "\n\n(fn COORDINATES)"]] 8 (#$ . 8729)])
#@36 

(fn COORDINATES-LIST &rest ARGS)
(defalias 'svg--moveto-command #[385 "\300\301\"\302\303\304\305\"\"B\207" [svg--path-command-symbol m apply append mapcar #[257 "\211@AD\207" [] 3 "\n\n(fn COORDINATES)"]] 8 (#$ . 9011)])
#@19 

(fn &rest ARGS)
(defalias 'svg--closepath-command #[128 "\300\301\"C\207" [svg--path-command-symbol z] 4 (#$ . 9245)])
#@36 

(fn COORDINATES-LIST &rest ARGS)
(defalias 'svg--lineto-command #[385 "\300\301\"\302\303\304\305\"\"B\207" [svg--path-command-symbol l apply append mapcar #[257 "\211@AD\207" [] 3 "\n\n(fn COORDINATES)"]] 8 (#$ . 9373)])
#@35 

(fn COORDINATE-LIST &rest ARGS)
(defalias 'svg--horizontal-lineto-command #[385 "\300\301\"B\207" [svg--path-command-symbol h] 5 (#$ . 9607)])
#@35 

(fn COORDINATE-LIST &rest ARGS)
(defalias 'svg--vertical-lineto-command #[385 "\300\301\"B\207" [svg--path-command-symbol v] 5 (#$ . 9760)])
#@36 

(fn COORDINATES-LIST &rest ARGS)
(defalias 'svg--curveto-command #[385 "\300\301\"\302\303\"B\207" [svg--path-command-symbol c apply append] 6 (#$ . 9911)])
#@36 

(fn COORDINATES-LIST &rest ARGS)
(defalias 'svg--smooth-curveto-command #[385 "\300\301\"\302\303\"B\207" [svg--path-command-symbol s apply append] 6 (#$ . 10078)])
#@36 

(fn COORDINATES-LIST &rest ARGS)
(defalias 'svg--quadratic-bezier-curveto-command #[385 "\300\301\"\302\303\"B\207" [svg--path-command-symbol q apply append] 6 (#$ . 10253)])
#@36 

(fn COORDINATES-LIST &rest ARGS)
(defalias 'svg--smooth-quadratic-bezier-curveto-command #[385 "\300\301\"\302\303\"B\207" [svg--path-command-symbol t apply append] 6 (#$ . 10438)])
#@33 

(fn COMMAND DEFAULT-RELATIVE)
(defalias 'svg--eval-path-command #[514 "\300\301D\"\302K\303K\304K\305K\306K\307K\310K\311K\312K\313K\n\314\315\316\317\320&\n\321\"\322$\216\302\323M\210\303\324M\210\304\325M\210\305\326M\210\306\327M\210\307\330M\210\310\331M\210\311\332M\210\312\333M\210\313\334M\210\335\336\337!\340#)\207" [append :default-relative elliptical-arc smooth-quadratic-bezier-curveto quadratic-bezier-curveto smooth-curveto curveto vertical-lineto horizontal-lineto lineto closepath moveto make-byte-code 0 "\312\300M\210\313\301M\210\314\302M\210\315\303M\210\316\304M\210\317\305M\210\320\306M\210\321\307M\210\322\310M\210\323\311M\207" vconcat vector [elliptical-arc smooth-quadratic-bezier-curveto quadratic-bezier-curveto smooth-curveto curveto vertical-lineto horizontal-lineto lineto closepath moveto] 2 svg--elliptical-arc-command svg--smooth-quadratic-bezier-curveto-command svg--quadratic-bezier-curveto-command svg--smooth-curveto-command svg--curveto-command svg--vertical-lineto-command svg--horizontal-lineto-command svg--lineto-command svg--closepath-command svg--moveto-command mapconcat prin1-to-string apply " "] 29 (#$ . 10630)])
#@262 Add the outline of a shape to SVG according to COMMANDS.
Coordinates by default are absolute.  ARGS is a plist of
modifiers.  If :relative is t, then coordinates are relative to
the last position, or -- initially -- to the origin.

(fn SVG COMMANDS &rest ARGS)
(defalias 'svg-path #[642 "\300\301\"\302\301\"\303\304\305\306\307\310\311\312	!\313\"\314\315%\"\316#\317\320\321\322B\323\"B\"\"\207" [plist-get :relative svg--plist-delete mapconcat identity mapcar make-byte-code 257 "\301\300\"\207" vconcat vector [svg--eval-path-command] 4 "\n\n(fn COMMAND)" " " svg--append dom-node path d svg--arguments] 14 (#$ . 11829)])
#@211 Add a clipping path to SVG, where ARGS is a plist of modifiers.
If applied to a shape via the :clip-path property, parts of that
shape which lie outside of the clipping path are not drawn.

(fn SVG &rest ARGS)
(defalias 'svg-clip-path #[385 "\300\301\302\"\"\303\"\210\211\207" [dom-node clipPath svg--arguments svg--append] 7 (#$ . 12475)])
#@58 Add the custom node TAG to SVG.

(fn SVG TAG &rest ARGS)
(defalias 'svg-node #[642 "\300\301\"\"\302\"\210\211\207" [dom-node svg--arguments svg--append] 8 (#$ . 12827)])
(provide 'svg)

Zerion Mini Shell 1.0