cl.downloadStrategy.TorrentStarted(t)
// TODO(anacrolix): I think this should be made available as a method, the
// channel only acts as a signal that the metadata has become available.
- select {
- case t.gotMetainfo <- &metainfo.MetaInfo{
- Info: metainfo.InfoEx{
- Info: md,
- },
- CreationDate: time.Now().Unix(),
- Comment: "metadata set in client",
- CreatedBy: "go.torrent",
- // TODO(anacrolix): Expose trackers given when torrent added.
- }:
- default:
- panic("shouldn't block")
+ // select {
+ // case t.gotMetainfo <- &metainfo.MetaInfo{
+ // Info: metainfo.InfoEx{
+ // Info: md,
+ // },
+ // CreationDate: time.Now().Unix(),
+ // Comment: "metadata set in client",
+ // CreatedBy: "go.torrent",
+ // // TODO(anacrolix): Expose trackers given when torrent added.
+ // }:
+ // default:
+ // panic("shouldn't block")
+ // }
+ if err := cl.saveTorrentFile(t); err != nil {
+ log.Printf("error saving torrent file for %s: %s", t, err)
}
close(t.gotMetainfo)
- t.gotMetainfo = nil
+ // t.gotMetainfo = nil
return
}
closing: make(chan struct{}),
ceasingNetworking: make(chan struct{}),
- gotMetainfo: make(chan *metainfo.MetaInfo, 1),
+ gotMetainfo: make(chan struct{}),
HalfOpen: make(map[string]struct{}, halfOpenLimit),
}
wg.Add(1)
go func() {
defer wg.Done()
- mi, ok := <-t.GotMetainfo
+ <-t.GotMetainfo
+ mi := t.MetaInfo()
t.Close()
- if !ok {
- log.Printf("no metainfo for %q", t.Name())
- return
- }
f, err := os.Create(mi.Info.Name + ".torrent")
if err != nil {
log.Fatalf("error creating torrent metainfo file: %s", err)
MetaData []byte
metadataHave []bool
- gotMetainfo chan *metainfo.MetaInfo
- GotMetainfo <-chan *metainfo.MetaInfo
+ gotMetainfo chan struct{}
+ GotMetainfo <-chan struct{}
}
func (t *torrent) addrActive(addr string) bool {
return t.Info != nil
}
+// TODO: Include URIs that weren't converted to tracker clients.
+func (t *torrent) AnnounceList() (al [][]string) {
+ for _, tier := range t.Trackers {
+ var l []string
+ for _, tr := range tier {
+ l = append(l, tr.URL())
+ }
+ al = append(al, l)
+ }
+ return
+}
+
+func (t *torrent) MetaInfo() *metainfo.MetaInfo {
+ return &metainfo.MetaInfo{
+ Info: metainfo.InfoEx{
+ Info: *t.Info.Info,
+ },
+ CreationDate: time.Now().Unix(),
+ Comment: "dynamic metainfo from client",
+ CreatedBy: "go.torrent",
+ AnnounceList: t.AnnounceList(),
+ }
+}
+
func (t *torrent) BytesLeft() (left int64) {
if !t.haveInfo() {
return -1