projects
/
8sync.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
dispatching to websocket handlers
[8sync.git]
/
demos
/
ircbot.scm
diff --git
a/demos/ircbot.scm
b/demos/ircbot.scm
index b962ad742db99e30e2437305190740434b98ce80..00c48ffe2eef8d6883802f78fd1918ba9c6353ef 100755
(executable)
--- a/
demos/ircbot.scm
+++ b/
demos/ircbot.scm
@@
-3,7
+3,7
@@
!#
;;; 8sync --- Asynchronous programming for Guile
!#
;;; 8sync --- Asynchronous programming for Guile
-;;; Copyright
(C) 2015
Christopher Allan Webber <cwebber@dustycloud.org>
+;;; Copyright
© 2015, 2016, 2017
Christopher Allan Webber <cwebber@dustycloud.org>
;;;
;;; This file is part of 8sync.
;;;
;;;
;;; This file is part of 8sync.
;;;
@@
-30,8
+30,8
@@
(define-class <my-irc-bot> (<irc-bot>))
(define-class <my-irc-bot> (<irc-bot>))
-(define-method (handle-line (irc-bot <my-irc-bot>)
speaker channel
- line emote?)
+(define-method (handle-line (irc-bot <my-irc-bot>)
message
+
speaker channel
line emote?)
(define my-name (irc-bot-username irc-bot))
(define (looks-like-me? str)
(or (equal? str my-name)
(define my-name (irc-bot-username irc-bot))
(define (looks-like-me? str)
(or (equal? str my-name)
@@
-41,19
+41,19
@@
(match action
;; The classic botsnack!
("botsnack"
(match action
;; The classic botsnack!
("botsnack"
- (<-
irc-bot
(actor-id irc-bot) 'send-line channel
+ (<- (actor-id irc-bot) 'send-line channel
"Yippie! *does a dance!*"))
;; Return greeting
((or "hello" "hello!" "hello." "greetings" "greetings." "greetings!"
"hei" "hei." "hei!" "hi" "hi!")
"Yippie! *does a dance!*"))
;; Return greeting
((or "hello" "hello!" "hello." "greetings" "greetings." "greetings!"
"hei" "hei." "hei!" "hi" "hi!")
- (<-
irc-bot
(actor-id irc-bot) 'send-line channel
+ (<- (actor-id irc-bot) 'send-line channel
(format #f "Oh hi ~a!" speaker)))
;; ---> Add yours here <---
;; Default
(_
(format #f "Oh hi ~a!" speaker)))
;; ---> Add yours here <---
;; Default
(_
- (<-
irc-bot
(actor-id irc-bot) 'send-line channel
+ (<- (actor-id irc-bot) 'send-line channel
"*stupid puppy look*"))))
;; Otherwise... just spit the output to current-output-port or whatever
(_
"*stupid puppy look*"))))
;; Otherwise... just spit the output to current-output-port or whatever
(_
@@
-104,26
+104,20
@@
(repl #f))
(define hive (make-hive))
(define irc-bot
(repl #f))
(define hive (make-hive))
(define irc-bot
- (
hive-create
-actor* hive <my-irc-bot> "irc-bot"
-
#:username username
-
#:server server
-
#:channels channels))
+ (
bootstrap
-actor* hive <my-irc-bot> "irc-bot"
+ #:username username
+ #:server server
+ #:channels channels))
(define repl-manager
(cond
((string? repl)
(define repl-manager
(cond
((string? repl)
- (
hive-create
-actor* hive <repl-manager> "repl"
-
#:path repl))
+ (
bootstrap
-actor* hive <repl-manager> "repl"
+ #:path repl))
(repl
(repl
- (hive-create-actor* hive <repl-manager> "repl"))))
-
- (define initial-messages
- (if repl
- (list (bootstrap-message hive irc-bot 'init)
- (bootstrap-message hive repl-manager 'init))
- (list (bootstrap-message hive irc-bot 'init))))
+ (bootstrap-actor* hive <repl-manager> "repl"))))
;; TODO: load REPL
;; TODO: load REPL
- (run-hive hive
initial-messages
))
+ (run-hive hive
'()
))
(define (main args)
(define parsed-args (parse-args "ircbot.scm" args))
(define (main args)
(define parsed-args (parse-args "ircbot.scm" args))