From f9ea7657945df342965a45d03361f4dc50acb2d2 Mon Sep 17 00:00:00 2001 From: tj Date: Thu, 19 Nov 2009 04:37:56 +0100 Subject: [PATCH] Move USER, NICK to right after connecting --- irc.go | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/irc.go b/irc.go index 9caa43e..cdd0265 100644 --- a/irc.go +++ b/irc.go @@ -30,7 +30,6 @@ func writer(irc *IRCConnection) { for { b := strings.Bytes(<-irc.pwrite); _, err := irc.socket.Write(b); - fmt.Printf("<-- %s", b); if err != nil { irc.perror <- err } @@ -149,7 +148,8 @@ func (irc *IRCConnection) handle_command(msg string) *IRCEvent { case "ERROR": e.Code = IRC_PING; e.Message = matches[2]; - e.Error = os.ErrorString(matches[2]);; + e.Error = os.ErrorString(matches[2]); + ; irc.perror <- e.Error; } return e; @@ -162,17 +162,13 @@ func (irc *IRCConnection) handle_command(msg string) *IRCEvent { func handler(irc *IRCConnection) { go reader(irc); go writer(irc); + irc.pwrite <- fmt.Sprintf("NICK %s\r\n", irc.nick); + irc.pwrite <- fmt.Sprintf("USER %s 0.0.0.0 0.0.0.0 :GolangBOT\r\n", irc.user); for { select { case msg := <-irc.pread: e := irc.handle_command(msg); switch e.Code { - case IRC_NOTICE_AUTH: - if irc.registered == false { - irc.pwrite <- fmt.Sprintf("NICK %s\r\n", irc.nick); - irc.pwrite <- fmt.Sprintf("USER %s 0.0.0.0 0.0.0.0 :GolangBOT\r\n", irc.user); - irc.registered = true; - } case IRC_PING: irc.pwrite <- fmt.Sprintf("PONG %s\r\n", e.Message) case IRC_PRIVMSG: