about summary refs log tree commit diff stats
path: root/js/map-maker/imgs/extracted-1688-map/MapPartsWhite/hills_white/52.png
blob: 58f6fbad998a20f1fa53dff3fb41f12172dbc3a7 (plain)
ofshex dumpascii
0000 89 50 4e 47 0d 0a 1a 0a 00 00 00 0d 49 48 44 52 00 00 00 54 00 00 00 29 08 06 00 00 00 ab d7 0e .PNG........IHDR...T...)........
0020 de 00 00 06 41 49 44 41 54 78 da ed 9a 0f 48 55 67 18 c6 d3 19 6a 49 ac c8 86 ca 55 2a 54 2c 8c ....AIDATx....HUg....jI....U*T,.
0040 26 c6 c2 a4 28 0a c5 68 18 ca 50 14 43 51 64 43 49 64 52 c4 a4 71 23 1c 13 b9 62 48 52 24 61 14 &...(..h..P.CQdCIdR..q#...bHR$a.
0060 8a 23 94 44 31 16 93 c6 24 29 1a 39 94 c2 a4 45 d1 a0 c6 1a db 0c 9d 53 f7 be ec 77 e0 a0 e7 5e .#.D1...$).9...E.......S...w...^
0080 f4 5e 73 79 3d 07 1e 3a f7 9c ef 7c e7 7c cf f7 be cf fb c7 56 ad b2 0f fb 58 f1 c7 cc cc cc 1a .^sy=..:...|.|......V....X......
00a0 41 a4 cd c4 e2 90 99 28 38 2d 68 12 94 da 8c f8 4e e8 5d c1 df 82 7f 04 53 02 87 cd 8a 6f 84 8e A......(8-h.....N.].....S....o..
00c0 08 3e 17 1c 15 4c 0b 2a 4d f7 de b7 19 f2 4c de 7a c1 31 c1 27 82 dd 82 8f 04 af 04 fb 94 3c c1 .>...L.*M.....L.z.1.'.........<.
00e0 9f 82 0a 41 30 e3 bf 16 6c b6 99 9b 4b e4 5a 41 12 64 fd 24 78 29 18 10 5c 14 bc 11 64 29 71 82 ...A0...l...K.ZA.d.$x)..\...d)q.
0100 51 c1 c7 82 00 25 55 f0 48 90 29 08 14 6c b4 99 fc 8f cc e3 90 78 43 90 27 58 2d 70 0a 2e 09 ce Q....%U.H.)..l.......xC.'X-p....
0120 08 c6 05 1d 82 7a 2c 74 1f 84 aa 35 d7 e9 66 d8 2c ce 75 f3 68 2b 62 48 97 da 04 c3 b8 be 06 a5 .....z,t...5..f.,.u.h+bH........
0140 34 c1 07 82 0c c1 7d 41 0a 63 43 b9 1e 62 7a 3e d8 66 78 2e a9 3b 04 2d 90 da 23 88 e2 7a 9c c0 4.....}A.cC..bz>.fx..;.-..#..z..
0160 25 38 a1 e9 94 e0 a4 a0 41 70 16 e9 38 ce bd 63 c8 c9 2e c1 86 45 fc ae 04 e3 5b 96 23 a9 aa 9f %8......Ap..8..c.....E....[.#...
0180 d9 82 70 8b 7b 2e d2 aa 69 52 2b 03 63 82 49 ce 55 36 fe 42 93 93 55 73 7d fc 1e dd bc df 04 dd ..p.{...iR+.c.I.U6.B..Us}.......
01a0 ea 19 fe 68 c5 47 4d 79 ea 13 41 27 ba fb 0d d6 dd 4c 70 53 92 9f 12 dc f2 bd 7c 57 13 f3 55 b3 ...h.GMy..A'.....LpS......|W..U.
01c0 49 e9 cb 99 b8 32 c1 16 8b eb 01 2c f4 17 32 84 3b 2c 5a d1 88 0c dc 80 e0 76 c1 a0 a0 8f 67 72 I....2.....,..2.;,Z......v....gr
01e0 f4 f9 05 7c c3 00 01 72 17 9b 54 b1 9c eb f9 f3 ee 2c 42 ae 47 90 1d 3c 14 fc 2e b8 2c 68 15 5c ...|...r..T......,B.G..<....,h.\
0200 85 54 cd 08 aa d0 d7 8b 90 aa 1b 30 c4 b5 28 0f ef 0e 34 9d df c3 e5 37 0a fe e0 d9 40 ee ed f7 .T.........0..(...4....7....@...
0220 bb 62 03 2b 1e c3 d5 5b 71 ff 9b 10 ad e8 47 0e 94 dc 7c aa b0 31 88 2d 73 33 e7 15 9d 87 f3 61 .b.+...[q.....G...|..1.-s3.....a
0240 02 5e 18 32 63 64 19 eb d8 a4 5c 7f 23 b4 00 2d fd 15 b7 56 f2 7a 21 f6 12 d6 79 9b eb 5f 12 ec .^.2cd....\.#..-...V.z!...y.._..
0260 5c 90 f1 9c b1 9a 19 ac 31 cd 99 2a 38 c0 79 27 cd 9a 54 de b3 8d eb 1b 28 93 33 fd 8d d0 2d 82 \.......1..*8.y'..T.....(.3...-.
0280 ef 58 ec f7 82 6b 82 6f 4d ae ef e2 df 16 34 b4 06 a2 fb 09 56 0f 49 cf b4 a8 38 48 15 e7 d0 82 .X...k.oM.....4.....V.I...8H....
02a0 c3 44 6e 22 04 7e 35 eb dd 9f f9 65 c5 26 8b 3a 84 3b de 82 b8 db 04 a5 0e 2c b4 10 2b bb 86 26 .Dn".~5....e.&.:.;.......,..+..&
02c0 be c0 32 1b 20 59 37 e0 99 e0 35 01 28 63 45 37 62 64 f1 e5 10 3a 8c b5 de c3 5a 8d 20 35 42 1e ..2..Y7...5.(cE7bd...:....Z..5B.
02e0 d9 87 96 b6 43 7c 37 39 ad 0b 6d bd 4c b9 fb 06 09 d1 f9 8a b5 b2 5b 69 84 ee 81 84 61 02 52 37 ....C|79..m.L.........[i....a.R7
0300 84 f5 f2 5b a3 f4 29 ac f1 07 ac b1 13 37 77 92 66 b5 d3 63 18 c4 62 bb 19 7b 8b b1 cd 8c 75 62 ...[..)......7w.f..c..b..{....ub
0320 ed 27 41 15 41 ab 08 09 c8 e7 7b d6 fb 5a 50 fc 9f 84 86 91 3a 3d 83 04 75 ed 12 da 7d 2d 94 aa .'A.A.....{..ZP.....:=..u...}-..
0340 07 59 b8 de 7f 80 6e 3a 69 1b 96 23 0f c3 e8 6b 35 64 35 d2 3f 78 8a 95 f7 f2 fc 00 b2 72 9f 1c .Y....n:i..#...k5d5.?x.......r..
0360 58 37 a0 8b df 43 dc d3 39 3f 05 d9 bc 7f a7 55 f5 f7 ae 92 3a 46 60 7a 8d 45 c5 6a e3 84 e6 ca X7...C..9?.....U....:F`z.E.j....
0380 14 64 14 72 3d 9e d4 e8 31 f9 6a 2a 56 55 4c 26 70 ce 94 21 b8 b0 6e ed d9 c6 e8 df ba b0 be 10 .d.r=...1.j*VUL&p..!..n.........
03a0 02 e2 26 02 96 26 fe b9 48 cc 0b e6 18 e4 dd d3 54 59 77 79 df 9e a5 20 e4 3d 1f 9e 8d c2 da da ..&..&..H.......TYwy.....=......
03c0 b0 0e b5 c0 1f d1 c5 38 70 16 ab 6c e5 77 14 0d ed 12 ac d3 b0 b4 f3 b8 6d 1a e9 94 93 a6 4b 09 .......8p..l.w..........m.....K.
03e0 96 5b 42 8f 56 93 fa 23 a6 2c 20 81 8d 72 18 9d 34 9a e4 51 14 29 41 4b 6d 61 41 5e ba 7a 16 d6 .[B.V..#.,...r..4..Q.)AKmaA^.z..
0400 d0 61 72 d7 02 2a 9a 02 16 9e c0 c2 8b b1 38 27 ee af 65 e8 5e 22 7b 2b 2e ae cf 7d c1 b5 36 53 .ar..*........8'..e.^"{+...}..6S
0420 70 3b 43 56 50 81 b5 1e 81 dc 03 58 ea 56 5f 8c 62 b1 c9 0c 58 48 7d 6d 7a 4e ad e8 3a bd d3 57 p;CVP......X.V_.b...XH}mzN..:..W
0440 90 9a 63 2c 0c 0b 51 6b aa 34 36 8c 5e ec 4d dc 52 a3 fe 61 1a dd 59 90 b3 9b 00 f4 33 63 9e a3 ..c,..Qk.46.^.M.R..a..Y.....3c..
0460 9b aa c5 17 d0 d6 22 ac b7 96 46 8d ce 99 f0 2e e9 5f ce 7c 74 05 d7 ba 4e 8e 99 84 d8 e7 92 37 ......"...F......_.|t...N......7
0480 ee 44 ff fa 70 f7 42 4f 51 16 8b 52 2b 9c 60 33 ae 90 cf c6 9b dc 37 92 9e 41 3a d6 6f b4 05 5f .D..p.BOQ..R+.`3......7..A:.o.._
04a0 d2 17 18 a7 40 a8 32 4a d2 c5 6a bc 5e 20 a2 3a bc 9c a3 1e 2b a8 31 4a 3b 37 e3 42 09 10 b5 bc ....@.2J..j.^..:....+.1J;7.B....
04c0 37 9b 28 5a 8e 3b 37 42 4c 3d d6 da ec a9 34 24 40 f5 11 c8 ba b0 e6 0c 22 f2 87 04 9b 20 a4 25 7.(Z.;7BL=....4$@......."......%
04e0 86 4d db 0e d9 f1 c8 48 bc f9 af 06 be 92 19 43 8a 32 0d ae e2 86 31 0b 9c a7 94 b4 64 82 08 5d .M.....H.......C.2....1.....d..]
0500 00 61 9b 2c c6 16 b2 79 c9 10 90 03 b1 87 08 26 19 68 5a 19 c4 e6 cd a3 b7 3a 4a 0e 5a 83 95 d7 .a.,...y.......&.hZ......:J.Z...
0520 a2 b3 fa 1d db 96 2c 9f c4 fd 26 c1 94 a9 7b 3e 89 80 6f 5e c0 5c 95 10 6a cc 37 4e b5 52 6b 6e ......,...&...{>..o^.\..j.7N.Rkn
0540 b5 91 76 18 2d b8 c3 0b dd 3c 37 ef ee a3 30 18 45 4e 1e a0 9d 23 78 84 e3 6d 92 a8 02 5e c5 79 ..v.-....<7...0.EN...#x..m...^.y
0560 38 ee d6 49 8a 12 8b ee 14 a1 63 5d 56 fd 4c e3 03 35 78 10 41 fb 69 52 dc c1 d5 42 11 fa 53 54 8..I......c]V.L..5x.A.iR...B..ST
0580 2c d5 c6 df 87 e8 4b 96 22 33 2d bc 3f da 8b 75 44 20 13 27 b0 ec 74 22 be 91 80 27 61 bd 7b 8d ,.....K."3-.?..uD..'..t"...'a.{.
05a0 46 c9 db 24 35 65 d6 ef 68 8b 31 fb f9 c8 08 8b 7b eb 4c e7 99 b8 a7 6a 61 ea ec 54 8a 85 6d b5 F..$5e..h.1.....{.L....ja..T..m.
05c0 98 23 8e 85 47 7a b9 86 58 72 ce c7 a4 47 0d 48 44 93 27 1d b7 0f eb ce d4 5a 92 fa 73 48 cb 23 .#..Gz..Xr...G.HD.'......Z..sH.#
05e0 ca ce 27 54 37 29 cb 75 71 21 4b f0 8e 00 8b 26 ca 04 a5 68 1d 81 d4 41 ce aa 69 59 d8 72 b6 96 ..'T7).uq!K....&...h...A..iY.r..
0600 34 dc 6e f5 3c c6 26 12 dd 53 2c ee 85 53 dd 64 9a ff b3 03 39 6a 0f 6e bc 83 c4 bd 8b c0 a9 41 4.n.<.&..S,..S.d....9j.n.......A
0620 a7 c3 df dc 2f 9e 34 25 78 1e 63 93 c8 31 b3 dc e8 f5 10 15 50 9e e9 7a 3a 9d a1 29 02 58 0d 73 ..../.4%x.c..1......P..z:..).X.s
0640 68 d3 e3 b4 ad 7f 6e 6a 65 02 4c 1d d9 86 a6 59 db 4d f7 92 c9 20 06 c9 35 7b ec 48 62 1f f6 61 h.....nje.L....Y.M......5{.Hb..a
0660 1f f6 e1 1f c7 bf 6f 02 94 ce 05 2a a8 a8 00 00 00 00 49 45 4e 44 ae 42 60 82 ......o....*......IEND.B`.
: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */
;; Implementation of parallel-execute using call/cc.
;;
;; By Ben Rudiak-Gould, 10/2002.
;;
;; Requires STk (for "procedure-body" and first-class environments).


(define call/cc call-with-current-continuation)


(define (parallel-execute . thunks)
  (apply run-concurrently-with-env
         random
         (map (lambda (thunk)
                (cons (list (uncode (procedure-body thunk)))
		      (make-virtual-env (procedure-environment thunk)) ))
              thunks ))
  'okay )


(define (run-concurrently select . exprs)
  (apply run-concurrently-with-env
	 select
	 (map (lambda (x)
		(cons x (make-virtual-env (global-environment))) )
	      exprs )))


(define (run-concurrently-with-env select . exprs-with-envs)
  (let ((threads
	 (map (lambda (exp-env)
		(list (call/cc
		       (lambda (cont)
			 (let ((scheduler (call/cc cont)))
			   (scheduler (myeval (car exp-env)
					      (cdr exp-env)
					      scheduler )))))))
	      exprs-with-envs )))
    (let loop ()
      (let ((active-threads
             (filter (lambda (x) (continuation? (car x))) threads) ))
        (if (null? active-threads)
            (map car threads)
            (let ((active (list-ref active-threads
                                    (select (length active-threads)) )))
              (set-car! active (call/cc (car active)))
              (loop) ))))))


(define (make-virtual-env real-env)
  (cons
   `((quote    **macro** ,macro-quote)
     (lambda   **macro** ,macro-lambda)
     (let      **macro** ,macro-let)
     (set!     **macro** ,macro-set!)
     (define   **macro** ,macro-define)
     (if       **macro** ,macro-if)
     (cond     **macro** ,macro-cond)
     (and      **macro** ,macro-and)
     (or       **macro** ,macro-or)
     (set-car! **prim**  ,prim-set-car!)
     (set-cdr! **prim**  ,prim-set-cdr!)
     (begin    **prim**  ,prim-begin)
     (test-and-set! **prim** ,prim-test-and-set!) )
   real-env ))


(define (env-lookup-raw sym env scheduler)
  (call/cc scheduler)
  (let ((virtual (assq sym (car env))))
    (if virtual
        (cdr virtual)
        (eval sym (cdr env)) )))


(define (env-lookup sym env scheduler)
  (let* ((val (env-lookup-raw sym env scheduler))
         (proc-body (procedure-body val)) )
    (if (and proc-body (not (eq? (cadr proc-body) '**args**)))
        (myeval (uncode proc-body)
                (make-virtual-env (procedure-environment val))
                scheduler )
        val )))


(define (env-set! sym val env scheduler)
  (call/cc scheduler)
  (let ((virtual (assq sym (car env))))
    (if virtual
        (set-cdr! virtual val)
        (eval `(set! ,sym ',val) (cdr env)) )))


(define (env-define! sym val env scheduler)
  (call/cc scheduler)
  (set-car! env (cons (cons sym val) (car env))) )


(define (get-special-form name env scheduler)
  (if (symbol? name)
      (let ((val (env-lookup-raw name env scheduler)))
        (if (and (pair? val) (eq? (car val) '**macro**))
            val
            #f ))
      #f ))


(define (myeval expr env scheduler)
  (cond ((pair? expr)
         (let ((special (get-special-form (car expr) env scheduler)))
           (if special
               ((cadr special) (cdr expr) env scheduler)
               (let ((evaluated (eval-seq expr env scheduler)))
                 (myapply (car evaluated) (cdr evaluated) scheduler) ))))
        ((symbol? expr)
	 (env-lookup expr env scheduler) )
        (else (eval expr)) ))


(define (eval-seq exprs env scheduler)
  (if (null? exprs)
      '()
      (let ((val (myeval (car exprs) env scheduler)))
	(cons val (eval-seq (cdr exprs) env scheduler)) )))


(define (myapply func args scheduler)
  (cond ((procedure? func)
         (apply func args) )
        ((and (pair? func) (eq? (car func) '**prim**))
         ((cadr func) args scheduler) )
        ((and (pair? func) (eq? (car func) '**macro**))
         ((cadr func) (map (lambda (x) (list 'quote x)) args) scheduler) )
        (else (error "apply of non-procedure" func args)) ))


(define (make-call-environment params args env)
  (cons (let loop ((params params) (args args))
          (cond ((pair? params)
                 (cons (cons (car params) (car args))
                       (loop (cdr params) (cdr args)) ))
                ((null? params)
                 (car env) )
                (else (cons (cons params args) (car env))) ))
        (cdr env) ))


(define (macro-lambda args env scheduler)
  (let ((params (car args))
        (body (cdr args)) )
    (lambda **args**
      (let ((new-env (make-call-environment params **args** env)))
        (last (map (lambda (x) (myeval x new-env scheduler)) body)) ))))


(define (macro-let args env scheduler)
  (let ((vars (map car (car args)))
        (vals (map cadr (car args)))
        (body (cdr args)) )
    (myeval `((lambda ,vars ,@body) ,@vals) env scheduler) ))


(define (macro-define args env scheduler)
  (if (pair? (car args))
      (macro-define `(,(caar args) (lambda ,(cdar args) ,@(cdr args)))
		    env scheduler )
      (let ((val (myeval (cadr args) env scheduler)))
        (env-define! (car args) val env scheduler) )))


(define (macro-set! args env scheduler)
  (let ((val (myeval (cadr args) env scheduler)))
    (env-set! (car args) val env scheduler) ))


(define (macro-quote args env scheduler)
  (car args) )


(define (macro-if args env scheduler)
  (if (myeval (car args) env scheduler)
      (myeval (cadr args) env scheduler)
      (if (pair? (cddr args))
	  (myeval (caddr args) env scheduler)
	  'okay )))


(define (macro-cond args env scheduler)
  (cond ((null? args) 'okay)
        ((or (eq? (caar args) 'else)
             (myeval (caar args) env scheduler) )
         (car (last-pair (eval-seq (cdar args) env scheduler))) )
        (else (macro-cond (cdr args) env scheduler)) ))


(define (macro-and args env scheduler)
  (if (null? args)
      #t
      (let ((val (myeval (car args) env scheduler)))
        (if (null? (cdr args))
            val
            (and val (macro-and (cdr args) env scheduler)) ))))


(define (macro-or args env scheduler)
  (if (null? args)
      #f
      (let ((val (myeval (car args) env scheduler)))
        (if (null? (cdr args))
            val
            (or val (macro-or (cdr args) env scheduler)) ))))


(define (prim-set-car! args scheduler)
  (call/cc scheduler)
  (apply set-car! args) )


(define (prim-set-cdr! args scheduler)
  (call/cc scheduler)
  (apply set-cdr! args) )


(define (prim-begin args scheduler)
  (car (last-pair args)) )


(define (prim-test-and-set! args scheduler)
  (call/cc scheduler)
  (test-and-set! (car args)) )


(define (test-and-set! x)
  (let ((oldval (car x)))
    (set-car! x #t)
    oldval ))


(define (last-pair lst)
  (if (null? (cdr lst))
      lst
      (last-pair (cdr lst)) ))


(load "~cs61a/lib/serial.scm")