go-sqlcipher/backup.go

51 lines
950 B
Go
Raw Normal View History

2014-01-30 14:45:09 +04:00
package sqlite3
/*
#include <sqlite3.h>
#include <stdlib.h>
*/
import "C"
import (
"unsafe"
)
type Backup struct {
b *C.sqlite3_backup
}
func (c *SQLiteConn) Backup(dest string, conn *SQLiteConn, src string) (*Backup, error) {
destptr := C.CString(dest)
defer C.free(unsafe.Pointer(destptr))
srcptr := C.CString(src)
defer C.free(unsafe.Pointer(srcptr))
if b := C.sqlite3_backup_init(c.db, destptr, conn.db, srcptr); b != nil {
return &Backup{b: b}, nil
}
return nil, c.lastError()
}
func (b *Backup) Step(p int) error {
2014-05-27 05:35:20 +04:00
ret := C.sqlite3_backup_step(b.b, C.int(p))
if ret != 0 {
return Error{Code: ErrNo(ret)}
}
return nil
2014-01-30 14:45:09 +04:00
}
func (b *Backup) Remaining() int {
return int(C.sqlite3_backup_remaining(b.b))
}
func (b *Backup) PageCount() int {
return int(C.sqlite3_backup_pagecount(b.b))
}
func (b *Backup) Finish() error {
2014-05-27 05:35:20 +04:00
ret := C.sqlite3_backup_finish(b.b)
if ret != 0 {
return Error{Code: ErrNo(ret)}
}
return nil
2014-01-30 14:45:09 +04:00
}