Artifact 9431c45e97630074812e2baaecb3e251394f7637:


0000: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0010: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0020: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0030: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0040: 3d 3d 3d 3d 3d 3d 0a 31 2e 20 43 72 65 61 74 65  ======.1. Create
0050: 20 61 20 6c 69 6e 6b 2e 0a 0a 28 73 3a 6e 75 6c   a link...(s:nul
0060: 6c 20 22 5b 22 20 28 73 3a 61 20 6e 61 6d 65 20  l "[" (s:a name 
0070: 27 68 72 65 66 20 0a 20 20 20 20 20 20 20 20 20  'href .         
0080: 20 20 20 20 20 20 28 73 3a 6c 69 6e 6b 2d 74 6f        (s:link-to
0090: 20 28 73 74 72 69 6e 67 2d 61 70 70 65 6e 64 20   (string-append 
00a0: 22 6c 6f 63 61 74 69 6f 6e 2f 22 20 28 73 74 72  "location/" (str
00b0: 69 6e 67 2d 69 6e 74 65 72 73 70 65 72 73 65 20  ing-intersperse 
00c0: 70 20 22 2f 22 29 20 22 22 29 29 29 20 22 5d 20  p "/") ""))) "] 
00d0: 22 29 29 29 0a 0a 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ")))..==========
00e0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
00f0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0100: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0110: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 0a 32 2e 20  ============.2. 
0120: 43 61 6c 6c 20 63 75 72 72 65 6e 74 20 70 61 67  Call current pag
0130: 65 20 77 69 74 68 20 6e 65 77 20 70 61 72 61 6d  e with new param
0140: 0a 0a 49 6e 20 76 69 65 77 2e 73 63 6d 3a 0a 0a  ..In view.scm:..
0150: 20 28 73 3a 63 65 6e 74 65 72 20 22 5b 22 20 28   (s:center "[" (
0160: 73 3a 61 20 27 68 72 65 66 20 28 73 3a 6c 69 6e  s:a 'href (s:lin
0170: 6b 2d 74 6f 20 22 70 6f 6c 6c 73 22 0a 20 20 20  k-to "polls".   
0180: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0190: 20 20 20 20 20 20 20 20 27 69 64 0a 20 20 20 20          'id.    
01a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
01b0: 20 20 20 20 20 20 20 20 28 62 65 67 69 6e 0a 20          (begin. 
01c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
01d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 28 70 6f               (po
01e0: 6c 6c 3a 70 6f 6c 6c 20 27 66 69 6c 6c 2d 70 6f  ll:poll 'fill-po
01f0: 6c 6c 73 29 0a 20 20 20 20 20 20 20 20 20 20 20  lls).           
0200: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0210: 20 20 20 28 70 6f 6c 6c 3a 70 6f 6c 6c 20 27 67     (poll:poll 'g
0220: 65 74 2d 6e 65 78 74 2d 70 6f 6c 6c 29 29 29 0a  et-next-poll))).
0230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0240: 20 20 20 20 20 20 20 20 20 20 22 47 6f 20 74 6f            "Go to
0250: 20 74 68 65 20 6e 65 78 74 20 70 6f 6c 6c 22 29   the next poll")
0260: 20 20 22 5d 22 29 0a 0a 49 6e 20 63 6f 6e 74 72    "]")..In contr
0270: 6f 6c 2e 73 63 6d 3a 0a 0a 28 6c 65 74 20 28 28  ol.scm:..(let ((
0280: 70 6f 6c 6c 2d 69 64 20 28 73 3a 67 65 74 2d 70  poll-id (s:get-p
0290: 61 72 61 6d 20 27 69 64 29 29 29 0a 20 3b 3b 20  aram 'id))). ;; 
02a0: 64 6f 20 73 74 75 66 66 20 62 61 73 65 64 20 6f  do stuff based o
02b0: 6e 20 70 6f 6c 6c 2d 69 64 0a 0a 3d 3d 3d 3d 3d  n poll-id..=====
02c0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
02d0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
02e0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
02f0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0300: 3d 0a 33 2e 20 43 61 6c 6c 20 61 6e 20 61 63 74  =.3. Call an act
0310: 69 6f 6e 20 6f 6e 20 61 20 73 70 65 63 69 66 69  ion on a specifi
0320: 63 20 70 61 67 65 0a 0a 20 28 73 3a 61 20 27 68  c page.. (s:a 'h
0330: 72 65 66 20 28 73 3a 6c 69 6e 6b 2d 74 6f 20 22  ref (s:link-to "
0340: 70 6f 6c 6c 73 22 20 27 69 64 20 28 70 6f 6c 6c  polls" 'id (poll
0350: 3a 70 6f 6c 6c 20 27 67 65 74 20 27 69 64 29 20  :poll 'get 'id) 
0360: 0a 09 09 09 20 20 20 20 20 20 20 27 61 63 74 69  ....       'acti
0370: 6f 6e 20 22 70 6f 6c 6c 2e 65 64 69 74 22 29 0a  on "poll.edit").
0380: 20 20 20 20 20 20 20 20 20 20 20 20 22 53 75 67              "Sug
0390: 67 65 73 74 20 63 68 61 6e 67 65 73 20 74 6f 20  gest changes to 
03a0: 74 68 69 73 20 70 6f 6c 6c 22 29 0a 0a 20 4e 4f  this poll").. NO
03b0: 54 20 54 52 55 45 21 20 54 68 69 73 20 63 61 6c  T TRUE! This cal
03c0: 6c 73 20 66 75 63 74 69 6f 6e 20 70 6f 6c 6c 2e  ls fuction poll.
03d0: 65 64 69 74 20 28 73 68 6f 75 6c 64 20 62 65 20  edit (should be 
03e0: 69 6e 20 63 6f 6e 74 72 6f 6c 2e 73 63 6d 29 2e  in control.scm).
03f0: 20 50 61 72 61 6d 65 74 65 72 20 73 65 74 20 69   Parameter set i
0400: 73 20 27 69 64 20 74 6f 20 61 20 70 6f 6c 6c 20  s 'id to a poll 
0410: 6e 75 6d 2e 0a 0a 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  num...==========
0420: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0430: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0440: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0450: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 0a 34 2e 20  ============.4. 
0460: 41 20 63 6f 6d 70 6c 65 78 20 6c 69 6e 6b 20 65  A complex link e
0470: 78 61 6d 70 6c 65 0a 0a 28 73 3a 61 20 22 52 65  xample..(s:a "Re
0480: 70 6c 79 22 20 27 68 72 65 66 20 28 73 3a 6c 69  ply" 'href (s:li
0490: 6e 6b 2d 74 6f 20 28 73 3a 63 75 72 72 65 6e 74  nk-to (s:current
04a0: 2d 70 61 67 65 29 20 0a 09 20 20 20 20 20 20 20  -page) ..       
04b0: 20 20 20 20 27 61 63 74 69 6f 6e 20 22 64 69 73      'action "dis
04c0: 63 75 73 73 69 6f 6e 2e 72 65 70 6c 79 22 20 3b  cussion.reply" ;
04d0: 3b 20 3c 70 61 67 65 3e 2e 3c 61 63 74 69 6f 6e  ; <page>.<action
04e0: 3e 0a 09 20 20 20 20 20 20 20 20 20 20 20 27 72  >..           'r
04f0: 65 70 6c 79 5f 74 6f 20 28 6e 75 6d 62 65 72 2d  eply_to (number-
0500: 3e 73 74 72 69 6e 67 20 28 68 61 73 68 2d 74 61  >string (hash-ta
0510: 62 6c 65 2d 72 65 66 20 72 6f 77 20 27 70 6f 73  ble-ref row 'pos
0520: 74 73 2e 69 64 29 29 20 0a 09 20 20 20 20 20 20  ts.id)) ..      
0530: 20 20 20 20 20 27 69 64 20 28 73 3a 67 65 74 20       'id (s:get 
0540: 22 64 69 73 63 75 73 73 69 6f 6e 2e 70 61 72 65  "discussion.pare
0550: 6e 74 5f 6f 62 6a 65 63 74 5f 69 64 22 29 29 20  nt_object_id")) 
0560: 22 72 65 70 6c 79 22 29 0a 0a 3b 3b 20 75 73 65  "reply")..;; use
0570: 20 28 73 3a 67 65 74 2d 70 61 72 61 6d 20 74 6f   (s:get-param to
0580: 20 67 65 74 20 74 68 65 20 27 69 64 2c 20 6f 72   get the 'id, or
0590: 20 27 72 65 70 6c 79 5f 74 6f 20 76 61 6c 75 65   'reply_to value
05a0: 73 0a 0a 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  s..=============
05b0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
05c0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
05d0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
05e0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 0a 35 2e 20 47 65 74  =========.5. Get
05f0: 20 61 6e 64 20 73 65 74 20 61 20 73 65 73 73 69   and set a sessi
0600: 6f 6e 20 76 61 72 0a 0a 28 73 3a 73 65 73 73 69  on var..(s:sessi
0610: 6f 6e 2d 76 61 72 2d 67 65 74 20 22 6b 65 79 6e  on-var-get "keyn
0620: 61 6d 65 22 29 0a 28 73 3a 73 65 73 73 69 6f 6e  ame").(s:session
0630: 2d 76 61 72 2d 73 65 74 21 20 22 6b 65 79 6e 61  -var-set! "keyna
0640: 6d 65 22 20 22 76 61 6c 75 65 22 29 0a 0a 35 2e  me" "value")..5.
0650: 31 20 50 61 67 65 20 6c 6f 63 61 6c 20 76 61 72  1 Page local var
0660: 73 0a 0a 28 73 3a 73 65 74 21 20 6b 65 79 20 76  s..(s:set! key v
0670: 61 6c 29 0a 28 73 3a 67 65 74 20 6b 65 79 29 0a  al).(s:get key).
0680: 0a 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  .===============
0690: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
06a0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
06b0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
06c0: 3d 3d 3d 3d 3d 3d 3d 0a 36 2e 20 6d 61 6b 65 20  =======.6. make 
06d0: 61 20 73 65 6c 65 63 74 69 6f 6e 20 64 72 6f 70  a selection drop
06e0: 20 64 6f 77 6e 0a 0a 49 6e 20 76 69 65 77 2e 73   down..In view.s
06f0: 63 6d 3a 20 0a 0a 28 73 3a 73 65 6c 65 63 74 20  cm: ..(s:select 
0700: 27 28 28 22 57 6f 72 6c 64 22 20 30 29 28 22 43  '(("World" 0)("C
0710: 6f 75 6e 74 72 79 22 20 31 29 28 22 53 74 61 74  ountry" 1)("Stat
0720: 65 22 20 32 29 28 22 54 6f 77 6e 2f 43 69 74 79  e" 2)("Town/City
0730: 22 20 33 29 29 20 27 6e 61 6d 65 20 27 73 63 6f  " 3)) 'name 'sco
0740: 70 65 29 0a 0a 49 6e 20 63 6f 6e 74 72 6f 6c 2e  pe)..In control.
0750: 73 63 6d 3a 0a 0a 28 6c 65 74 20 28 28 73 63 6f  scm:..(let ((sco
0760: 70 65 20 28 73 3a 67 65 74 2d 69 6e 70 75 74 20  pe (s:get-input 
0770: 27 73 63 6f 70 65 29 29 29 0a 20 20 2e 2e 2e 2e  'scope))).  ....
0780: 0a 0a 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ..==============
0790: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
07a0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
07b0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
07c0: 3d 3d 3d 3d 3d 3d 3d 3d 0a 37 2e 20 53 69 6d 70  ========.7. Simp
07d0: 6c 65 20 65 72 72 6f 72 20 72 65 70 6f 72 74 69  le error reporti
07e0: 6e 67 0a 0a 49 6e 20 63 6f 6e 74 72 6f 6c 2e 73  ng..In control.s
07f0: 63 6d 3a 0a 28 73 3a 73 65 74 2d 65 72 72 20 22  cm:.(s:set-err "
0800: 59 6f 75 20 6d 75 73 74 20 70 72 6f 76 69 64 65  You must provide
0810: 20 61 6e 20 65 6d 61 69 6c 20 61 64 64 72 65 73   an email addres
0820: 73 22 29 0a 0a 49 6e 20 76 69 65 77 2e 73 63 6d  s")..In view.scm
0830: 3a 0a 28 73 3a 67 65 74 2d 65 72 72 20 73 3a 65  :.(s:get-err s:e
0840: 72 72 2d 66 6f 6e 74 29 0a 0a 4f 72 3a 0a 28 73  rr-font)..Or:.(s
0850: 3a 67 65 74 2d 65 72 72 20 28 6c 61 6d 62 64 61  :get-err (lambda
0860: 20 28 78 29 28 73 3a 65 72 72 2d 66 6f 6e 74 20   (x)(s:err-font 
0870: 78 20 28 73 3a 62 72 29 29 29 29 0a 0a 3d 3d 3d  x (s:br))))..===
0880: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0890: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
08a0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
08b0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
08c0: 3d 3d 3d 0a 38 2e 20 4d 69 73 63 20 75 73 65 66  ===.8. Misc usef
08d0: 75 6c 20 73 74 75 66 66 0a 0a 20 20 69 2e 20 4c  ul stuff..  i. L
08e0: 61 7a 79 2f 73 61 66 65 20 73 74 72 69 6e 67 2d  azy/safe string-
08f0: 3e 6e 75 6d 62 65 72 20 0a 0a 28 73 3a 61 6e 79  >number ..(s:any
0900: 2d 3e 6e 75 6d 62 65 72 20 76 61 6c 29 0a 0a 20  ->number val).. 
0910: 20 69 69 2e 20 52 61 6e 64 6f 6d 20 73 74 72 69   ii. Random stri
0920: 6e 67 0a 0a 28 73 65 73 73 69 6f 6e 3a 6d 61 6b  ng..(session:mak
0930: 65 2d 72 61 6e 64 2d 73 74 72 69 6e 67 20 6c 65  e-rand-string le
0940: 6e 29 0a 0a 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  n)..============
0950: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0960: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0970: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0980: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 0a 39 2e 20 46 6f  ==========.9. Fo
0990: 72 6d 73 20 61 6e 64 20 69 6e 70 75 74 0a 0a 28  rms and input..(
09a0: 73 3a 66 6f 72 6d 20 27 61 63 74 69 6f 6e 20 22  s:form 'action "
09b0: 6c 6f 67 69 6e 2e 6c 6f 67 69 6e 22 20 27 6d 65  login.login" 'me
09c0: 74 68 6f 64 20 22 70 6f 73 74 22 0a 20 20 20 28  thod "post".   (
09d0: 73 3a 69 6e 70 75 74 2d 70 72 65 73 65 72 76 65  s:input-preserve
09e0: 20 27 74 79 70 65 20 22 74 65 78 74 22 20 27 6e   'type "text" 'n
09f0: 61 6d 65 20 22 65 6d 61 69 6c 2d 61 64 64 72 65  ame "email-addre
0a00: 73 73 22 20 27 73 69 7a 65 20 22 31 36 22 20 27  ss" 'size "16" '
0a10: 6d 61 78 6c 65 6e 67 74 68 20 22 33 30 22 29 0a  maxlength "30").
0a20: 20 20 20 28 73 3a 69 6e 70 75 74 20 27 74 79 70     (s:input 'typ
0a30: 65 20 22 73 75 62 6d 69 74 22 20 20 20 27 6e 61  e "submit"   'na
0a40: 6d 65 20 22 66 6f 72 6d 2d 6e 61 6d 65 22 20 27  me "form-name" '
0a50: 76 61 6c 75 65 20 22 6c 6f 67 69 6e 22 29 29 0a  value "login")).
0a60: 0a 28 73 3a 67 65 74 2d 69 6e 70 75 74 20 27 65  .(s:get-input 'e
0a70: 6d 61 69 6c 2d 61 64 64 72 65 73 73 29 0a 0a 3d  mail-address)..=
0a80: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0a90: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0aa0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0ab0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0ac0: 3d 3d 3d 3d 3d 0a 31 30 2e 20 0a 0a              =====.10. ..