Преглед изворни кода

move db init/open functions into a single file

tags/v0.1.0
Jeremy Latt пре 10 година
родитељ
комит
b421971b61
3 измењених фајлова са 34 додато и 31 уклоњено
  1. 1
    24
      ergonomadic.go
  2. 32
    0
      irc/database.go
  3. 1
    7
      irc/server.go

+ 1
- 24
ergonomadic.go Прегледај датотеку

@@ -2,12 +2,10 @@ package main
2 2
 
3 3
 import (
4 4
 	"code.google.com/p/go.crypto/bcrypt"
5
-	"database/sql"
6 5
 	"encoding/base64"
7 6
 	"flag"
8 7
 	"fmt"
9 8
 	"github.com/jlatt/ergonomadic/irc"
10
-	_ "github.com/mattn/go-sqlite3"
11 9
 	"log"
12 10
 	"os"
13 11
 )
@@ -21,27 +19,6 @@ func genPasswd(passwd string) {
21 19
 	fmt.Println(encoded)
22 20
 }
23 21
 
24
-func initDB(config *irc.Config) {
25
-	os.Remove(config.Database())
26
-
27
-	db, err := sql.Open("sqlite3", config.Database())
28
-	if err != nil {
29
-		log.Fatal(err)
30
-	}
31
-	defer db.Close()
32
-
33
-	_, err = db.Exec(`
34
-        CREATE TABLE channel (
35
-          name TEXT NOT NULL UNIQUE,
36
-          flags TEXT NOT NULL,
37
-          key TEXT NOT NULL,
38
-          topic TEXT NOT NULL,
39
-          user_limit INTEGER DEFAULT 0)`)
40
-	if err != nil {
41
-		log.Fatal(err)
42
-	}
43
-}
44
-
45 22
 func main() {
46 23
 	conf := flag.String("conf", "ergonomadic.json", "ergonomadic config file")
47 24
 	initdb := flag.Bool("initdb", false, "initialize database")
@@ -59,7 +36,7 @@ func main() {
59 36
 	}
60 37
 
61 38
 	if *initdb {
62
-		initDB(config)
39
+		irc.InitDB(config.Database())
63 40
 		return
64 41
 	}
65 42
 

+ 32
- 0
irc/database.go Прегледај датотеку

@@ -0,0 +1,32 @@
1
+package irc
2
+
3
+import (
4
+	"database/sql"
5
+	_ "github.com/mattn/go-sqlite3"
6
+	"log"
7
+	"os"
8
+)
9
+
10
+func InitDB(path string) {
11
+	os.Remove(path)
12
+	db := OpenDB(path)
13
+	defer db.Close()
14
+	_, err := db.Exec(`
15
+        CREATE TABLE channel (
16
+          name TEXT NOT NULL UNIQUE,
17
+          flags TEXT NOT NULL,
18
+          key TEXT NOT NULL,
19
+          topic TEXT NOT NULL,
20
+          user_limit INTEGER DEFAULT 0)`)
21
+	if err != nil {
22
+		log.Fatal(err)
23
+	}
24
+}
25
+
26
+func OpenDB(path string) *sql.DB {
27
+	db, err := sql.Open("sqlite3", path)
28
+	if err != nil {
29
+		log.Fatal(err)
30
+	}
31
+	return db
32
+}

+ 1
- 7
irc/server.go Прегледај датотеку

@@ -7,7 +7,6 @@ import (
7 7
 	"database/sql"
8 8
 	"encoding/binary"
9 9
 	"fmt"
10
-	_ "github.com/mattn/go-sqlite3"
11 10
 	"log"
12 11
 	"net"
13 12
 	"os"
@@ -36,17 +35,12 @@ type Server struct {
36 35
 }
37 36
 
38 37
 func NewServer(config *Config) *Server {
39
-	db, err := sql.Open("sqlite3", config.Database())
40
-	if err != nil {
41
-		log.Fatal(err)
42
-	}
43
-
44 38
 	server := &Server{
45 39
 		channels:  make(ChannelNameMap),
46 40
 		clients:   make(ClientNameMap),
47 41
 		commands:  make(chan Command, 16),
48 42
 		ctime:     time.Now(),
49
-		db:        db,
43
+		db:        OpenDB(config.Database()),
50 44
 		idle:      make(chan *Client, 16),
51 45
 		motdFile:  config.MOTD,
52 46
 		name:      config.Name,

Loading…
Откажи
Сачувај