summaryrefslogtreecommitdiff
path: root/community-garden.scm
blob: 7cd535aa5ae9adccfe3e96a6307b91dc434ccd27 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
(setenv "CATBIRD_DEV_MODE" "1")

(use-modules (catbird)
             (catbird camera)
             (catbird kernel)
             (catbird node)
             (catbird node-2d)
             (catbird region)
             ((catbird scene) #:select (<scene>))
             (chickadee graphics color)
             (chickadee graphics path)
             (chickadee math vector)
             (community-garden actors)
             (community-garden garden-bed)
             (community-garden plant)
             (community-garden view)
             (goblins)
             (goblins vrun)
             (goblins ocapn ids)
             (goblins ocapn captp)
             (goblins ocapn netlayer onion)
             (ice-9 atomic)
             (oop goops))

(define garden-vat (spawn-vat))
(define catbird-vat (spawn-vat))
(define alice-vat (spawn-vat))
(define-vat-run garden-run garden-vat)
(define-vat-run catbird-run catbird-vat)
(define-vat-run alice-run alice-vat)
(define the-botanist (garden-run (spawn ^botanist)))
(define the-garden-gate (garden-run (spawn ^garden-gate the-botanist)))
(define sunflower/approved
  (garden-run ($ the-botanist 'approve-plant sunflower)))
(define cabbage/approved
  (garden-run ($ the-botanist 'approve-plant cabbage)))
(define our-garden
  (garden-run
   (spawn ^garden
          "Spritely Institute Community Garden"
          (make-garden-bed 8 8)
          the-garden-gate)))
(define our-garden-community
  (garden-run
   (spawn ^garden-community our-garden)))
(define onion-netlayer (garden-run (new-onion-netlayer)))
(define mycapn
  (garden-run
   (let* ((mycapn (spawn-mycapn onion-netlayer))
          (community-sref ($ mycapn 'register our-garden-community 'onion)))
     (format #t "Connect to: ~a\n" (ocapn-id->string community-sref))
     mycapn)))

(define alice
  (alice-run (<- our-garden-community 'register-gardener "Alice")))
(define (alice-plant x y plant)
  (alice-run (on alice
                 (lambda (alice)
                   (<- alice 'plant x y plant)))))

(alice-plant 1 1 sunflower/approved)
(alice-plant 2 1 sunflower/approved)
(alice-plant 1 2 sunflower/approved)
(alice-plant 2 2 sunflower/approved)
(alice-plant 5 1 cabbage/approved)
(alice-plant 6 1 cabbage/approved)
(alice-plant 5 2 cabbage/approved)
(alice-plant 6 2 cabbage/approved)

(define catbird-visitor
  (catbird-run (<- our-garden-community 'register-visitor "Catbird Viewer")))
(define catbird-garden-bed (make-atomic-box #f))
(define catbird-garden-name (make-atomic-box #f))
(catbird-run
 (on catbird-visitor
     (lambda (visitor)
       (on (<- visitor 'get-garden-name)
           (lambda (name)
             (atomic-box-set! catbird-garden-name name))))))

(run-catbird
 (lambda ()
   (let ((region (create-full-region #:name 'main))
         (scene (make <scene> #:name 'scratch)))
     (replace-scene region scene)
     (set! (camera region)
           (make <camera-2d>
             #:width %window-width
             #:height %window-height))
     (attach-to scene
                (make <canvas>
                  #:name 'background
                  #:painter
                  (with-style ((fill-color db32-elf-green))
                    (fill
                     (rectangle (vec2 0.0 0.0)
                                %window-width
                                %window-height))))
                (make <garden-view>
                  #:vat catbird-vat
                  #:visitor catbird-visitor
                  #:name-box catbird-garden-name
                  #:garden-bed-box catbird-garden-bed))))
 #:title "Community Garden"
 #:width %window-width
 #:height %window-height)