4 "bitbucket.org/anacrolix/go.torrent/mmap_span"
10 // "github.com/davecheney/profile"
15 metainfo "github.com/nsf/libtorgo/torrent"
16 "launchpad.net/gommap"
20 filePath = flag.String("torrent", "/path/to/the.torrent", "path of the torrent file")
21 dirPath = flag.String("path", "/torrent/data", "path of the torrent data")
29 // defer profile.Start(profile.CPUProfile).Stop()
30 metaInfo, err := metainfo.LoadFromFile(*filePath)
34 devZero, err := os.Open("/dev/zero")
39 var mMapSpan mmap_span.MMapSpan
40 for _, file := range metaInfo.Files {
41 filename := filepath.Join(append([]string{*dirPath, metaInfo.Name}, file.Path...)...)
42 osFile, err := os.Open(filename)
45 if pe, ok := err.(*os.PathError); ok && pe.Err.Error() == "no such file or directory" {
51 goMMap, err := gommap.MapRegion(mmapFd, 0, file.Length, gommap.PROT_READ, gommap.MAP_PRIVATE)
55 if int64(len(goMMap)) != file.Length {
56 log.Printf("file mmap has wrong size: %#v", filename)
59 mMapSpan = append(mMapSpan, goMMap)
61 log.Println(len(metaInfo.Files))
62 log.Println(mMapSpan.Size())
63 log.Println(len(metaInfo.Pieces))
64 for piece := 0; piece < (len(metaInfo.Pieces)+sha1.Size-1)/sha1.Size; piece++ {
65 expectedHash := metaInfo.Pieces[sha1.Size*piece : sha1.Size*(piece+1)]
66 if len(expectedHash) == 0 {
70 _, err := mMapSpan.WriteSectionTo(hash, int64(piece)*metaInfo.PieceLength, metaInfo.PieceLength)
74 fmt.Println(piece, bytes.Equal(hash.Sum(nil), expectedHash))