syncthing/files/set.go

124 lines
3.1 KiB
Go
Raw Normal View History

2014-07-13 00:45:33 +02:00
// Copyright (C) 2014 Jakob Borg and Contributors (see the CONTRIBUTORS file).
// All rights reserved. Use of this source code is governed by an MIT-style
// license that can be found in the LICENSE file.
2014-06-01 22:50:14 +02:00
// Package files provides a set type to track local/remote files with newness checks.
package files
import (
"sync"
2014-07-17 11:13:23 +02:00
"github.com/calmh/syncthing/lamport"
"github.com/calmh/syncthing/protocol"
2014-07-06 14:46:48 +02:00
"github.com/syndtr/goleveldb/leveldb"
)
type fileRecord struct {
2014-07-12 23:06:48 +02:00
File protocol.FileInfo
Usage int
Global bool
}
type bitset uint64
type Set struct {
localVersion map[protocol.NodeID]uint64
mutex sync.Mutex
repo string
db *leveldb.DB
}
2014-07-06 14:46:48 +02:00
func NewSet(repo string, db *leveldb.DB) *Set {
var s = Set{
localVersion: make(map[protocol.NodeID]uint64),
repo: repo,
db: db,
}
2014-07-17 11:00:54 +02:00
var nodeID protocol.NodeID
ldbWithAllRepo(db, []byte(repo), func(node []byte, f protocol.FileInfo) bool {
copy(nodeID[:], node)
if f.LocalVersion > s.localVersion[nodeID] {
s.localVersion[nodeID] = f.LocalVersion
}
2014-07-17 11:13:23 +02:00
lamport.Default.Tick(f.Version)
return true
})
2014-07-17 11:00:54 +02:00
if debug {
l.Debugf("loaded localVersion for %q: %#v", repo, s.localVersion)
}
clock(s.localVersion[protocol.LocalNodeID])
2014-07-06 14:46:48 +02:00
return &s
}
2014-07-12 23:06:48 +02:00
func (s *Set) Replace(node protocol.NodeID, fs []protocol.FileInfo) {
if debug {
2014-07-06 14:46:48 +02:00
l.Debugf("%s Replace(%v, [%d])", s.repo, node, len(fs))
}
2014-07-06 14:46:48 +02:00
s.mutex.Lock()
defer s.mutex.Unlock()
s.localVersion[node] = ldbReplace(s.db, []byte(s.repo), node[:], fs)
}
2014-07-12 23:06:48 +02:00
func (s *Set) ReplaceWithDelete(node protocol.NodeID, fs []protocol.FileInfo) {
if debug {
2014-07-06 14:46:48 +02:00
l.Debugf("%s ReplaceWithDelete(%v, [%d])", s.repo, node, len(fs))
}
2014-07-06 14:46:48 +02:00
s.mutex.Lock()
defer s.mutex.Unlock()
if lv := ldbReplaceWithDelete(s.db, []byte(s.repo), node[:], fs); lv > s.localVersion[node] {
s.localVersion[node] = lv
}
}
2014-07-12 23:06:48 +02:00
func (s *Set) Update(node protocol.NodeID, fs []protocol.FileInfo) {
if debug {
2014-07-06 14:46:48 +02:00
l.Debugf("%s Update(%v, [%d])", s.repo, node, len(fs))
}
2014-07-06 14:46:48 +02:00
s.mutex.Lock()
defer s.mutex.Unlock()
if lv := ldbUpdate(s.db, []byte(s.repo), node[:], fs); lv > s.localVersion[node] {
s.localVersion[node] = lv
}
}
2014-07-06 14:46:48 +02:00
func (s *Set) WithNeed(node protocol.NodeID, fn fileIterator) {
if debug {
l.Debugf("%s WithNeed(%v)", s.repo, node)
}
2014-07-06 14:46:48 +02:00
ldbWithNeed(s.db, []byte(s.repo), node[:], fn)
}
2014-07-06 14:46:48 +02:00
func (s *Set) WithHave(node protocol.NodeID, fn fileIterator) {
if debug {
2014-07-06 14:46:48 +02:00
l.Debugf("%s WithHave(%v)", s.repo, node)
}
2014-07-06 14:46:48 +02:00
ldbWithHave(s.db, []byte(s.repo), node[:], fn)
}
2014-07-06 14:46:48 +02:00
func (s *Set) WithGlobal(fn fileIterator) {
if debug {
2014-07-06 14:46:48 +02:00
l.Debugf("%s WithGlobal()", s.repo)
}
2014-07-06 14:46:48 +02:00
ldbWithGlobal(s.db, []byte(s.repo), fn)
}
2014-07-12 23:06:48 +02:00
func (s *Set) Get(node protocol.NodeID, file string) protocol.FileInfo {
2014-07-06 14:46:48 +02:00
return ldbGet(s.db, []byte(s.repo), node[:], []byte(file))
}
2014-07-12 23:06:48 +02:00
func (s *Set) GetGlobal(file string) protocol.FileInfo {
2014-07-06 14:46:48 +02:00
return ldbGetGlobal(s.db, []byte(s.repo), []byte(file))
}
2014-07-06 14:46:48 +02:00
func (s *Set) Availability(file string) []protocol.NodeID {
return ldbAvailability(s.db, []byte(s.repo), []byte(file))
}
func (s *Set) LocalVersion(node protocol.NodeID) uint64 {
2014-07-06 19:21:58 +02:00
s.mutex.Lock()
defer s.mutex.Unlock()
return s.localVersion[node]
}