-#!/usr/bin/guile \
+#! /usr/bin/env guile \
-e main -s
!#
;;; 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.
;;;
;;; License along with 8sync. If not, see <http://www.gnu.org/licenses/>.
(use-modules (8sync)
+ (8sync contrib irc)
(8sync systems irc)
+ (8sync repl)
(oop goops)
(srfi srfi-37)
+ (ice-9 format)
(ice-9 match))
(define-class <my-irc-bot> (<irc-bot>))
-(define-method (irc-bot-handle-line (irc-bot <my-irc-bot>) speaker channel
- line emote?)
+(define-method (handle-message (irc-bot <my-irc-bot>) message)
(define my-name (irc-bot-username irc-bot))
(define (looks-like-me? str)
(or (equal? str my-name)
(equal? str (string-concatenate (list my-name ":")))))
- (match (string-split line #\space)
- (((? looks-like-me? _) action action-args ...)
- (match action
- ;; The classic botsnack!
- ("botsnack"
- (<- irc-bot (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!")
- (<- irc-bot (actor-id irc-bot) 'send-line channel
- (format #f "Oh hi ~a!" speaker)))
- ;; ---> Add yours here <---
+ (match message
+ ((and ($ <irc:message>)
+ (= irc:message-line line)
+ (= irc:message-command 'PRIVMSG)
+ (= irc:message-speaker speaker)
+ (= irc:message-channel channel)
+ (= irc:message-message message)
+ (= irc:message-emote? emote?))
- ;; Default
+ (match (string-split message #\space)
+ (((? looks-like-me? _) action action-args ...)
+ (match action
+ ;; The classic botsnack!
+ ("botsnack"
+ (<- (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!")
+ (<- (actor-id irc-bot) 'send-line channel
+ (format #f "Oh hi ~a!" speaker)))
+
+ ;; ---> Add yours here <---
+
+ ;; Default
+ (_
+ (<- (actor-id irc-bot) 'send-line channel
+ "*stupid puppy look*"))))
+ ;; Otherwise... just spit the output to current-output-port or whatever
(_
- (<- irc-bot (actor-id irc-bot) 'send-line channel
- "*stupid puppy look*"))))
- ;; Otherwise... just spit the output to current-output-port or whatever
- (_
- (if emote?
- (format #t "~a emoted ~s in channel ~a\n"
- speaker line channel)
- (format #t "~a said ~s in channel ~a\n"
- speaker line channel)))))
+ (if emote?
+ (format #t "~a emoted ~s in channel ~a\n"
+ speaker message channel)
+ (format #t "~a said ~s in channel ~a\n"
+ speaker message channel)))))
+ (_ #f)))
(define (display-help scriptname)
(option '("channels") #t #f
(lambda (opt name arg result)
`(#:channels ,(string-split arg #\,)
- ,@result))))
+ ,@result)))
+ (option '("repl") #f #t
+ (lambda (opt name arg result)
+ `(#:repl ,(or arg #t) ,@result))))
(lambda (opt name arg result)
(format #t "Unrecognized option `~a'\n" name)
(exit 1))
(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)
+ (bootstrap-actor* hive <repl-manager> "repl"
+ #:path repl))
+ (repl
+ (bootstrap-actor* hive <repl-manager> "repl"))))
+
;; TODO: load REPL
- (ez-run-hive hive (list (bootstrap-message hive irc-bot 'init))))
+ (run-hive hive '()))
(define (main args)
(define parsed-args (parse-args "ircbot.scm" args))