9 _ "github.com/mattn/go-sqlite3"
11 "github.com/anacrolix/torrent/metainfo"
14 type sqlitePieceCompletion struct {
18 var _ PieceCompletion = (*sqlitePieceCompletion)(nil)
20 func NewSqlitePieceCompletion(dir string) (ret *sqlitePieceCompletion, err error) {
21 p := filepath.Join(dir, ".torrent.db")
22 db, err := sql.Open("sqlite3", p)
27 db.Exec(`PRAGMA journal_mode=WAL`)
28 db.Exec(`PRAGMA synchronous=1`)
29 _, err = db.Exec(`create table if not exists piece_completion(infohash, "index", complete, unique(infohash, "index"))`)
34 ret = &sqlitePieceCompletion{db}
38 func (me *sqlitePieceCompletion) Get(pk metainfo.PieceKey) (c Completion, err error) {
39 row := me.db.QueryRow(`select complete from piece_completion where infohash=? and "index"=?`, pk.InfoHash.HexString(), pk.Index)
40 err = row.Scan(&c.Complete)
41 if err == sql.ErrNoRows {
43 } else if err == nil {
49 func (me *sqlitePieceCompletion) Set(pk metainfo.PieceKey, b bool) error {
50 _, err := me.db.Exec(`insert or replace into piece_completion(infohash, "index", complete) values(?, ?, ?)`, pk.InfoHash.HexString(), pk.Index, b)
54 func (me *sqlitePieceCompletion) Close() error {