Artifact ed1ac7e149327202a2533bbced8ecfd6163a1a63:


0000: 23 6c 61 6e 67 20 72 61 63 6b 65 74 0a 28 72 65  #lang racket.(re
0010: 71 75 69 72 65 0a 20 73 72 66 69 2f 31 37 0a 20  quire. srfi/17. 
0020: 73 72 66 69 2f 32 36 0a 20 66 66 69 2f 75 6e 73  srfi/26. ffi/uns
0030: 61 66 65 0a 20 66 66 69 2f 75 6e 73 61 66 65 2f  afe. ffi/unsafe/
0040: 63 76 65 63 74 6f 72 0a 20 22 62 61 73 65 2e 72  cvector. "base.r
0050: 6b 74 22 29 0a 0a 28 64 65 66 69 6e 65 20 6c 69  kt")..(define li
0060: 62 63 64 0a 20 20 28 63 61 73 65 20 28 73 79 73  bcd.  (case (sys
0070: 74 65 6d 2d 74 79 70 65 20 27 6f 73 29 0a 20 20  tem-type 'os).  
0080: 20 20 5b 28 77 69 6e 64 6f 77 73 29 0a 20 20 20    [(windows).   
0090: 20 20 28 66 66 69 2d 6c 69 62 20 22 63 64 22 29    (ffi-lib "cd")
00a0: 5d 0a 20 20 20 20 5b 65 6c 73 65 0a 20 20 20 20  ].    [else.    
00b0: 20 28 66 66 69 2d 6c 69 62 20 22 6c 69 62 63 64   (ffi-lib "libcd
00c0: 22 29 5d 29 29 0a 0a 3b 3b 20 7b 7b 7b 20 50 6f  ")]))..;; {{{ Po
00d0: 69 6e 74 20 64 72 61 77 69 6e 67 20 66 75 6e 63  int drawing func
00e0: 74 69 6f 6e 73 0a 0a 28 64 65 66 69 6e 65 20 63  tions..(define c
00f0: 61 6e 76 61 73 2d 70 69 78 65 6c 21 0a 20 20 28  anvas-pixel!.  (
0100: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22  get-ffi-obj.   "
0110: 63 64 43 61 6e 76 61 73 50 69 78 65 6c 22 20 6c  cdCanvasPixel" l
0120: 69 62 63 64 0a 20 20 20 28 5f 66 75 6e 20 28 63  ibcd.   (_fun (c
0130: 61 6e 76 61 73 20 78 20 79 20 5b 63 6f 6c 6f 72  anvas x y [color
0140: 20 28 63 61 6e 76 61 73 2d 66 6f 72 65 67 72 6f   (canvas-foregro
0150: 75 6e 64 20 63 61 6e 76 61 73 29 5d 29 0a 20 20  und canvas)]).  
0160: 20 20 20 20 20 20 20 3a 3a 20 5b 63 61 6e 76 61         :: [canva
0170: 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 78 20  s : _canvas] [x 
0180: 3a 20 5f 69 6e 74 5d 20 5b 79 20 3a 20 5f 69 6e  : _int] [y : _in
0190: 74 5d 20 5b 63 6f 6c 6f 72 20 3a 20 5f 75 6c 6f  t] [color : _ulo
01a0: 6e 67 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a  ng] -> _void))).
01b0: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d  .(define canvas-
01c0: 6d 61 72 6b 21 0a 20 20 28 67 65 74 2d 66 66 69  mark!.  (get-ffi
01d0: 2d 6f 62 6a 0a 20 20 20 22 63 64 43 61 6e 76 61  -obj.   "cdCanva
01e0: 73 4d 61 72 6b 22 20 6c 69 62 63 64 0a 20 20 20  sMark" libcd.   
01f0: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20  (_fun [canvas : 
0200: 5f 63 61 6e 76 61 73 5d 20 5b 78 20 3a 20 5f 69  _canvas] [x : _i
0210: 6e 74 5d 20 5b 79 20 3a 20 5f 69 6e 74 5d 20 2d  nt] [y : _int] -
0220: 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 64 65 66  > _void)))..(def
0230: 69 6e 65 20 5f 6d 61 72 6b 2d 74 79 70 65 0a 20  ine _mark-type. 
0240: 20 28 5f 65 6e 75 6d 0a 20 20 20 27 28 2b 20 3d   (_enum.   '(+ =
0250: 20 30 20 70 6c 75 73 20 3d 20 30 0a 20 20 20 20   0 plus = 0.    
0260: 20 2a 20 3d 20 31 20 73 74 61 72 20 3d 20 31 0a   * = 1 star = 1.
0270: 20 20 20 20 20 30 20 3d 20 32 20 63 69 72 63 6c       0 = 2 circl
0280: 65 20 3d 20 32 0a 20 20 20 20 20 58 20 3d 20 33  e = 2.     X = 3
0290: 20 78 20 3d 20 33 0a 20 20 20 20 20 62 6f 78 0a   x = 3.     box.
02a0: 20 20 20 20 20 64 69 61 6d 6f 6e 64 0a 20 20 20       diamond.   
02b0: 20 20 4f 20 3d 20 36 20 68 6f 6c 6c 6f 77 2d 63    O = 6 hollow-c
02c0: 69 72 63 6c 65 20 3d 20 36 0a 20 20 20 20 20 68  ircle = 6.     h
02d0: 6f 6c 6c 6f 77 2d 62 6f 78 0a 20 20 20 20 20 68  ollow-box.     h
02e0: 6f 6c 6c 6f 77 2d 64 69 61 6d 6f 6e 64 29 0a 20  ollow-diamond). 
02f0: 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 64 65    _fixint))..(de
0300: 66 69 6e 65 20 63 61 6e 76 61 73 2d 6d 61 72 6b  fine canvas-mark
0310: 2d 74 79 70 65 2d 73 65 74 21 0a 20 20 28 67 65  -type-set!.  (ge
0320: 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64  t-ffi-obj.   "cd
0330: 43 61 6e 76 61 73 4d 61 72 6b 54 79 70 65 22 20  CanvasMarkType" 
0340: 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 6e 20 5b  libcd.   (_fun [
0350: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73  canvas : _canvas
0360: 5d 20 5b 6d 61 72 6b 2d 74 79 70 65 20 3a 20 5f  ] [mark-type : _
0370: 6d 61 72 6b 2d 74 79 70 65 5d 20 2d 3e 20 5f 76  mark-type] -> _v
0380: 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 20  oid)))..(define 
0390: 63 61 6e 76 61 73 2d 6d 61 72 6b 2d 74 79 70 65  canvas-mark-type
03a0: 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74 68 2d  .  (getter-with-
03b0: 73 65 74 74 65 72 0a 20 20 20 28 67 65 74 2d 66  setter.   (get-f
03c0: 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64 43 61  fi-obj.    "cdCa
03d0: 6e 76 61 73 4d 61 72 6b 54 79 70 65 22 20 6c 69  nvasMarkType" li
03e0: 62 63 64 0a 20 20 20 20 28 5f 66 75 6e 20 5b 63  bcd.    (_fun [c
03f0: 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d  anvas : _canvas]
0400: 20 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 69 6e   [query : _fixin
0410: 74 20 3d 20 2d 31 5d 20 2d 3e 20 5b 6d 61 72 6b  t = -1] -> [mark
0420: 2d 74 79 70 65 20 3a 20 5f 6d 61 72 6b 2d 74 79  -type : _mark-ty
0430: 70 65 5d 29 29 0a 20 20 20 63 61 6e 76 61 73 2d  pe])).   canvas-
0440: 6d 61 72 6b 2d 74 79 70 65 2d 73 65 74 21 29 29  mark-type-set!))
0450: 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73  ..(define canvas
0460: 2d 6d 61 72 6b 2d 73 69 7a 65 2d 73 65 74 21 0a  -mark-size-set!.
0470: 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20    (get-ffi-obj. 
0480: 20 20 22 63 64 43 61 6e 76 61 73 4d 61 72 6b 53    "cdCanvasMarkS
0490: 69 7a 65 22 20 6c 69 62 63 64 0a 20 20 20 28 5f  ize" libcd.   (_
04a0: 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63  fun [canvas : _c
04b0: 61 6e 76 61 73 5d 20 5b 73 69 7a 65 20 3a 20 5f  anvas] [size : _
04c0: 69 6e 74 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29  int] -> _void)))
04d0: 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73  ..(define canvas
04e0: 2d 6d 61 72 6b 2d 73 69 7a 65 0a 20 20 28 67 65  -mark-size.  (ge
04f0: 74 74 65 72 2d 77 69 74 68 2d 73 65 74 74 65 72  tter-with-setter
0500: 0a 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a  .   (get-ffi-obj
0510: 0a 20 20 20 20 22 63 64 43 61 6e 76 61 73 4d 61  .    "cdCanvasMa
0520: 72 6b 53 69 7a 65 22 20 6c 69 62 63 64 0a 20 20  rkSize" libcd.  
0530: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20    (_fun [canvas 
0540: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 71 75 65 72  : _canvas] [quer
0550: 79 20 3a 20 5f 69 6e 74 20 3d 20 2d 31 5d 20 2d  y : _int = -1] -
0560: 3e 20 5b 73 69 7a 65 20 3a 20 5f 69 6e 74 5d 29  > [size : _int])
0570: 29 0a 20 20 20 63 61 6e 76 61 73 2d 6d 61 72 6b  ).   canvas-mark
0580: 2d 73 69 7a 65 2d 73 65 74 21 29 29 0a 0a 28 70  -size-set!))..(p
0590: 72 6f 76 69 64 65 0a 20 63 61 6e 76 61 73 2d 70  rovide. canvas-p
05a0: 69 78 65 6c 21 0a 20 63 61 6e 76 61 73 2d 6d 61  ixel!. canvas-ma
05b0: 72 6b 21 0a 20 63 61 6e 76 61 73 2d 6d 61 72 6b  rk!. canvas-mark
05c0: 2d 74 79 70 65 20 63 61 6e 76 61 73 2d 6d 61 72  -type canvas-mar
05d0: 6b 2d 74 79 70 65 2d 73 65 74 21 0a 20 63 61 6e  k-type-set!. can
05e0: 76 61 73 2d 6d 61 72 6b 2d 73 69 7a 65 20 63 61  vas-mark-size ca
05f0: 6e 76 61 73 2d 6d 61 72 6b 2d 73 69 7a 65 2d 73  nvas-mark-size-s
0600: 65 74 21 29 0a 0a 3b 3b 20 7d 7d 7d 0a 0a 3b 3b  et!)..;; }}}..;;
0610: 20 7b 7b 7b 20 4c 69 6e 65 20 66 75 6e 63 74 69   {{{ Line functi
0620: 6f 6e 73 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e  ons..(define can
0630: 76 61 73 2d 6c 69 6e 65 21 0a 20 20 28 67 65 74  vas-line!.  (get
0640: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 66  -ffi-obj.   "cdf
0650: 43 61 6e 76 61 73 4c 69 6e 65 22 20 6c 69 62 63  CanvasLine" libc
0660: 64 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76  d.   (_fun [canv
0670: 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 78  as : _canvas] [x
0680: 30 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 20 5b 79  0 : _double*] [y
0690: 30 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 20 5b 78  0 : _double*] [x
06a0: 31 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 20 5b 79  1 : _double*] [y
06b0: 31 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 20 2d 3e  1 : _double*] ->
06c0: 20 5f 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 69   _void)))..(defi
06d0: 6e 65 20 63 61 6e 76 61 73 2d 72 65 63 74 61 6e  ne canvas-rectan
06e0: 67 6c 65 21 0a 20 20 28 67 65 74 2d 66 66 69 2d  gle!.  (get-ffi-
06f0: 6f 62 6a 0a 20 20 20 22 63 64 66 43 61 6e 76 61  obj.   "cdfCanva
0700: 73 52 65 63 74 22 20 6c 69 62 63 64 0a 20 20 20  sRect" libcd.   
0710: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20  (_fun [canvas : 
0720: 5f 63 61 6e 76 61 73 5d 20 5b 78 30 20 3a 20 5f  _canvas] [x0 : _
0730: 64 6f 75 62 6c 65 2a 5d 20 5b 78 31 20 3a 20 5f  double*] [x1 : _
0740: 64 6f 75 62 6c 65 2a 5d 20 5b 79 30 20 3a 20 5f  double*] [y0 : _
0750: 64 6f 75 62 6c 65 2a 5d 20 5b 79 31 20 3a 20 5f  double*] [y1 : _
0760: 64 6f 75 62 6c 65 2a 5d 20 2d 3e 20 5f 76 6f 69  double*] -> _voi
0770: 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 63 61  d)))..(define ca
0780: 6e 76 61 73 2d 61 72 63 21 0a 20 20 28 67 65 74  nvas-arc!.  (get
0790: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 66  -ffi-obj.   "cdf
07a0: 43 61 6e 76 61 73 41 72 63 22 20 6c 69 62 63 64  CanvasArc" libcd
07b0: 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61  .   (_fun [canva
07c0: 73 20 3a 20 5f 63 61 6e 76 61 73 5d 0a 20 20 20  s : _canvas].   
07d0: 20 20 20 20 20 20 5b 78 20 3a 20 5f 64 6f 75 62        [x : _doub
07e0: 6c 65 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62 6c  le*] [y : _doubl
07f0: 65 2a 5d 20 5b 77 69 64 74 68 20 3a 20 5f 64 6f  e*] [width : _do
0800: 75 62 6c 65 2a 5d 20 5b 68 65 69 67 68 74 20 3a  uble*] [height :
0810: 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 20 20   _double*].     
0820: 20 20 20 20 5b 61 6c 70 68 61 30 20 3a 20 5f 64      [alpha0 : _d
0830: 6f 75 62 6c 65 2a 5d 20 5b 61 6c 70 68 61 31 20  ouble*] [alpha1 
0840: 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 20  : _double*].    
0850: 20 20 20 20 20 2d 3e 20 5f 76 6f 69 64 29 29 29       -> _void)))
0860: 0a 0a 28 64 65 66 69 6e 65 20 5f 6c 69 6e 65 2d  ..(define _line-
0870: 73 74 79 6c 65 0a 20 20 28 5f 65 6e 75 6d 0a 20  style.  (_enum. 
0880: 20 20 27 28 63 6f 6e 74 69 6e 75 6f 75 73 20 64    '(continuous d
0890: 61 73 68 65 64 20 64 6f 74 74 65 64 20 64 61 73  ashed dotted das
08a0: 68 2d 64 6f 74 74 65 64 20 64 61 73 68 2d 64 6f  h-dotted dash-do
08b0: 74 2d 64 6f 74 74 65 64 20 63 75 73 74 6f 6d 29  t-dotted custom)
08c0: 0a 20 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28  .   _fixint))..(
08d0: 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 6c 69  define canvas-li
08e0: 6e 65 2d 73 74 79 6c 65 2d 73 65 74 21 0a 20 20  ne-style-set!.  
08f0: 28 6c 65 74 72 65 63 20 28 5b 63 61 6e 76 61 73  (letrec ([canvas
0900: 2d 6c 69 6e 65 2d 73 74 79 6c 65 2d 73 65 74 2f  -line-style-set/
0910: 72 61 77 21 0a 20 20 20 20 20 20 20 20 20 20 20  raw!.           
0920: 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20   (get-ffi-obj.  
0930: 20 20 20 20 20 20 20 20 20 20 20 22 63 64 43 61             "cdCa
0940: 6e 76 61 73 4c 69 6e 65 53 74 79 6c 65 22 20 6c  nvasLineStyle" l
0950: 69 62 63 64 0a 20 20 20 20 20 20 20 20 20 20 20  ibcd.           
0960: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20    (_fun [canvas 
0970: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 6c 69 6e 65  : _canvas] [line
0980: 2d 73 74 79 6c 65 20 3a 20 5f 6c 69 6e 65 2d 73  -style : _line-s
0990: 74 79 6c 65 5d 20 2d 3e 20 5f 76 6f 69 64 29 29  tyle] -> _void))
09a0: 5d 0a 20 20 20 20 20 20 20 20 20 20 20 5b 63 61  ].           [ca
09b0: 6e 76 61 73 2d 6c 69 6e 65 2d 73 74 79 6c 65 2d  nvas-line-style-
09c0: 64 61 73 68 65 73 2d 73 65 74 2f 72 61 77 21 0a  dashes-set/raw!.
09d0: 20 20 20 20 20 20 20 20 20 20 20 20 28 67 65 74              (get
09e0: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20  -ffi-obj.       
09f0: 20 20 20 20 20 20 22 63 64 43 61 6e 76 61 73 4c        "cdCanvasL
0a00: 69 6e 65 53 74 79 6c 65 44 61 73 68 65 73 22 20  ineStyleDashes" 
0a10: 6c 69 62 63 64 0a 20 20 20 20 20 20 20 20 20 20  libcd.          
0a20: 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73     (_fun [canvas
0a30: 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 64 61 73   : _canvas] [das
0a40: 68 65 73 20 3a 20 5f 63 76 65 63 74 6f 72 5d 20  hes : _cvector] 
0a50: 5b 6c 65 6e 20 3a 20 5f 69 6e 74 20 3d 20 28 63  [len : _int = (c
0a60: 76 65 63 74 6f 72 2d 6c 65 6e 67 74 68 20 64 61  vector-length da
0a70: 73 68 65 73 29 5d 20 2d 3e 20 5f 76 6f 69 64 29  shes)] -> _void)
0a80: 29 5d 29 0a 20 20 20 20 28 ce bb 20 28 63 61 6e  )]).    (λ (can
0a90: 76 61 73 20 6c 69 6e 65 2d 73 74 79 6c 65 29 0a  vas line-style).
0aa0: 20 20 20 20 20 20 28 6d 61 74 63 68 20 6c 69 6e        (match lin
0ab0: 65 2d 73 74 79 6c 65 0a 20 20 20 20 20 20 20 20  e-style.        
0ac0: 5b 28 6c 69 73 74 2d 72 65 73 74 20 27 63 75 73  [(list-rest 'cus
0ad0: 74 6f 6d 20 64 61 73 68 65 73 29 0a 20 20 20 20  tom dashes).    
0ae0: 20 20 20 20 20 28 63 61 6e 76 61 73 2d 6c 69 6e       (canvas-lin
0af0: 65 2d 73 74 79 6c 65 2d 64 61 73 68 65 73 2d 73  e-style-dashes-s
0b00: 65 74 2f 72 61 77 21 20 63 61 6e 76 61 73 20 28  et/raw! canvas (
0b10: 6c 69 73 74 2d 3e 63 76 65 63 74 6f 72 20 64 61  list->cvector da
0b20: 73 68 65 73 20 5f 69 6e 74 29 29 0a 20 20 20 20  shes _int)).    
0b30: 20 20 20 20 20 28 63 61 6e 76 61 73 2d 6c 69 6e       (canvas-lin
0b40: 65 2d 73 74 79 6c 65 2d 73 65 74 2f 72 61 77 21  e-style-set/raw!
0b50: 20 63 61 6e 76 61 73 20 27 64 61 73 68 65 73 29   canvas 'dashes)
0b60: 5d 0a 20 20 20 20 20 20 20 20 5b 5f 0a 20 20 20  ].        [_.   
0b70: 20 20 20 20 20 20 28 63 61 6e 76 61 73 2d 6c 69        (canvas-li
0b80: 6e 65 2d 73 74 79 6c 65 2d 73 65 74 2f 72 61 77  ne-style-set/raw
0b90: 21 20 63 61 6e 76 61 73 20 6c 69 6e 65 2d 73 74  ! canvas line-st
0ba0: 79 6c 65 29 5d 29 29 29 29 0a 0a 28 64 65 66 69  yle)]))))..(defi
0bb0: 6e 65 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 73  ne canvas-line-s
0bc0: 74 79 6c 65 0a 20 20 28 67 65 74 74 65 72 2d 77  tyle.  (getter-w
0bd0: 69 74 68 2d 73 65 74 74 65 72 0a 20 20 20 28 67  ith-setter.   (g
0be0: 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 22  et-ffi-obj.    "
0bf0: 63 64 43 61 6e 76 61 73 4c 69 6e 65 53 74 79 6c  cdCanvasLineStyl
0c00: 65 22 20 6c 69 62 63 64 0a 20 20 20 20 28 5f 66  e" libcd.    (_f
0c10: 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61  un [canvas : _ca
0c20: 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 3a 20 5f  nvas] [query : _
0c30: 66 69 78 69 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20  fixint = -1] -> 
0c40: 5b 6c 69 6e 65 2d 73 74 79 6c 65 20 3a 20 5f 6c  [line-style : _l
0c50: 69 6e 65 2d 73 74 79 6c 65 5d 29 29 0a 20 20 20  ine-style])).   
0c60: 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 73 74 79 6c  canvas-line-styl
0c70: 65 2d 73 65 74 21 29 29 0a 0a 28 64 65 66 69 6e  e-set!))..(defin
0c80: 65 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 77 69  e canvas-line-wi
0c90: 64 74 68 2d 73 65 74 21 0a 20 20 28 67 65 74 2d  dth-set!.  (get-
0ca0: 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 43 61  ffi-obj.   "cdCa
0cb0: 6e 76 61 73 4c 69 6e 65 57 69 64 74 68 22 20 6c  nvasLineWidth" l
0cc0: 69 62 63 64 0a 20 20 20 28 5f 66 75 6e 20 5b 63  ibcd.   (_fun [c
0cd0: 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d  anvas : _canvas]
0ce0: 20 5b 77 69 64 74 68 20 3a 20 5f 69 6e 74 5d 20   [width : _int] 
0cf0: 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 64 65  -> _void)))..(de
0d00: 66 69 6e 65 20 63 61 6e 76 61 73 2d 6c 69 6e 65  fine canvas-line
0d10: 2d 77 69 64 74 68 0a 20 20 28 67 65 74 74 65 72  -width.  (getter
0d20: 2d 77 69 74 68 2d 73 65 74 74 65 72 0a 20 20 20  -with-setter.   
0d30: 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20  (get-ffi-obj.   
0d40: 20 22 63 64 43 61 6e 76 61 73 4c 69 6e 65 57 69   "cdCanvasLineWi
0d50: 64 74 68 22 20 6c 69 62 63 64 0a 20 20 20 20 28  dth" libcd.    (
0d60: 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f  _fun [canvas : _
0d70: 63 61 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 3a  canvas] [query :
0d80: 20 5f 69 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 5b   _int = -1] -> [
0d90: 77 69 64 74 68 20 3a 20 5f 69 6e 74 5d 29 29 0a  width : _int])).
0da0: 20 20 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 77     canvas-line-w
0db0: 69 64 74 68 2d 73 65 74 21 29 29 0a 0a 28 64 65  idth-set!))..(de
0dc0: 66 69 6e 65 20 5f 6c 69 6e 65 2d 6a 6f 69 6e 0a  fine _line-join.
0dd0: 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27 28 6d 69    (_enum.   '(mi
0de0: 74 65 72 20 62 65 76 65 6c 20 72 6f 75 6e 64 29  ter bevel round)
0df0: 0a 20 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28  .   _fixint))..(
0e00: 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 6c 69  define canvas-li
0e10: 6e 65 2d 6a 6f 69 6e 2d 73 65 74 21 0a 20 20 28  ne-join-set!.  (
0e20: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22  get-ffi-obj.   "
0e30: 63 64 43 61 6e 76 61 73 4c 69 6e 65 4a 6f 69 6e  cdCanvasLineJoin
0e40: 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 6e  " libcd.   (_fun
0e50: 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76   [canvas : _canv
0e60: 61 73 5d 20 5b 6c 69 6e 65 2d 6a 6f 69 6e 20 3a  as] [line-join :
0e70: 20 5f 6c 69 6e 65 2d 6a 6f 69 6e 5d 20 2d 3e 20   _line-join] -> 
0e80: 5f 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 6e  _void)))..(defin
0e90: 65 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 6a 6f  e canvas-line-jo
0ea0: 69 6e 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74  in.  (getter-wit
0eb0: 68 2d 73 65 74 74 65 72 0a 20 20 20 28 67 65 74  h-setter.   (get
0ec0: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64  -ffi-obj.    "cd
0ed0: 43 61 6e 76 61 73 4c 69 6e 65 4a 6f 69 6e 22 20  CanvasLineJoin" 
0ee0: 6c 69 62 63 64 0a 20 20 20 20 28 5f 66 75 6e 20  libcd.    (_fun 
0ef0: 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61  [canvas : _canva
0f00: 73 5d 20 5b 71 75 65 72 79 20 3a 20 5f 66 69 78  s] [query : _fix
0f10: 69 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 5f 76 6f  int = -1] -> _vo
0f20: 69 64 29 29 0a 20 20 20 63 61 6e 76 61 73 2d 6c  id)).   canvas-l
0f30: 69 6e 65 2d 6a 6f 69 6e 2d 73 65 74 21 29 29 0a  ine-join-set!)).
0f40: 0a 28 64 65 66 69 6e 65 20 5f 6c 69 6e 65 2d 63  .(define _line-c
0f50: 61 70 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27  ap.  (_enum.   '
0f60: 28 66 6c 61 74 20 73 71 75 61 72 65 20 72 6f 75  (flat square rou
0f70: 6e 64 29 0a 20 20 20 5f 66 69 78 69 6e 74 29 29  nd).   _fixint))
0f80: 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73  ..(define canvas
0f90: 2d 6c 69 6e 65 2d 63 61 70 2d 73 65 74 21 0a 20  -line-cap-set!. 
0fa0: 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20   (get-ffi-obj.  
0fb0: 20 22 63 64 43 61 6e 76 61 73 4c 69 6e 65 43 61   "cdCanvasLineCa
0fc0: 70 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75  p" libcd.   (_fu
0fd0: 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e  n [canvas : _can
0fe0: 76 61 73 5d 20 5b 6c 69 6e 65 2d 63 61 70 20 3a  vas] [line-cap :
0ff0: 20 5f 6c 69 6e 65 2d 63 61 70 5d 20 2d 3e 20 5f   _line-cap] -> _
1000: 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65  void)))..(define
1010: 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 63 61 70   canvas-line-cap
1020: 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74 68 2d  .  (getter-with-
1030: 73 65 74 74 65 72 0a 20 20 20 28 67 65 74 2d 66  setter.   (get-f
1040: 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64 43 61  fi-obj.    "cdCa
1050: 6e 76 61 73 4c 69 6e 65 43 61 70 22 20 6c 69 62  nvasLineCap" lib
1060: 63 64 0a 20 20 20 20 28 5f 66 75 6e 20 5b 63 61  cd.    (_fun [ca
1070: 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20  nvas : _canvas] 
1080: 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 69 6e 74  [query : _fixint
1090: 20 3d 20 2d 31 5d 20 2d 3e 20 5b 6c 69 6e 65 2d   = -1] -> [line-
10a0: 63 61 70 20 3a 20 5f 6c 69 6e 65 2d 63 61 70 5d  cap : _line-cap]
10b0: 29 29 0a 20 20 20 63 61 6e 76 61 73 2d 6c 69 6e  )).   canvas-lin
10c0: 65 2d 63 61 70 2d 73 65 74 21 29 29 0a 0a 28 70  e-cap-set!))..(p
10d0: 72 6f 76 69 64 65 0a 20 63 61 6e 76 61 73 2d 6c  rovide. canvas-l
10e0: 69 6e 65 21 20 63 61 6e 76 61 73 2d 72 65 63 74  ine! canvas-rect
10f0: 61 6e 67 6c 65 21 20 63 61 6e 76 61 73 2d 61 72  angle! canvas-ar
1100: 63 21 0a 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d  c!. canvas-line-
1110: 73 74 79 6c 65 20 63 61 6e 76 61 73 2d 6c 69 6e  style canvas-lin
1120: 65 2d 73 74 79 6c 65 2d 73 65 74 21 0a 20 63 61  e-style-set!. ca
1130: 6e 76 61 73 2d 6c 69 6e 65 2d 77 69 64 74 68 20  nvas-line-width 
1140: 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 77 69 64 74  canvas-line-widt
1150: 68 2d 73 65 74 21 0a 20 63 61 6e 76 61 73 2d 6c  h-set!. canvas-l
1160: 69 6e 65 2d 6a 6f 69 6e 20 63 61 6e 76 61 73 2d  ine-join canvas-
1170: 6c 69 6e 65 2d 6a 6f 69 6e 2d 73 65 74 21 0a 20  line-join-set!. 
1180: 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 63 61 70 20  canvas-line-cap 
1190: 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 63 61 70 2d  canvas-line-cap-
11a0: 73 65 74 21 29 0a 0a 3b 3b 20 7d 7d 7d 0a 0a 3b  set!)..;; }}}..;
11b0: 3b 20 7b 7b 7b 20 46 69 6c 6c 65 64 20 61 72 65  ; {{{ Filled are
11c0: 61 20 66 75 6e 63 74 69 6f 6e 73 0a 0a 28 64 65  a functions..(de
11d0: 66 69 6e 65 20 63 61 6e 76 61 73 2d 62 6f 78 21  fine canvas-box!
11e0: 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a  .  (get-ffi-obj.
11f0: 20 20 20 22 63 64 66 43 61 6e 76 61 73 42 6f 78     "cdfCanvasBox
1200: 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 6e  " libcd.   (_fun
1210: 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76   [canvas : _canv
1220: 61 73 5d 20 5b 78 30 20 3a 20 5f 64 6f 75 62 6c  as] [x0 : _doubl
1230: 65 2a 5d 20 5b 78 31 20 3a 20 5f 64 6f 75 62 6c  e*] [x1 : _doubl
1240: 65 2a 5d 20 5b 79 30 20 3a 20 5f 64 6f 75 62 6c  e*] [y0 : _doubl
1250: 65 2a 5d 20 5b 79 31 20 3a 20 5f 64 6f 75 62 6c  e*] [y1 : _doubl
1260: 65 2a 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a  e*] -> _void))).
1270: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d  .(define canvas-
1280: 73 65 63 74 6f 72 21 0a 20 20 28 67 65 74 2d 66  sector!.  (get-f
1290: 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 66 43 61  fi-obj.   "cdfCa
12a0: 6e 76 61 73 53 65 63 74 6f 72 22 20 6c 69 62 63  nvasSector" libc
12b0: 64 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76  d.   (_fun [canv
12c0: 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 0a 20 20  as : _canvas].  
12d0: 20 20 20 20 20 20 20 5b 78 20 3a 20 5f 64 6f 75         [x : _dou
12e0: 62 6c 65 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62  ble*] [y : _doub
12f0: 6c 65 2a 5d 20 5b 77 69 64 74 68 20 3a 20 5f 64  le*] [width : _d
1300: 6f 75 62 6c 65 2a 5d 20 5b 68 65 69 67 68 74 20  ouble*] [height 
1310: 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 20  : _double*].    
1320: 20 20 20 20 20 5b 61 6c 70 68 61 30 20 3a 20 5f       [alpha0 : _
1330: 64 6f 75 62 6c 65 2a 5d 20 5b 61 6c 70 68 61 31  double*] [alpha1
1340: 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20   : _double*].   
1350: 20 20 20 20 20 20 2d 3e 20 5f 76 6f 69 64 29 29        -> _void))
1360: 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61  )..(define canva
1370: 73 2d 63 68 6f 72 64 21 0a 20 20 28 67 65 74 2d  s-chord!.  (get-
1380: 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 66 43  ffi-obj.   "cdfC
1390: 61 6e 76 61 73 43 68 6f 72 64 22 20 6c 69 62 63  anvasChord" libc
13a0: 64 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76  d.   (_fun [canv
13b0: 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 0a 20 20  as : _canvas].  
13c0: 20 20 20 20 20 20 20 5b 78 20 3a 20 5f 64 6f 75         [x : _dou
13d0: 62 6c 65 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62  ble*] [y : _doub
13e0: 6c 65 2a 5d 20 5b 77 69 64 74 68 20 3a 20 5f 64  le*] [width : _d
13f0: 6f 75 62 6c 65 2a 5d 20 5b 68 65 69 67 68 74 20  ouble*] [height 
1400: 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 20  : _double*].    
1410: 20 20 20 20 20 5b 61 6c 70 68 61 30 20 3a 20 5f       [alpha0 : _
1420: 64 6f 75 62 6c 65 2a 5d 20 5b 61 6c 70 68 61 31  double*] [alpha1
1430: 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20   : _double*].   
1440: 20 20 20 20 20 20 2d 3e 20 5f 76 6f 69 64 29 29        -> _void))
1450: 29 0a 0a 28 64 65 66 69 6e 65 20 5f 6f 70 61 63  )..(define _opac
1460: 69 74 79 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 20  ity.  (_enum.   
1470: 27 28 6f 70 61 71 75 65 20 74 72 61 6e 73 70 61  '(opaque transpa
1480: 72 65 6e 74 29 0a 20 20 20 5f 66 69 78 69 6e 74  rent).   _fixint
1490: 29 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76  ))..(define canv
14a0: 61 73 2d 62 61 63 6b 67 72 6f 75 6e 64 2d 6f 70  as-background-op
14b0: 61 63 69 74 79 2d 73 65 74 21 0a 20 20 28 67 65  acity-set!.  (ge
14c0: 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64  t-ffi-obj.   "cd
14d0: 43 61 6e 76 61 73 42 61 63 6b 4f 70 61 63 69 74  CanvasBackOpacit
14e0: 79 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75  y" libcd.   (_fu
14f0: 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e  n [canvas : _can
1500: 76 61 73 5d 20 5b 6f 70 61 63 69 74 79 20 3a 20  vas] [opacity : 
1510: 5f 6f 70 61 63 69 74 79 5d 20 2d 3e 20 5f 76 6f  _opacity] -> _vo
1520: 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 63  id)))..(define c
1530: 61 6e 76 61 73 2d 62 61 63 6b 67 72 6f 75 6e 64  anvas-background
1540: 2d 6f 70 61 63 69 74 79 0a 20 20 28 67 65 74 74  -opacity.  (gett
1550: 65 72 2d 77 69 74 68 2d 73 65 74 74 65 72 0a 20  er-with-setter. 
1560: 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20    (get-ffi-obj. 
1570: 20 20 20 22 63 64 43 61 6e 76 61 73 42 61 63 6b     "cdCanvasBack
1580: 4f 70 61 63 69 74 79 22 20 6c 69 62 63 64 0a 20  Opacity" libcd. 
1590: 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73     (_fun [canvas
15a0: 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 71 75 65   : _canvas] [que
15b0: 72 79 20 3a 20 5f 66 69 78 69 6e 74 20 3d 20 2d  ry : _fixint = -
15c0: 31 5d 20 2d 3e 20 5b 6f 70 61 63 69 74 79 20 3a  1] -> [opacity :
15d0: 20 5f 6f 70 61 63 69 74 79 5d 29 29 0a 20 20 20   _opacity])).   
15e0: 63 61 6e 76 61 73 2d 62 61 63 6b 67 72 6f 75 6e  canvas-backgroun
15f0: 64 2d 6f 70 61 63 69 74 79 2d 73 65 74 21 29 29  d-opacity-set!))
1600: 0a 0a 28 64 65 66 69 6e 65 20 5f 66 69 6c 6c 2d  ..(define _fill-
1610: 6d 6f 64 65 0a 20 20 28 5f 65 6e 75 6d 0a 20 20  mode.  (_enum.  
1620: 20 27 28 65 76 65 6e 2d 6f 64 64 20 77 69 6e 64   '(even-odd wind
1630: 69 6e 67 29 0a 20 20 20 5f 66 69 78 69 6e 74 29  ing).   _fixint)
1640: 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61  )..(define canva
1650: 73 2d 66 69 6c 6c 2d 6d 6f 64 65 2d 73 65 74 21  s-fill-mode-set!
1660: 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a  .  (get-ffi-obj.
1670: 20 20 20 22 63 64 43 61 6e 76 61 73 46 69 6c 6c     "cdCanvasFill
1680: 4d 6f 64 65 22 20 6c 69 62 63 64 0a 20 20 20 28  Mode" libcd.   (
1690: 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f  _fun [canvas : _
16a0: 63 61 6e 76 61 73 5d 20 5b 66 69 6c 6c 2d 6d 6f  canvas] [fill-mo
16b0: 64 65 20 3a 20 5f 66 69 6c 6c 2d 6d 6f 64 65 5d  de : _fill-mode]
16c0: 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 64   -> _void)))..(d
16d0: 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 66 69 6c  efine canvas-fil
16e0: 6c 2d 6d 6f 64 65 0a 20 20 28 67 65 74 74 65 72  l-mode.  (getter
16f0: 2d 77 69 74 68 2d 73 65 74 74 65 72 0a 20 20 20  -with-setter.   
1700: 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20  (get-ffi-obj.   
1710: 20 22 63 64 43 61 6e 76 61 73 46 69 6c 6c 4d 6f   "cdCanvasFillMo
1720: 64 65 22 20 6c 69 62 63 64 0a 20 20 20 20 28 5f  de" libcd.    (_
1730: 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63  fun [canvas : _c
1740: 61 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 3a 20  anvas] [query : 
1750: 5f 66 69 78 69 6e 74 20 3d 20 2d 31 5d 20 2d 3e  _fixint = -1] ->
1760: 20 5b 66 69 6c 6c 2d 6d 6f 64 65 20 3a 20 5f 66   [fill-mode : _f
1770: 69 6c 6c 2d 6d 6f 64 65 5d 29 29 0a 20 20 20 63  ill-mode])).   c
1780: 61 6e 76 61 73 2d 66 69 6c 6c 2d 6d 6f 64 65 2d  anvas-fill-mode-
1790: 73 65 74 21 29 29 0a 0a 28 64 65 66 69 6e 65 20  set!))..(define 
17a0: 5f 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 0a  _interior-style.
17b0: 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27 28 73 6f    (_enum.   '(so
17c0: 6c 69 64 20 68 61 74 63 68 20 73 74 69 70 70 6c  lid hatch stippl
17d0: 65 20 70 61 74 74 65 72 6e 20 23 66 29 0a 20 20  e pattern #f).  
17e0: 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 64 65 66   _fixint))..(def
17f0: 69 6e 65 20 5f 68 61 74 63 68 2d 73 74 79 6c 65  ine _hatch-style
1800: 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27 28 68  .  (_enum.   '(h
1810: 6f 72 69 7a 6f 6e 74 61 6c 20 76 65 72 74 69 63  orizontal vertic
1820: 61 6c 20 66 6f 72 77 61 72 64 2d 64 69 61 67 6f  al forward-diago
1830: 6e 61 6c 20 62 61 63 6b 77 61 72 64 2d 64 69 61  nal backward-dia
1840: 67 6f 6e 61 6c 20 63 72 6f 73 73 20 64 69 61 67  gonal cross diag
1850: 6f 6e 61 6c 2d 63 72 6f 73 73 29 0a 20 20 20 5f  onal-cross).   _
1860: 66 69 78 69 6e 74 29 29 0a 0a 28 64 65 66 69 6e  fixint))..(defin
1870: 65 20 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f  e canvas-interio
1880: 72 2d 73 74 79 6c 65 2d 73 65 74 21 0a 20 20 28  r-style-set!.  (
1890: 6c 65 74 72 65 63 20 28 5b 63 61 6e 76 61 73 2d  letrec ([canvas-
18a0: 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 2d 73  interior-style-s
18b0: 65 74 2f 72 61 77 21 0a 20 20 20 20 20 20 20 20  et/raw!.        
18c0: 20 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a      (get-ffi-obj
18d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 22 63  .             "c
18e0: 64 43 61 6e 76 61 73 49 6e 74 65 72 69 6f 72 53  dCanvasInteriorS
18f0: 74 79 6c 65 22 20 6c 69 62 63 64 0a 20 20 20 20  tyle" libcd.    
1900: 20 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 5b           (_fun [
1910: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73  canvas : _canvas
1920: 5d 20 5b 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c  ] [interior-styl
1930: 65 20 3a 20 5f 69 6e 74 65 72 69 6f 72 2d 73 74  e : _interior-st
1940: 79 6c 65 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 5d  yle] -> _void))]
1950: 0a 20 20 20 20 20 20 20 20 20 20 20 5b 63 61 6e  .           [can
1960: 76 61 73 2d 68 61 74 63 68 2d 73 74 79 6c 65 2d  vas-hatch-style-
1970: 73 65 74 2f 72 61 77 21 0a 20 20 20 20 20 20 20  set/raw!.       
1980: 20 20 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62       (get-ffi-ob
1990: 6a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 22  j.             "
19a0: 63 64 43 61 6e 76 61 73 48 61 74 63 68 22 20 6c  cdCanvasHatch" l
19b0: 69 62 63 64 0a 20 20 20 20 20 20 20 20 20 20 20  ibcd.           
19c0: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20    (_fun [canvas 
19d0: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 68 61 74 63  : _canvas] [hatc
19e0: 68 2d 73 74 79 6c 65 20 3a 20 5f 68 61 74 63 68  h-style : _hatch
19f0: 2d 73 74 79 6c 65 5d 20 2d 3e 20 5f 76 6f 69 64  -style] -> _void
1a00: 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 5b  ))].           [
1a10: 63 61 6e 76 61 73 2d 73 74 69 70 70 6c 65 2d 73  canvas-stipple-s
1a20: 65 74 2f 72 61 77 21 0a 20 20 20 20 20 20 20 20  et/raw!.        
1a30: 20 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a      (get-ffi-obj
1a40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 22 63  .             "c
1a50: 64 43 61 6e 76 61 73 53 74 69 70 70 6c 65 22 20  dCanvasStipple" 
1a60: 6c 69 62 63 64 0a 20 20 20 20 20 20 20 20 20 20  libcd.          
1a70: 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73     (_fun [canvas
1a80: 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 77 69 64   : _canvas] [wid
1a90: 74 68 20 3a 20 5f 69 6e 74 5d 20 5b 68 65 69 67  th : _int] [heig
1aa0: 68 74 20 3a 20 5f 69 6e 74 5d 20 5b 64 61 74 61  ht : _int] [data
1ab0: 2a 20 3a 20 5f 63 76 65 63 74 6f 72 5d 20 2d 3e  * : _cvector] ->
1ac0: 20 5f 76 6f 69 64 29 29 5d 0a 20 20 20 20 20 20   _void))].      
1ad0: 20 20 20 20 20 5b 63 61 6e 76 61 73 2d 70 61 74       [canvas-pat
1ae0: 74 65 72 6e 2d 73 65 74 2f 72 61 77 21 0a 20 20  tern-set/raw!.  
1af0: 20 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66            (get-f
1b00: 66 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20  fi-obj.         
1b10: 20 20 20 20 22 63 64 43 61 6e 76 61 73 50 61 74      "cdCanvasPat
1b20: 74 65 72 6e 22 20 6c 69 62 63 64 0a 20 20 20 20  tern" libcd.    
1b30: 20 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 5b           (_fun [
1b40: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73  canvas : _canvas
1b50: 5d 20 5b 77 69 64 74 68 20 3a 20 5f 69 6e 74 5d  ] [width : _int]
1b60: 20 5b 68 65 69 67 68 74 20 3a 20 5f 69 6e 74 5d   [height : _int]
1b70: 20 5b 64 61 74 61 2a 20 3a 20 5f 63 76 65 63 74   [data* : _cvect
1b80: 6f 72 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 5d 29  or] -> _void))])
1b90: 0a 20 20 20 20 28 ce bb 20 28 63 61 6e 76 61 73  .    (λ (canvas
1ba0: 20 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 29   interior-style)
1bb0: 0a 20 20 20 20 20 20 28 6d 61 74 63 68 20 69 6e  .      (match in
1bc0: 74 65 72 69 6f 72 2d 73 74 79 6c 65 0a 20 20 20  terior-style.   
1bd0: 20 20 20 20 20 5b 28 6c 69 73 74 20 27 68 61 74       [(list 'hat
1be0: 63 68 20 68 61 74 63 68 2d 73 74 79 6c 65 29 0a  ch hatch-style).
1bf0: 20 20 20 20 20 20 20 20 20 28 63 61 6e 76 61 73           (canvas
1c00: 2d 68 61 74 63 68 2d 73 74 79 6c 65 2d 73 65 74  -hatch-style-set
1c10: 2f 72 61 77 21 20 63 61 6e 76 61 73 20 68 61 74  /raw! canvas hat
1c20: 63 68 2d 73 74 79 6c 65 29 0a 20 20 20 20 20 20  ch-style).      
1c30: 20 20 20 28 63 61 6e 76 61 73 2d 69 6e 74 65 72     (canvas-inter
1c40: 69 6f 72 2d 73 74 79 6c 65 2d 73 65 74 2f 72 61  ior-style-set/ra
1c50: 77 21 20 63 61 6e 76 61 73 20 27 68 61 74 63 68  w! canvas 'hatch
1c60: 29 5d 0a 20 20 20 20 20 20 20 20 5b 28 6c 69 73  )].        [(lis
1c70: 74 20 27 73 74 69 70 70 6c 65 20 77 69 64 74 68  t 'stipple width
1c80: 20 68 65 69 67 68 74 20 64 61 74 61 29 0a 20 20   height data).  
1c90: 20 20 20 20 20 20 20 28 6c 65 74 20 28 5b 64 61         (let ([da
1ca0: 74 61 2a 20 28 6d 61 6b 65 2d 63 76 65 63 74 6f  ta* (make-cvecto
1cb0: 72 20 5f 75 62 79 74 65 20 28 2a 20 77 69 64 74  r _ubyte (* widt
1cc0: 68 20 68 65 69 67 68 74 29 29 5d 29 0a 20 20 20  h height))]).   
1cd0: 20 20 20 20 20 20 20 20 28 66 6f 72 2a 20 28 5b          (for* ([
1ce0: 6a 20 28 69 6e 2d 72 61 6e 67 65 20 68 65 69 67  j (in-range heig
1cf0: 68 74 29 5d 20 5b 69 20 28 69 6e 2d 72 61 6e 67  ht)] [i (in-rang
1d00: 65 20 77 69 64 74 68 29 5d 0a 20 20 20 20 20 20  e width)].      
1d10: 20 20 20 20 20 20 20 20 20 20 20 20 5b 6f 66 73              [ofs
1d20: 2a 20 28 69 6e 2d 76 61 6c 75 65 20 28 2b 20 28  * (in-value (+ (
1d30: 2a 20 6a 20 77 69 64 74 68 29 20 69 29 29 5d 0a  * j width) i))].
1d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1d50: 20 20 5b 76 6f 66 73 20 28 69 6e 2d 76 61 6c 75    [vofs (in-valu
1d60: 65 20 28 71 75 6f 74 69 65 6e 74 20 6f 66 73 2a  e (quotient ofs*
1d70: 20 38 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20   8))].          
1d80: 20 20 20 20 20 20 20 20 5b 62 6f 66 73 20 28 69          [bofs (i
1d90: 6e 2d 76 61 6c 75 65 20 28 72 65 6d 61 69 6e 64  n-value (remaind
1da0: 65 72 20 6f 66 73 2a 20 38 29 29 5d 29 0a 20 20  er ofs* 8))]).  
1db0: 20 20 20 20 20 20 20 20 20 20 20 28 63 76 65 63             (cvec
1dc0: 74 6f 72 2d 73 65 74 21 20 64 61 74 61 2a 20 6f  tor-set! data* o
1dd0: 66 73 2a 20 28 62 69 74 77 69 73 65 2d 62 69 74  fs* (bitwise-bit
1de0: 2d 66 69 65 6c 64 20 28 62 79 74 65 73 2d 72 65  -field (bytes-re
1df0: 66 20 64 61 74 61 20 76 6f 66 73 29 20 62 6f 66  f data vofs) bof
1e00: 73 20 28 61 64 64 31 20 62 6f 66 73 29 29 29 29  s (add1 bofs))))
1e10: 0a 20 20 20 20 20 20 20 20 20 20 20 28 63 61 6e  .           (can
1e20: 76 61 73 2d 73 74 69 70 70 6c 65 2d 73 65 74 2f  vas-stipple-set/
1e30: 72 61 77 21 20 63 61 6e 76 61 73 20 77 69 64 74  raw! canvas widt
1e40: 68 20 68 65 69 67 68 74 20 64 61 74 61 2a 29 29  h height data*))
1e50: 0a 20 20 20 20 20 20 20 20 20 28 63 61 6e 76 61  .         (canva
1e60: 73 2d 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65  s-interior-style
1e70: 2d 73 65 74 2f 72 61 77 21 20 63 61 6e 76 61 73  -set/raw! canvas
1e80: 20 27 73 74 69 70 70 6c 65 29 5d 0a 20 20 20 20   'stipple)].    
1e90: 20 20 20 20 5b 28 6c 69 73 74 20 27 70 61 74 74      [(list 'patt
1ea0: 65 72 6e 2f 72 67 62 20 77 69 64 74 68 20 68 65  ern/rgb width he
1eb0: 69 67 68 74 20 64 61 74 61 29 0a 20 20 20 20 20  ight data).     
1ec0: 20 20 20 20 28 6c 65 74 20 28 5b 64 61 74 61 2a      (let ([data*
1ed0: 20 28 6d 61 6b 65 2d 63 76 65 63 74 6f 72 20 5f   (make-cvector _
1ee0: 75 6c 6f 6e 67 20 28 2a 20 77 69 64 74 68 20 68  ulong (* width h
1ef0: 65 69 67 68 74 29 29 5d 29 0a 20 20 20 20 20 20  eight))]).      
1f00: 20 20 20 20 20 28 66 6f 72 2a 20 28 5b 6a 20 28       (for* ([j (
1f10: 69 6e 2d 72 61 6e 67 65 20 68 65 69 67 68 74 29  in-range height)
1f20: 5d 20 5b 69 20 28 69 6e 2d 72 61 6e 67 65 20 77  ] [i (in-range w
1f30: 69 64 74 68 29 5d 0a 20 20 20 20 20 20 20 20 20  idth)].         
1f40: 20 20 20 20 20 20 20 20 20 5b 6f 66 73 2a 20 28           [ofs* (
1f50: 69 6e 2d 76 61 6c 75 65 20 28 2b 20 28 2a 20 6a  in-value (+ (* j
1f60: 20 77 69 64 74 68 29 20 69 29 29 5d 0a 20 20 20   width) i))].   
1f70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5b                 [
1f80: 6f 66 73 20 28 69 6e 2d 76 61 6c 75 65 20 28 2a  ofs (in-value (*
1f90: 20 33 20 6f 66 73 2a 29 29 5d 29 0a 20 20 20 20   3 ofs*))]).    
1fa0: 20 20 20 20 20 20 20 20 20 28 63 76 65 63 74 6f           (cvecto
1fb0: 72 2d 73 65 74 21 20 64 61 74 61 2a 20 6f 66 73  r-set! data* ofs
1fc0: 2a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  *.              
1fd0: 20 28 62 69 74 77 69 73 65 2d 69 6f 72 0a 20 20   (bitwise-ior.  
1fe0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28 61                (a
1ff0: 72 69 74 68 6d 65 74 69 63 2d 73 68 69 66 74 20  rithmetic-shift 
2000: 28 62 79 74 65 73 2d 72 65 66 20 64 61 74 61 20  (bytes-ref data 
2010: 6f 66 73 29 20 31 36 29 0a 20 20 20 20 20 20 20  ofs) 16).       
2020: 20 20 20 20 20 20 20 20 20 28 61 72 69 74 68 6d           (arithm
2030: 65 74 69 63 2d 73 68 69 66 74 20 28 62 79 74 65  etic-shift (byte
2040: 73 2d 72 65 66 20 64 61 74 61 20 28 2b 20 6f 66  s-ref data (+ of
2050: 73 20 31 29 29 20 38 29 0a 20 20 20 20 20 20 20  s 1)) 8).       
2060: 20 20 20 20 20 20 20 20 20 28 62 79 74 65 73 2d           (bytes-
2070: 72 65 66 20 64 61 74 61 20 28 2b 20 6f 66 73 20  ref data (+ ofs 
2080: 32 29 29 29 29 29 0a 20 20 20 20 20 20 20 20 20  2))))).         
2090: 20 20 28 63 61 6e 76 61 73 2d 70 61 74 74 65 72    (canvas-patter
20a0: 6e 2d 73 65 74 2f 72 61 77 21 20 63 61 6e 76 61  n-set/raw! canva
20b0: 73 20 77 69 64 74 68 20 68 65 69 67 68 74 20 64  s width height d
20c0: 61 74 61 2a 29 29 0a 20 20 20 20 20 20 20 20 20  ata*)).         
20d0: 28 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f 72  (canvas-interior
20e0: 2d 73 74 79 6c 65 2d 73 65 74 2f 72 61 77 21 20  -style-set/raw! 
20f0: 63 61 6e 76 61 73 20 27 70 61 74 74 65 72 6e 29  canvas 'pattern)
2100: 5d 0a 20 20 20 20 20 20 20 20 5b 28 6c 69 73 74  ].        [(list
2110: 20 27 70 61 74 74 65 72 6e 2f 72 67 62 61 20 77   'pattern/rgba w
2120: 69 64 74 68 20 68 65 69 67 68 74 20 64 61 74 61  idth height data
2130: 29 0a 20 20 20 20 20 20 20 20 20 28 6c 65 74 2a  ).         (let*
2140: 20 28 5b 64 61 74 61 2a 20 28 6d 61 6b 65 2d 63   ([data* (make-c
2150: 76 65 63 74 6f 72 20 5f 75 6c 6f 6e 67 20 28 2a  vector _ulong (*
2160: 20 77 69 64 74 68 20 68 65 69 67 68 74 29 29 5d   width height))]
2170: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2180: 20 5b 65 6c 74 2d 73 65 74 21 20 28 63 75 74 20   [elt-set! (cut 
2190: 70 74 72 2d 73 65 74 21 20 64 61 74 61 2a 20 5f  ptr-set! data* _
21a0: 6c 6f 6e 67 20 3c 3e 20 3c 3e 29 5d 29 0a 20 20  long <> <>)]).  
21b0: 20 20 20 20 20 20 20 20 20 28 66 6f 72 2a 20 28           (for* (
21c0: 5b 6a 20 28 69 6e 2d 72 61 6e 67 65 20 68 65 69  [j (in-range hei
21d0: 67 68 74 29 5d 20 5b 69 20 28 69 6e 2d 72 61 6e  ght)] [i (in-ran
21e0: 67 65 20 77 69 64 74 68 29 5d 0a 20 20 20 20 20  ge width)].     
21f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 5b 6f 66               [of
2200: 73 2a 20 28 69 6e 2d 76 61 6c 75 65 20 28 2b 20  s* (in-value (+ 
2210: 28 2a 20 6a 20 77 69 64 74 68 29 20 69 29 29 5d  (* j width) i))]
2220: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2230: 20 20 20 5b 6f 66 73 20 28 69 6e 2d 76 61 6c 75     [ofs (in-valu
2240: 65 20 28 2a 20 34 20 6f 66 73 2a 29 29 5d 29 0a  e (* 4 ofs*))]).
2250: 20 20 20 20 20 20 20 20 20 20 20 20 20 28 63 76               (cv
2260: 65 63 74 6f 72 2d 73 65 74 21 20 64 61 74 61 2a  ector-set! data*
2270: 20 6f 66 73 2a 0a 20 20 20 20 20 20 20 20 20 20   ofs*.          
2280: 20 20 20 20 20 28 62 69 74 77 69 73 65 2d 69 6f       (bitwise-io
2290: 72 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  r.              
22a0: 20 20 28 61 72 69 74 68 6d 65 74 69 63 2d 73 68    (arithmetic-sh
22b0: 69 66 74 20 28 2d 20 23 78 66 66 20 28 62 79 74  ift (- #xff (byt
22c0: 65 73 2d 72 65 66 20 64 61 74 61 20 28 2b 20 6f  es-ref data (+ o
22d0: 66 73 20 33 29 29 29 20 32 34 29 0a 20 20 20 20  fs 3))) 24).    
22e0: 20 20 20 20 20 20 20 20 20 20 20 20 28 61 72 69              (ari
22f0: 74 68 6d 65 74 69 63 2d 73 68 69 66 74 20 28 62  thmetic-shift (b
2300: 79 74 65 73 2d 72 65 66 20 64 61 74 61 20 6f 66  ytes-ref data of
2310: 73 29 20 31 36 29 0a 20 20 20 20 20 20 20 20 20  s) 16).         
2320: 20 20 20 20 20 20 20 28 61 72 69 74 68 6d 65 74         (arithmet
2330: 69 63 2d 73 68 69 66 74 20 28 62 79 74 65 73 2d  ic-shift (bytes-
2340: 72 65 66 20 64 61 74 61 20 28 2b 20 6f 66 73 20  ref data (+ ofs 
2350: 31 29 29 20 38 29 0a 20 20 20 20 20 20 20 20 20  1)) 8).         
2360: 20 20 20 20 20 20 20 28 62 79 74 65 73 2d 72 65         (bytes-re
2370: 66 20 64 61 74 61 20 28 2b 20 6f 66 73 20 32 29  f data (+ ofs 2)
2380: 29 29 29 29 0a 20 20 20 20 20 20 20 20 20 20 20  )))).           
2390: 28 63 61 6e 76 61 73 2d 70 61 74 74 65 72 6e 2d  (canvas-pattern-
23a0: 73 65 74 2f 72 61 77 21 20 63 61 6e 76 61 73 20  set/raw! canvas 
23b0: 77 69 64 74 68 20 68 65 69 67 68 74 20 64 61 74  width height dat
23c0: 61 2a 29 29 0a 20 20 20 20 20 20 20 20 20 28 63  a*)).         (c
23d0: 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f 72 2d 73  anvas-interior-s
23e0: 74 79 6c 65 2d 73 65 74 2f 72 61 77 21 20 63 61  tyle-set/raw! ca
23f0: 6e 76 61 73 20 27 70 61 74 74 65 72 6e 29 5d 0a  nvas 'pattern)].
2400: 20 20 20 20 20 20 20 20 5b 5f 0a 20 20 20 20 20          [_.     
2410: 20 20 20 20 28 63 61 6e 76 61 73 2d 69 6e 74 65      (canvas-inte
2420: 72 69 6f 72 2d 73 74 79 6c 65 2d 73 65 74 2f 72  rior-style-set/r
2430: 61 77 21 20 63 61 6e 76 61 73 20 69 6e 74 65 72  aw! canvas inter
2440: 69 6f 72 2d 73 74 79 6c 65 29 5d 29 29 29 29 0a  ior-style)])))).
2450: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d  .(define canvas-
2460: 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 0a 20  interior-style. 
2470: 20 28 67 65 74 74 65 72 2d 77 69 74 68 2d 73 65   (getter-with-se
2480: 74 74 65 72 0a 20 20 20 28 6c 65 74 72 65 63 20  tter.   (letrec 
2490: 28 5b 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f  ([canvas-interio
24a0: 72 2d 73 74 79 6c 65 2f 72 61 77 0a 20 20 20 20  r-style/raw.    
24b0: 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66 66           (get-ff
24c0: 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20 20  i-obj.          
24d0: 20 20 20 20 22 63 64 43 61 6e 76 61 73 49 6e 74      "cdCanvasInt
24e0: 65 72 69 6f 72 53 74 79 6c 65 22 20 6c 69 62 63  eriorStyle" libc
24f0: 64 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  d.              
2500: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20  (_fun [canvas : 
2510: 5f 63 61 6e 76 61 73 5d 20 5b 71 75 65 72 79 20  _canvas] [query 
2520: 3a 20 5f 66 69 78 69 6e 74 20 3d 20 2d 31 5d 20  : _fixint = -1] 
2530: 2d 3e 20 5b 69 6e 74 65 72 69 6f 72 2d 73 74 79  -> [interior-sty
2540: 6c 65 20 3a 20 5f 69 6e 74 65 72 69 6f 72 2d 73  le : _interior-s
2550: 74 79 6c 65 5d 29 29 5d 0a 20 20 20 20 20 20 20  tyle]))].       
2560: 20 20 20 20 20 5b 63 61 6e 76 61 73 2d 68 61 74       [canvas-hat
2570: 63 68 2d 73 74 79 6c 65 2f 72 61 77 0a 20 20 20  ch-style/raw.   
2580: 20 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66            (get-f
2590: 66 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20  fi-obj.         
25a0: 20 20 20 20 20 22 63 64 43 61 6e 76 61 73 48 61       "cdCanvasHa
25b0: 74 63 68 22 20 6c 69 62 63 64 0a 20 20 20 20 20  tch" libcd.     
25c0: 20 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 5b           (_fun [
25d0: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73  canvas : _canvas
25e0: 5d 20 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 69  ] [query : _fixi
25f0: 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 5b 68 61 74  nt = -1] -> [hat
2600: 63 68 2d 73 74 79 6c 65 20 3a 20 5f 68 61 74 63  ch-style : _hatc
2610: 68 2d 73 74 79 6c 65 5d 29 29 5d 0a 20 20 20 20  h-style]))].    
2620: 20 20 20 20 20 20 20 20 5b 63 61 6e 76 61 73 2d          [canvas-
2630: 73 74 69 70 70 6c 65 2f 72 61 77 0a 20 20 20 20  stipple/raw.    
2640: 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66 66           (get-ff
2650: 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20 20  i-obj.          
2660: 20 20 20 20 22 63 64 43 61 6e 76 61 73 47 65 74      "cdCanvasGet
2670: 53 74 69 70 70 6c 65 22 20 6c 69 62 63 64 0a 20  Stipple" libcd. 
2680: 20 20 20 20 20 20 20 20 20 20 20 20 20 28 5f 66               (_f
2690: 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61  un [canvas : _ca
26a0: 6e 76 61 73 5d 20 5b 77 69 64 74 68 20 3a 20 28  nvas] [width : (
26b0: 5f 70 74 72 20 6f 20 5f 69 6e 74 29 5d 20 5b 68  _ptr o _int)] [h
26c0: 65 69 67 68 74 20 3a 20 28 5f 70 74 72 20 6f 20  eight : (_ptr o 
26d0: 5f 69 6e 74 29 5d 0a 20 20 20 20 20 20 20 20 20  _int)].         
26e0: 20 20 20 20 20 20 20 20 20 20 20 2d 3e 20 5b 64             -> [d
26f0: 61 74 61 20 3a 20 5f 67 63 70 6f 69 6e 74 65 72  ata : _gcpointer
2700: 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ].              
2710: 20 20 20 20 20 20 2d 3e 20 28 76 61 6c 75 65 73        -> (values
2720: 20 77 69 64 74 68 20 68 65 69 67 68 74 20 64 61   width height da
2730: 74 61 29 29 29 5d 0a 20 20 20 20 20 20 20 20 20  ta)))].         
2740: 20 20 20 5b 63 61 6e 76 61 73 2d 70 61 74 74 65     [canvas-patte
2750: 72 6e 2f 72 61 77 0a 20 20 20 20 20 20 20 20 20  rn/raw.         
2760: 20 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a      (get-ffi-obj
2770: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22  .              "
2780: 63 64 43 61 6e 76 61 73 47 65 74 50 61 74 74 65  cdCanvasGetPatte
2790: 72 6e 22 20 6c 69 62 63 64 0a 20 20 20 20 20 20  rn" libcd.      
27a0: 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 5b 63          (_fun [c
27b0: 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d  anvas : _canvas]
27c0: 20 5b 77 69 64 74 68 20 3a 20 28 5f 70 74 72 20   [width : (_ptr 
27d0: 6f 20 5f 69 6e 74 29 5d 20 5b 68 65 69 67 68 74  o _int)] [height
27e0: 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74 29   : (_ptr o _int)
27f0: 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ].              
2800: 20 20 20 20 20 20 2d 3e 20 5b 64 61 74 61 20 3a        -> [data :
2810: 20 5f 67 63 70 6f 69 6e 74 65 72 5d 0a 20 20 20   _gcpointer].   
2820: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2830: 20 2d 3e 20 28 76 61 6c 75 65 73 20 77 69 64 74   -> (values widt
2840: 68 20 68 65 69 67 68 74 20 64 61 74 61 29 29 29  h height data)))
2850: 5d 29 0a 20 20 20 20 20 28 ce bb 20 28 63 61 6e  ]).     (λ (can
2860: 76 61 73 29 0a 20 20 20 20 20 20 20 28 6c 65 74  vas).       (let
2870: 20 28 5b 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c   ([interior-styl
2880: 65 20 28 63 61 6e 76 61 73 2d 69 6e 74 65 72 69  e (canvas-interi
2890: 6f 72 2d 73 74 79 6c 65 2f 72 61 77 20 63 61 6e  or-style/raw can
28a0: 76 61 73 29 5d 29 0a 20 20 20 20 20 20 20 20 20  vas)]).         
28b0: 28 63 61 73 65 20 69 6e 74 65 72 69 6f 72 2d 73  (case interior-s
28c0: 74 79 6c 65 0a 20 20 20 20 20 20 20 20 20 20 20  tyle.           
28d0: 5b 28 68 61 74 63 68 29 0a 20 20 20 20 20 20 20  [(hatch).       
28e0: 20 20 20 20 20 28 6c 69 73 74 20 27 68 61 74 63       (list 'hatc
28f0: 68 20 28 63 61 6e 76 61 73 2d 68 61 74 63 68 2d  h (canvas-hatch-
2900: 73 74 79 6c 65 2f 72 61 77 20 63 61 6e 76 61 73  style/raw canvas
2910: 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 5b  ))].           [
2920: 28 73 74 69 70 70 6c 65 29 0a 20 20 20 20 20 20  (stipple).      
2930: 20 20 20 20 20 20 28 6c 65 74 2a 2d 76 61 6c 75        (let*-valu
2940: 65 73 20 28 5b 28 77 69 64 74 68 20 68 65 69 67  es ([(width heig
2950: 68 74 20 64 61 74 61 2a 29 20 28 63 61 6e 76 61  ht data*) (canva
2960: 73 2d 73 74 69 70 70 6c 65 2f 72 61 77 20 63 61  s-stipple/raw ca
2970: 6e 76 61 73 29 5d 0a 20 20 20 20 20 20 20 20 20  nvas)].         
2980: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2990: 20 5b 28 64 61 74 61 2a 29 20 28 6d 61 6b 65 2d   [(data*) (make-
29a0: 63 76 65 63 74 6f 72 2a 20 64 61 74 61 2a 20 5f  cvector* data* _
29b0: 75 62 79 74 65 20 28 2a 20 77 69 64 74 68 20 68  ubyte (* width h
29c0: 65 69 67 68 74 29 29 5d 0a 20 20 20 20 20 20 20  eight))].       
29d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
29e0: 20 20 20 5b 28 64 61 74 61 29 20 28 6d 61 6b 65     [(data) (make
29f0: 2d 62 79 74 65 73 20 28 63 65 69 6c 69 6e 67 20  -bytes (ceiling 
2a00: 28 2f 20 28 2a 20 77 69 64 74 68 20 68 65 69 67  (/ (* width heig
2a10: 68 74 29 20 38 29 29 20 30 29 5d 29 0a 20 20 20  ht) 8)) 0)]).   
2a20: 20 20 20 20 20 20 20 20 20 20 20 28 66 6f 72 2a             (for*
2a30: 20 28 5b 6a 20 28 69 6e 2d 72 61 6e 67 65 20 68   ([j (in-range h
2a40: 65 69 67 68 74 29 5d 20 5b 69 20 28 69 6e 2d 72  eight)] [i (in-r
2a50: 61 6e 67 65 20 77 69 64 74 68 29 5d 0a 20 20 20  ange width)].   
2a60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2a70: 20 20 5b 6f 66 73 2a 20 28 69 6e 2d 76 61 6c 75    [ofs* (in-valu
2a80: 65 20 28 2b 20 28 2a 20 6a 20 77 69 64 74 68 29  e (+ (* j width)
2a90: 20 69 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20   i))].          
2aa0: 20 20 20 20 20 20 20 20 20 20 20 5b 76 6f 66 73             [vofs
2ab0: 20 28 69 6e 2d 76 61 6c 75 65 20 28 71 75 6f 74   (in-value (quot
2ac0: 69 65 6e 74 20 6f 66 73 2a 20 38 29 29 5d 0a 20  ient ofs* 8))]. 
2ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ae0: 20 20 20 20 5b 62 6f 66 73 20 28 69 6e 2d 76 61      [bofs (in-va
2af0: 6c 75 65 20 28 72 65 6d 61 69 6e 64 65 72 20 6f  lue (remainder o
2b00: 66 73 2a 20 38 29 29 5d 29 0a 20 20 20 20 20 20  fs* 8))]).      
2b10: 20 20 20 20 20 20 20 20 20 20 28 62 79 74 65 73            (bytes
2b20: 2d 73 65 74 21 20 64 61 74 61 20 76 6f 66 73 0a  -set! data vofs.
2b30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b40: 20 20 28 62 69 74 77 69 73 65 2d 69 6f 72 0a 20    (bitwise-ior. 
2b50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b60: 20 20 28 62 79 74 65 73 2d 72 65 66 20 64 61 74    (bytes-ref dat
2b70: 61 20 76 6f 66 73 29 0a 20 20 20 20 20 20 20 20  a vofs).        
2b80: 20 20 20 20 20 20 20 20 20 20 20 28 61 72 69 74             (arit
2b90: 68 6d 65 74 69 63 2d 73 68 69 66 74 20 28 62 69  hmetic-shift (bi
2ba0: 74 77 69 73 65 2d 61 6e 64 20 28 63 76 65 63 74  twise-and (cvect
2bb0: 6f 72 2d 72 65 66 20 64 61 74 61 2a 20 6f 66 73  or-ref data* ofs
2bc0: 2a 29 20 31 29 20 62 6f 66 73 29 29 29 29 0a 20  *) 1) bofs)))). 
2bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 28 6c 69               (li
2be0: 73 74 20 27 73 74 69 70 70 6c 65 20 77 69 64 74  st 'stipple widt
2bf0: 68 20 68 65 69 67 68 74 20 64 61 74 61 29 29 5d  h height data))]
2c00: 0a 20 20 20 20 20 20 20 20 20 20 20 5b 28 70 61  .           [(pa
2c10: 74 74 65 72 6e 29 0a 20 20 20 20 20 20 20 20 20  ttern).         
2c20: 20 20 20 28 6c 65 74 2a 2d 76 61 6c 75 65 73 20     (let*-values 
2c30: 28 5b 28 77 69 64 74 68 20 68 65 69 67 68 74 20  ([(width height 
2c40: 64 61 74 61 2a 29 20 28 63 61 6e 76 61 73 2d 70  data*) (canvas-p
2c50: 61 74 74 65 72 6e 2f 72 61 77 20 63 61 6e 76 61  attern/raw canva
2c60: 73 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20  s)].            
2c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5b 28                [(
2c80: 64 61 74 61 2a 29 20 28 6d 61 6b 65 2d 63 76 65  data*) (make-cve
2c90: 63 74 6f 72 2a 20 64 61 74 61 2a 20 5f 75 6c 6f  ctor* data* _ulo
2ca0: 6e 67 20 28 2a 20 77 69 64 74 68 20 68 65 69 67  ng (* width heig
2cb0: 68 74 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20  ht))].          
2cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2cd0: 5b 28 64 61 74 61 29 20 28 6d 61 6b 65 2d 62 79  [(data) (make-by
2ce0: 74 65 73 20 28 2a 20 34 20 77 69 64 74 68 20 68  tes (* 4 width h
2cf0: 65 69 67 68 74 29 29 5d 29 0a 20 20 20 20 20 20  eight))]).      
2d00: 20 20 20 20 20 20 20 20 28 66 6f 72 2a 20 28 5b          (for* ([
2d10: 6a 20 28 69 6e 2d 72 61 6e 67 65 20 68 65 69 67  j (in-range heig
2d20: 68 74 29 5d 20 5b 69 20 28 69 6e 2d 72 61 6e 67  ht)] [i (in-rang
2d30: 65 20 77 69 64 74 68 29 5d 0a 20 20 20 20 20 20  e width)].      
2d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5b                 [
2d50: 6f 66 73 2a 20 28 69 6e 2d 76 61 6c 75 65 20 28  ofs* (in-value (
2d60: 2b 20 28 2a 20 6a 20 77 69 64 74 68 29 20 69 29  + (* j width) i)
2d70: 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  )].             
2d80: 20 20 20 20 20 20 20 20 5b 6f 66 73 20 28 69 6e          [ofs (in
2d90: 2d 76 61 6c 75 65 20 28 2a 20 34 20 6f 66 73 2a  -value (* 4 ofs*
2da0: 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ))].            
2db0: 20 20 20 20 20 20 20 20 20 5b 63 6f 6c 20 28 69           [col (i
2dc0: 6e 2d 76 61 6c 75 65 20 28 63 76 65 63 74 6f 72  n-value (cvector
2dd0: 2d 72 65 66 20 64 61 74 61 2a 20 6f 66 73 2a 29  -ref data* ofs*)
2de0: 29 5d 29 0a 20 20 20 20 20 20 20 20 20 20 20 20  )]).            
2df0: 20 20 20 20 28 62 79 74 65 73 2d 73 65 74 21 20      (bytes-set! 
2e00: 64 61 74 61 20 6f 66 73 20 28 62 69 74 77 69 73  data ofs (bitwis
2e10: 65 2d 62 69 74 2d 66 69 65 6c 64 20 63 6f 6c 20  e-bit-field col 
2e20: 31 36 20 32 34 29 29 0a 20 20 20 20 20 20 20 20  16 24)).        
2e30: 20 20 20 20 20 20 20 20 28 62 79 74 65 73 2d 73          (bytes-s
2e40: 65 74 21 20 64 61 74 61 20 28 2b 20 6f 66 73 20  et! data (+ ofs 
2e50: 31 29 20 28 62 69 74 77 69 73 65 2d 62 69 74 2d  1) (bitwise-bit-
2e60: 66 69 65 6c 64 20 63 6f 6c 20 38 20 31 36 29 29  field col 8 16))
2e70: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2e80: 20 28 62 79 74 65 73 2d 73 65 74 21 20 64 61 74   (bytes-set! dat
2e90: 61 20 28 2b 20 6f 66 73 20 32 29 20 28 62 69 74  a (+ ofs 2) (bit
2ea0: 77 69 73 65 2d 62 69 74 2d 66 69 65 6c 64 20 63  wise-bit-field c
2eb0: 6f 6c 20 30 20 38 29 29 0a 20 20 20 20 20 20 20  ol 0 8)).       
2ec0: 20 20 20 20 20 20 20 20 20 28 62 79 74 65 73 2d           (bytes-
2ed0: 73 65 74 21 20 64 61 74 61 20 28 2b 20 6f 66 73  set! data (+ ofs
2ee0: 20 33 29 20 28 2d 20 23 78 66 66 20 28 62 69 74   3) (- #xff (bit
2ef0: 77 69 73 65 2d 62 69 74 2d 66 69 65 6c 64 20 63  wise-bit-field c
2f00: 6f 6c 20 32 34 20 33 32 29 29 29 29 0a 20 20 20  ol 24 32)))).   
2f10: 20 20 20 20 20 20 20 20 20 20 20 28 6c 69 73 74             (list
2f20: 20 27 70 61 74 74 65 72 6e 2f 72 67 62 61 20 77   'pattern/rgba w
2f30: 69 64 74 68 20 68 65 69 67 68 74 20 64 61 74 61  idth height data
2f40: 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 5b  ))].           [
2f50: 65 6c 73 65 0a 20 20 20 20 20 20 20 20 20 20 20  else.           
2f60: 20 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 5d   interior-style]
2f70: 29 29 29 29 0a 20 20 20 63 61 6e 76 61 73 2d 69  )))).   canvas-i
2f80: 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 2d 73 65  nterior-style-se
2f90: 74 21 29 29 0a 0a 28 70 72 6f 76 69 64 65 0a 20  t!))..(provide. 
2fa0: 63 61 6e 76 61 73 2d 62 6f 78 21 20 63 61 6e 76  canvas-box! canv
2fb0: 61 73 2d 73 65 63 74 6f 72 21 20 63 61 6e 76 61  as-sector! canva
2fc0: 73 2d 63 68 6f 72 64 21 0a 20 63 61 6e 76 61 73  s-chord!. canvas
2fd0: 2d 62 61 63 6b 67 72 6f 75 6e 64 2d 6f 70 61 63  -background-opac
2fe0: 69 74 79 20 63 61 6e 76 61 73 2d 62 61 63 6b 67  ity canvas-backg
2ff0: 72 6f 75 6e 64 2d 6f 70 61 63 69 74 79 2d 73 65  round-opacity-se
3000: 74 21 0a 20 63 61 6e 76 61 73 2d 66 69 6c 6c 2d  t!. canvas-fill-
3010: 6d 6f 64 65 20 63 61 6e 76 61 73 2d 66 69 6c 6c  mode canvas-fill
3020: 2d 6d 6f 64 65 2d 73 65 74 21 0a 20 63 61 6e 76  -mode-set!. canv
3030: 61 73 2d 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c  as-interior-styl
3040: 65 20 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f  e canvas-interio
3050: 72 2d 73 74 79 6c 65 2d 73 65 74 21 29 0a 0a 3b  r-style-set!)..;
3060: 3b 20 7d 7d 7d 0a 0a 3b 3b 20 7b 7b 7b 20 54 65  ; }}}..;; {{{ Te
3070: 78 74 20 66 75 6e 63 74 69 6f 6e 73 0a 0a 28 64  xt functions..(d
3080: 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 74 65 78  efine canvas-tex
3090: 74 21 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62  t!.  (get-ffi-ob
30a0: 6a 0a 20 20 20 22 63 64 66 43 61 6e 76 61 73 54  j.   "cdfCanvasT
30b0: 65 78 74 22 20 6c 69 62 63 64 0a 20 20 20 28 5f  ext" libcd.   (_
30c0: 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63  fun [canvas : _c
30d0: 61 6e 76 61 73 5d 20 5b 78 20 3a 20 5f 64 6f 75  anvas] [x : _dou
30e0: 62 6c 65 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62  ble*] [y : _doub
30f0: 6c 65 2a 5d 20 5b 74 65 78 74 20 3a 20 5f 73 74  le*] [text : _st
3100: 72 69 6e 67 2f 75 74 66 2d 38 5d 20 2d 3e 20 5f  ring/utf-8] -> _
3110: 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65  void)))..(define
3120: 20 63 61 6e 76 61 73 2d 66 6f 6e 74 2d 73 65 74   canvas-font-set
3130: 21 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a  !.  (get-ffi-obj
3140: 0a 20 20 20 22 63 64 43 61 6e 76 61 73 4e 61 74  .   "cdCanvasNat
3150: 69 76 65 46 6f 6e 74 22 20 6c 69 62 63 64 0a 20  iveFont" libcd. 
3160: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20    (_fun [canvas 
3170: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 66 6f 6e 74  : _canvas] [font
3180: 20 3a 20 5f 73 74 72 69 6e 67 2f 75 74 66 2d 38   : _string/utf-8
3190: 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28  ] -> _void)))..(
31a0: 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 66 6f  define canvas-fo
31b0: 6e 74 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74  nt.  (getter-wit
31c0: 68 2d 73 65 74 74 65 72 0a 20 20 20 28 67 65 74  h-setter.   (get
31d0: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64  -ffi-obj.    "cd
31e0: 43 61 6e 76 61 73 4e 61 74 69 76 65 46 6f 6e 74  CanvasNativeFont
31f0: 22 20 6c 69 62 63 64 0a 20 20 20 20 28 5f 66 75  " libcd.    (_fu
3200: 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e  n [canvas : _can
3210: 76 61 73 5d 20 5b 71 75 65 72 79 20 3a 20 5f 70  vas] [query : _p
3220: 6f 69 6e 74 65 72 20 3d 20 23 66 5d 20 2d 3e 20  ointer = #f] -> 
3230: 5b 66 6f 6e 74 20 3a 20 5f 73 74 72 69 6e 67 2f  [font : _string/
3240: 75 74 66 2d 38 5d 29 29 0a 20 20 20 63 61 6e 76  utf-8])).   canv
3250: 61 73 2d 66 6f 6e 74 2d 73 65 74 21 29 29 0a 0a  as-font-set!))..
3260: 28 64 65 66 69 6e 65 20 5f 61 6c 69 67 6e 6d 65  (define _alignme
3270: 6e 74 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27  nt.  (_enum.   '
3280: 28 6e 6f 72 74 68 20 73 6f 75 74 68 20 65 61 73  (north south eas
3290: 74 20 77 65 73 74 20 6e 6f 72 74 68 2d 65 61 73  t west north-eas
32a0: 74 20 6e 6f 72 74 68 2d 77 65 73 74 20 73 6f 75  t north-west sou
32b0: 74 68 2d 65 61 73 74 20 73 6f 75 74 68 2d 77 65  th-east south-we
32c0: 73 74 20 63 65 6e 74 65 72 20 62 61 73 65 2d 6c  st center base-l
32d0: 65 66 74 20 62 61 73 65 2d 63 65 6e 74 65 72 20  eft base-center 
32e0: 62 61 73 65 2d 72 69 67 68 74 29 0a 20 20 20 5f  base-right).   _
32f0: 66 69 78 69 6e 74 29 29 0a 0a 28 64 65 66 69 6e  fixint))..(defin
3300: 65 20 63 61 6e 76 61 73 2d 74 65 78 74 2d 61 6c  e canvas-text-al
3310: 69 67 6e 6d 65 6e 74 2d 73 65 74 21 0a 20 20 28  ignment-set!.  (
3320: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22  get-ffi-obj.   "
3330: 63 64 43 61 6e 76 61 73 54 65 78 74 41 6c 69 67  cdCanvasTextAlig
3340: 6e 6d 65 6e 74 22 20 6c 69 62 63 64 0a 20 20 20  nment" libcd.   
3350: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20  (_fun [canvas : 
3360: 5f 63 61 6e 76 61 73 5d 20 5b 61 6c 69 67 6e 6d  _canvas] [alignm
3370: 65 6e 74 20 3a 20 5f 61 6c 69 67 6e 6d 65 6e 74  ent : _alignment
3380: 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28  ] -> _void)))..(
3390: 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 74 65  define canvas-te
33a0: 78 74 2d 61 6c 69 67 6e 6d 65 6e 74 0a 20 20 28  xt-alignment.  (
33b0: 67 65 74 74 65 72 2d 77 69 74 68 2d 73 65 74 74  getter-with-sett
33c0: 65 72 0a 20 20 20 28 67 65 74 2d 66 66 69 2d 6f  er.   (get-ffi-o
33d0: 62 6a 0a 20 20 20 20 22 63 64 43 61 6e 76 61 73  bj.    "cdCanvas
33e0: 54 65 78 74 41 6c 69 67 6e 6d 65 6e 74 22 20 6c  TextAlignment" l
33f0: 69 62 63 64 0a 20 20 20 20 28 5f 66 75 6e 20 5b  ibcd.    (_fun [
3400: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73  canvas : _canvas
3410: 5d 20 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 69  ] [query : _fixi
3420: 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 5b 61 6c 69  nt = -1] -> [ali
3430: 67 6e 6d 65 6e 74 20 3a 20 5f 61 6c 69 67 6e 6d  gnment : _alignm
3440: 65 6e 74 5d 29 29 0a 20 20 20 63 61 6e 76 61 73  ent])).   canvas
3450: 2d 74 65 78 74 2d 61 6c 69 67 6e 6d 65 6e 74 2d  -text-alignment-
3460: 73 65 74 21 29 29 0a 0a 28 64 65 66 69 6e 65 20  set!))..(define 
3470: 63 61 6e 76 61 73 2d 74 65 78 74 2d 6f 72 69 65  canvas-text-orie
3480: 6e 74 61 74 69 6f 6e 2d 73 65 74 21 0a 20 20 28  ntation-set!.  (
3490: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22  get-ffi-obj.   "
34a0: 63 64 43 61 6e 76 61 73 54 65 78 74 4f 72 69 65  cdCanvasTextOrie
34b0: 6e 74 61 74 69 6f 6e 22 20 6c 69 62 63 64 0a 20  ntation" libcd. 
34c0: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20    (_fun [canvas 
34d0: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 6f 72 69 65  : _canvas] [orie
34e0: 6e 74 61 74 69 6f 6e 20 3a 20 5f 64 6f 75 62 6c  ntation : _doubl
34f0: 65 2a 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a  e*] -> _void))).
3500: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d  .(define canvas-
3510: 74 65 78 74 2d 6f 72 69 65 6e 74 61 74 69 6f 6e  text-orientation
3520: 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74 68 2d  .  (getter-with-
3530: 73 65 74 74 65 72 0a 20 20 20 28 67 65 74 2d 66  setter.   (get-f
3540: 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64 43 61  fi-obj.    "cdCa
3550: 6e 76 61 73 54 65 78 74 4f 72 69 65 6e 74 61 74  nvasTextOrientat
3560: 69 6f 6e 22 20 6c 69 62 63 64 0a 20 20 20 20 28  ion" libcd.    (
3570: 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f  _fun [canvas : _
3580: 63 61 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 3a  canvas] [query :
3590: 20 5f 64 6f 75 62 6c 65 20 3d 20 2d 31 2e 30 5d   _double = -1.0]
35a0: 20 2d 3e 20 5b 6f 72 69 65 6e 74 61 74 69 6f 6e   -> [orientation
35b0: 20 3a 20 5f 64 6f 75 62 6c 65 5d 29 29 0a 20 20   : _double])).  
35c0: 20 63 61 6e 76 61 73 2d 74 65 78 74 2d 6f 72 69   canvas-text-ori
35d0: 65 6e 74 61 74 69 6f 6e 2d 73 65 74 21 29 29 0a  entation-set!)).
35e0: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d  .(define canvas-
35f0: 66 6f 6e 74 2d 64 69 6d 65 6e 73 69 6f 6e 73 0a  font-dimensions.
3600: 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20    (get-ffi-obj. 
3610: 20 20 22 63 64 43 61 6e 76 61 73 47 65 74 46 6f    "cdCanvasGetFo
3620: 6e 74 44 69 6d 22 20 6c 69 62 63 64 0a 20 20 20  ntDim" libcd.   
3630: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20  (_fun [canvas : 
3640: 5f 63 61 6e 76 61 73 5d 0a 20 20 20 20 20 20 20  _canvas].       
3650: 20 20 5b 6d 61 78 2d 77 69 64 74 68 20 3a 20 28    [max-width : (
3660: 5f 70 74 72 20 6f 20 5f 69 6e 74 29 5d 20 5b 68  _ptr o _int)] [h
3670: 65 69 67 68 74 20 3a 20 28 5f 70 74 72 20 6f 20  eight : (_ptr o 
3680: 5f 69 6e 74 29 5d 0a 20 20 20 20 20 20 20 20 20  _int)].         
3690: 5b 61 73 63 65 6e 74 20 3a 20 28 5f 70 74 72 20  [ascent : (_ptr 
36a0: 6f 20 5f 69 6e 74 29 5d 20 5b 64 65 73 63 65 6e  o _int)] [descen
36b0: 74 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74  t : (_ptr o _int
36c0: 29 5d 0a 20 20 20 20 20 20 20 20 20 2d 3e 20 5f  )].         -> _
36d0: 76 6f 69 64 0a 20 20 20 20 20 20 20 20 20 2d 3e  void.         ->
36e0: 20 28 76 61 6c 75 65 73 0a 20 20 20 20 20 20 20   (values.       
36f0: 20 20 20 20 20 20 6d 61 78 2d 77 69 64 74 68 20        max-width 
3700: 68 65 69 67 68 74 0a 20 20 20 20 20 20 20 20 20  height.         
3710: 20 20 20 20 61 73 63 65 6e 74 20 64 65 73 63 65      ascent desce
3720: 6e 74 29 29 29 29 0a 0a 28 64 65 66 69 6e 65 20  nt))))..(define 
3730: 63 61 6e 76 61 73 2d 74 65 78 74 2d 73 69 7a 65  canvas-text-size
3740: 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a  .  (get-ffi-obj.
3750: 20 20 20 22 63 64 43 61 6e 76 61 73 47 65 74 54     "cdCanvasGetT
3760: 65 78 74 53 69 7a 65 22 20 6c 69 62 63 64 0a 20  extSize" libcd. 
3770: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20    (_fun [canvas 
3780: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 74 65 78 74  : _canvas] [text
3790: 20 3a 20 5f 73 74 72 69 6e 67 2f 75 74 66 2d 38   : _string/utf-8
37a0: 5d 0a 20 20 20 20 20 20 20 20 20 5b 77 69 64 74  ].         [widt
37b0: 68 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74  h : (_ptr o _int
37c0: 29 5d 20 5b 68 65 69 67 68 74 20 3a 20 28 5f 70  )] [height : (_p
37d0: 74 72 20 6f 20 5f 69 6e 74 29 5d 0a 20 20 20 20  tr o _int)].    
37e0: 20 20 20 20 20 2d 3e 20 5f 76 6f 69 64 0a 20 20       -> _void.  
37f0: 20 20 20 20 20 20 20 2d 3e 20 28 76 61 6c 75 65         -> (value
3800: 73 20 77 69 64 74 68 20 68 65 69 67 68 74 29 29  s width height))
3810: 29 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76  ))..(define canv
3820: 61 73 2d 74 65 78 74 2d 62 6f 78 0a 20 20 28 67  as-text-box.  (g
3830: 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63  et-ffi-obj.   "c
3840: 64 43 61 6e 76 61 73 47 65 74 54 65 78 74 42 6f  dCanvasGetTextBo
3850: 78 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75  x" libcd.   (_fu
3860: 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e  n [canvas : _can
3870: 76 61 73 5d 20 5b 78 20 3a 20 5f 69 6e 74 5d 20  vas] [x : _int] 
3880: 5b 79 20 3a 20 5f 69 6e 74 5d 20 5b 74 65 78 74  [y : _int] [text
3890: 20 3a 20 5f 73 74 72 69 6e 67 2f 75 74 66 2d 38   : _string/utf-8
38a0: 5d 0a 20 20 20 20 20 20 20 20 20 5b 78 30 20 3a  ].         [x0 :
38b0: 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74 29 5d 20   (_ptr o _int)] 
38c0: 5b 78 31 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69  [x1 : (_ptr o _i
38d0: 6e 74 29 5d 0a 20 20 20 20 20 20 20 20 20 5b 79  nt)].         [y
38e0: 30 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74  0 : (_ptr o _int
38f0: 29 5d 20 5b 79 31 20 3a 20 28 5f 70 74 72 20 6f  )] [y1 : (_ptr o
3900: 20 5f 69 6e 74 29 5d 0a 20 20 20 20 20 20 20 20   _int)].        
3910: 20 2d 3e 20 5f 76 6f 69 64 0a 20 20 20 20 20 20   -> _void.      
3920: 20 20 20 2d 3e 20 28 76 61 6c 75 65 73 20 78 30     -> (values x0
3930: 20 78 31 20 79 30 20 79 31 29 29 29 29 0a 0a 28   x1 y0 y1))))..(
3940: 70 72 6f 76 69 64 65 0a 20 63 61 6e 76 61 73 2d  provide. canvas-
3950: 74 65 78 74 21 0a 20 63 61 6e 76 61 73 2d 66 6f  text!. canvas-fo
3960: 6e 74 20 63 61 6e 76 61 73 2d 66 6f 6e 74 2d 73  nt canvas-font-s
3970: 65 74 21 0a 20 63 61 6e 76 61 73 2d 74 65 78 74  et!. canvas-text
3980: 2d 61 6c 69 67 6e 6d 65 6e 74 20 63 61 6e 76 61  -alignment canva
3990: 73 2d 74 65 78 74 2d 61 6c 69 67 6e 6d 65 6e 74  s-text-alignment
39a0: 2d 73 65 74 21 0a 20 63 61 6e 76 61 73 2d 74 65  -set!. canvas-te
39b0: 78 74 2d 6f 72 69 65 6e 74 61 74 69 6f 6e 20 63  xt-orientation c
39c0: 61 6e 76 61 73 2d 74 65 78 74 2d 6f 72 69 65 6e  anvas-text-orien
39d0: 74 61 74 69 6f 6e 2d 73 65 74 21 0a 20 63 61 6e  tation-set!. can
39e0: 76 61 73 2d 66 6f 6e 74 2d 64 69 6d 65 6e 73 69  vas-font-dimensi
39f0: 6f 6e 73 20 63 61 6e 76 61 73 2d 74 65 78 74 2d  ons canvas-text-
3a00: 73 69 7a 65 20 63 61 6e 76 61 73 2d 74 65 78 74  size canvas-text
3a10: 2d 62 6f 78 29 0a 0a 3b 3b 20 7d 7d 7d 0a 0a 3b  -box)..;; }}}..;
3a20: 3b 20 7b 7b 7b 20 56 65 72 74 65 78 20 66 75 6e  ; {{{ Vertex fun
3a30: 63 74 69 6f 6e 73 0a 0a 28 64 65 66 69 6e 65 20  ctions..(define 
3a40: 5f 63 61 6e 76 61 73 2d 6d 6f 64 65 0a 20 20 28  _canvas-mode.  (
3a50: 5f 65 6e 75 6d 0a 20 20 20 27 28 66 69 6c 6c 20  _enum.   '(fill 
3a60: 6f 70 65 6e 2d 6c 69 6e 65 73 20 63 6c 6f 73 65  open-lines close
3a70: 64 2d 6c 69 6e 65 73 20 63 6c 69 70 20 62 65 7a  d-lines clip bez
3a80: 69 65 72 20 72 65 67 69 6f 6e 20 70 61 74 68 29  ier region path)
3a90: 0a 20 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28  .   _fixint))..(
3aa0: 64 65 66 69 6e 65 20 63 61 6c 6c 2d 77 69 74 68  define call-with
3ab0: 2d 63 61 6e 76 61 73 2d 69 6e 2d 6d 6f 64 65 0a  -canvas-in-mode.
3ac0: 20 20 28 6c 65 74 72 65 63 20 28 5b 63 61 6e 76    (letrec ([canv
3ad0: 61 73 2d 62 65 67 69 6e 2f 72 61 77 0a 20 20 20  as-begin/raw.   
3ae0: 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66 66           (get-ff
3af0: 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20 20  i-obj.          
3b00: 20 20 20 22 63 64 43 61 6e 76 61 73 42 65 67 69     "cdCanvasBegi
3b10: 6e 22 20 6c 69 62 63 64 0a 20 20 20 20 20 20 20  n" libcd.       
3b20: 20 20 20 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e        (_fun [can
3b30: 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b  vas : _canvas] [
3b40: 63 61 6e 76 61 73 2d 6d 6f 64 65 20 3a 20 5f 63  canvas-mode : _c
3b50: 61 6e 76 61 73 2d 6d 6f 64 65 5d 20 2d 3e 20 5f  anvas-mode] -> _
3b60: 76 6f 69 64 29 29 5d 0a 20 20 20 20 20 20 20 20  void))].        
3b70: 20 20 20 5b 63 61 6e 76 61 73 2d 65 6e 64 2f 72     [canvas-end/r
3b80: 61 77 0a 20 20 20 20 20 20 20 20 20 20 20 20 28  aw.            (
3b90: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20  get-ffi-obj.    
3ba0: 20 20 20 20 20 20 20 20 20 22 63 64 43 61 6e 76           "cdCanv
3bb0: 61 73 45 6e 64 22 20 6c 69 62 63 64 0a 20 20 20  asEnd" libcd.   
3bc0: 20 20 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20            (_fun 
3bd0: 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61  [canvas : _canva
3be0: 73 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 5d 29 0a  s] -> _void))]).
3bf0: 20 20 20 20 28 ce bb 20 28 63 61 6e 76 61 73 20      (λ (canvas 
3c00: 63 61 6e 76 61 73 2d 6d 6f 64 65 20 70 72 6f 63  canvas-mode proc
3c10: 29 0a 20 20 20 20 20 20 28 64 79 6e 61 6d 69 63  ).      (dynamic
3c20: 2d 77 69 6e 64 0a 20 20 20 20 20 20 20 28 63 75  -wind.       (cu
3c30: 74 20 63 61 6e 76 61 73 2d 62 65 67 69 6e 2f 72  t canvas-begin/r
3c40: 61 77 20 63 61 6e 76 61 73 20 63 61 6e 76 61 73  aw canvas canvas
3c50: 2d 6d 6f 64 65 29 0a 20 20 20 20 20 20 20 28 63  -mode).       (c
3c60: 75 74 20 70 72 6f 63 20 63 61 6e 76 61 73 29 0a  ut proc canvas).
3c70: 20 20 20 20 20 20 20 28 63 75 74 20 63 61 6e 76         (cut canv
3c80: 61 73 2d 65 6e 64 2f 72 61 77 20 63 61 6e 76 61  as-end/raw canva
3c90: 73 29 29 29 29 29 0a 0a 28 64 65 66 69 6e 65 20  s)))))..(define 
3ca0: 5f 70 61 74 68 2d 61 63 74 69 6f 6e 0a 20 20 28  _path-action.  (
3cb0: 5f 65 6e 75 6d 0a 20 20 20 27 28 6e 65 77 20 6d  _enum.   '(new m
3cc0: 6f 76 65 2d 74 6f 20 6c 69 6e 65 2d 74 6f 20 61  ove-to line-to a
3cd0: 72 63 20 63 75 72 76 65 2d 74 6f 20 63 6c 6f 73  rc curve-to clos
3ce0: 65 20 66 69 6c 6c 20 73 74 72 6f 6b 65 20 66 69  e fill stroke fi
3cf0: 6c 6c 2b 73 74 72 6f 6b 65 20 63 6c 69 70 29 0a  ll+stroke clip).
3d00: 20 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 64     _fixint))..(d
3d10: 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 70 61 74  efine canvas-pat
3d20: 68 2d 73 65 74 21 0a 20 20 28 67 65 74 2d 66 66  h-set!.  (get-ff
3d30: 69 2d 6f 62 6a 0a 20 20 20 22 63 64 43 61 6e 76  i-obj.   "cdCanv
3d40: 61 73 50 61 74 68 53 65 74 22 20 6c 69 62 63 64  asPathSet" libcd
3d50: 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61  .   (_fun [canva
3d60: 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 70 61  s : _canvas] [pa
3d70: 74 68 2d 61 63 74 69 6f 6e 20 3a 20 5f 70 61 74  th-action : _pat
3d80: 68 2d 61 63 74 69 6f 6e 5d 20 2d 3e 20 5f 76 6f  h-action] -> _vo
3d90: 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 63  id)))..(define c
3da0: 61 6e 76 61 73 2d 76 65 72 74 65 78 21 0a 20 20  anvas-vertex!.  
3db0: 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20  (get-ffi-obj.   
3dc0: 22 63 64 66 43 61 6e 76 61 73 56 65 72 74 65 78  "cdfCanvasVertex
3dd0: 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 6e  " libcd.   (_fun
3de0: 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76   [canvas : _canv
3df0: 61 73 5d 20 5b 78 20 3a 20 5f 64 6f 75 62 6c 65  as] [x : _double
3e00: 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62 6c 65 2a  *] [y : _double*
3e10: 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28  ] -> _void)))..(
3e20: 70 72 6f 76 69 64 65 0a 20 63 61 6c 6c 2d 77 69  provide. call-wi
3e30: 74 68 2d 63 61 6e 76 61 73 2d 69 6e 2d 6d 6f 64  th-canvas-in-mod
3e40: 65 20 63 61 6e 76 61 73 2d 70 61 74 68 2d 73 65  e canvas-path-se
3e50: 74 21 0a 20 63 61 6e 76 61 73 2d 76 65 72 74 65  t!. canvas-verte
3e60: 78 21 29 0a 0a 3b 3b 20 7d 7d 7d 0a              x!)..;; }}}.