mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-10-15 20:06:19 +08:00
compatible with Go1
git-svn-id: https://weed-fs.googlecode.com/svn/trunk@46 282b0af5-e82d-9cf1-ede4-77906d7719d0
This commit is contained in:
@@ -1,19 +1,19 @@
|
||||
package storage
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"log"
|
||||
"json"
|
||||
"os"
|
||||
"strings"
|
||||
"net/url"
|
||||
"strconv"
|
||||
"url"
|
||||
"util"
|
||||
"strings"
|
||||
"pkg/util"
|
||||
)
|
||||
|
||||
type Store struct {
|
||||
volumes map[uint64]*Volume
|
||||
dir string
|
||||
Port int
|
||||
volumes map[uint64]*Volume
|
||||
dir string
|
||||
Port int
|
||||
PublicUrl string
|
||||
}
|
||||
type VolumeInfo struct {
|
||||
@@ -24,44 +24,44 @@ type VolumeInfo struct {
|
||||
func NewStore(port int, publicUrl, dirname string, volumeListString string) (s *Store) {
|
||||
s = &Store{Port: port, PublicUrl: publicUrl, dir: dirname}
|
||||
s.volumes = make(map[uint64]*Volume)
|
||||
|
||||
|
||||
s.AddVolume(volumeListString)
|
||||
|
||||
|
||||
log.Println("Store started on dir:", dirname, "with", len(s.volumes), "volumes")
|
||||
return
|
||||
}
|
||||
func (s *Store) AddVolume(volumeListString string) os.Error{
|
||||
for _, range_string := range strings.Split(volumeListString, ",") {
|
||||
if strings.Index(range_string, "-") < 0 {
|
||||
id_string := range_string
|
||||
id, err := strconv.Atoui64(id_string)
|
||||
if err != nil {
|
||||
return os.NewError("Volume Id " + id_string+ " is not a valid unsigned integer!")
|
||||
}
|
||||
s.addVolume(id)
|
||||
} else {
|
||||
pair := strings.Split(range_string, "-")
|
||||
start, start_err := strconv.Atoui64(pair[0])
|
||||
if start_err != nil {
|
||||
return os.NewError("Volume Start Id" + pair[0] + " is not a valid unsigned integer!")
|
||||
}
|
||||
end, end_err := strconv.Atoui64(pair[1])
|
||||
if end_err != nil {
|
||||
return os.NewError("Volume End Id" + pair[1] + " is not a valid unsigned integer!")
|
||||
}
|
||||
for id := start; id<=end; id++ {
|
||||
s.addVolume(id)
|
||||
}
|
||||
}
|
||||
}
|
||||
return nil
|
||||
func (s *Store) AddVolume(volumeListString string) error {
|
||||
for _, range_string := range strings.Split(volumeListString, ",") {
|
||||
if strings.Index(range_string, "-") < 0 {
|
||||
id_string := range_string
|
||||
id, err := strconv.ParseUint(id_string, 10, 64)
|
||||
if err != nil {
|
||||
return errors.New("Volume Id " + id_string + " is not a valid unsigned integer!")
|
||||
}
|
||||
s.addVolume(id)
|
||||
} else {
|
||||
pair := strings.Split(range_string, "-")
|
||||
start, start_err := strconv.ParseUint(pair[0], 10, 64)
|
||||
if start_err != nil {
|
||||
return errors.New("Volume Start Id" + pair[0] + " is not a valid unsigned integer!")
|
||||
}
|
||||
end, end_err := strconv.ParseUint(pair[1], 10, 64)
|
||||
if end_err != nil {
|
||||
return errors.New("Volume End Id" + pair[1] + " is not a valid unsigned integer!")
|
||||
}
|
||||
for id := start; id <= end; id++ {
|
||||
s.addVolume(id)
|
||||
}
|
||||
}
|
||||
}
|
||||
return nil
|
||||
}
|
||||
func (s *Store) addVolume(vid uint64) os.Error{
|
||||
if s.volumes[vid]!=nil {
|
||||
return os.NewError("Volume Id "+strconv.Uitoa64(vid)+" already exists!")
|
||||
}
|
||||
s.volumes[vid] = NewVolume(s.dir, uint32(vid))
|
||||
return nil
|
||||
func (s *Store) addVolume(vid uint64) error {
|
||||
if s.volumes[vid] != nil {
|
||||
return errors.New("Volume Id " + strconv.FormatUint(vid, 10) + " already exists!")
|
||||
}
|
||||
s.volumes[vid] = NewVolume(s.dir, uint32(vid))
|
||||
return nil
|
||||
}
|
||||
func (s *Store) Status() *[]*VolumeInfo {
|
||||
stats := new([]*VolumeInfo)
|
||||
@@ -92,11 +92,11 @@ func (s *Store) Close() {
|
||||
}
|
||||
}
|
||||
func (s *Store) Write(i uint64, n *Needle) uint32 {
|
||||
return s.volumes[i].write(n)
|
||||
return s.volumes[i].write(n)
|
||||
}
|
||||
func (s *Store) Delete(i uint64, n *Needle) uint32 {
|
||||
return s.volumes[i].delete(n)
|
||||
}
|
||||
func (s *Store) Read(i uint64, n *Needle) (int, os.Error) {
|
||||
func (s *Store) Read(i uint64, n *Needle) (int, error) {
|
||||
return s.volumes[i].read(n)
|
||||
}
|
||||
|
Reference in New Issue
Block a user