"os"
"path/filepath"
- "launchpad.net/gommap"
+ "github.com/edsrzf/mmap-go"
"github.com/anacrolix/torrent/metainfo"
"github.com/anacrolix/torrent/mmap_span"
dataPath = flag.String("path", "/torrent/data", "path of the torrent data")
)
-func fileToMmap(filename string, length int64, devZero *os.File) gommap.MMap {
+func fileToMmap(filename string, length int64, devZero *os.File) mmap.MMap {
osFile, err := os.Open(filename)
if err != nil {
log.Fatal(err)
}
- mmapFd := osFile.Fd()
- goMMap, err := gommap.MapRegion(mmapFd, 0, length, gommap.PROT_READ, gommap.MAP_PRIVATE)
+ goMMap, err := mmap.MapRegion(osFile, int(length), mmap.RDONLY, mmap.COPY, 0)
if err != nil {
log.Fatal(err)
}
"os"
"path/filepath"
- "launchpad.net/gommap"
+ "github.com/edsrzf/mmap-go"
"github.com/anacrolix/torrent/metainfo"
"github.com/anacrolix/torrent/mmap_span"
// Can't mmap() regions with length 0.
return
}
- var mMap gommap.MMap
- mMap, err = gommap.MapRegion(file.Fd(), 0, miFile.Length, gommap.PROT_READ|gommap.PROT_WRITE, gommap.MAP_SHARED)
+ var mMap mmap.MMap
+ mMap, err = mmap.MapRegion(file,
+ int(miFile.Length), // Probably not great on <64 bit systems.
+ mmap.RDWR, 0, 0)
if err != nil {
err = fmt.Errorf("error mapping file %q, length %d: %s", file.Name(), miFile.Length, err)
return
import (
"io"
- "launchpad.net/gommap"
+ "github.com/edsrzf/mmap-go"
)
type segment struct {
- gommap.MMap
+ *mmap.MMap
}
func (me segment) Size() int64 {
- return int64(len(me.MMap))
+ return int64(len(*me.MMap))
}
type MMapSpan struct {
span
}
-func (me *MMapSpan) Append(mmap gommap.MMap) {
- me.span = append(me.span, segment{mmap})
+func (me *MMapSpan) Append(mmap mmap.MMap) {
+ me.span = append(me.span, segment{&mmap})
}
func (me MMapSpan) Close() {
for _, mMap := range me.span {
- mMap.(segment).UnsafeUnmap()
+ mMap.(segment).Unmap()
}
}
func (me MMapSpan) ReadAt(p []byte, off int64) (n int, err error) {
me.ApplyTo(off, func(intervalOffset int64, interval sizer) (stop bool) {
- _n := copy(p, interval.(segment).MMap[intervalOffset:])
+ _n := copy(p, (*interval.(segment).MMap)[intervalOffset:])
p = p[_n:]
n += _n
return len(p) == 0
func (me MMapSpan) WriteSectionTo(w io.Writer, off, n int64) (written int64, err error) {
me.ApplyTo(off, func(intervalOffset int64, interval sizer) (stop bool) {
var _n int
- p := interval.(segment).MMap[intervalOffset:]
+ p := (*interval.(segment).MMap)[intervalOffset:]
if n < int64(len(p)) {
p = p[:n]
}
func (me MMapSpan) WriteAt(p []byte, off int64) (n int, err error) {
me.ApplyTo(off, func(iOff int64, i sizer) (stop bool) {
mMap := i.(segment)
- _n := copy(mMap.MMap[iOff:], p)
+ _n := copy((*mMap.MMap)[iOff:], p)
// err = mMap.Sync(gommap.MS_ASYNC)
// if err != nil {
// return true