Refactor with ordered maps
This commit is contained in:
@@ -65,13 +65,15 @@ func handleListOfTorrents(requestPath string, w http.ResponseWriter, r *http.Req
|
||||
for _, directory := range c.GetDirectories() {
|
||||
if basePath == directory {
|
||||
htmlDoc := "<ol>"
|
||||
for name, torrent := range t.TorrentMap {
|
||||
if len(torrent.SelectedFiles) == 0 {
|
||||
for el := t.TorrentMap.Front(); el != nil; el = el.Next() {
|
||||
accessKey := el.Key
|
||||
torrent := el.Value
|
||||
if torrent.InProgress {
|
||||
continue
|
||||
}
|
||||
for _, dir := range torrent.Directories {
|
||||
if dir == basePath {
|
||||
htmlDoc += fmt.Sprintf("<li><a href=\"%s/\">%s</a></li>", filepath.Join(requestPath, url.PathEscape(name)), name)
|
||||
htmlDoc += fmt.Sprintf("<li><a href=\"%s/\">%s</a></li>", filepath.Join(requestPath, url.PathEscape(accessKey)), accessKey)
|
||||
break
|
||||
}
|
||||
}
|
||||
@@ -84,12 +86,18 @@ func handleListOfTorrents(requestPath string, w http.ResponseWriter, r *http.Req
|
||||
}
|
||||
|
||||
func handleSingleTorrent(requestPath string, w http.ResponseWriter, r *http.Request, t *torrent.TorrentManager) (*string, error) {
|
||||
torrentName := path.Base(requestPath)
|
||||
accessKey := path.Base(requestPath)
|
||||
torrent, _ := t.TorrentMap.Get(accessKey)
|
||||
if torrent == nil {
|
||||
return nil, fmt.Errorf("cannot find torrent %s", requestPath)
|
||||
}
|
||||
|
||||
htmlDoc := "<ol>"
|
||||
for _, file := range t.TorrentMap[torrentName].SelectedFiles {
|
||||
for el := torrent.SelectedFiles.Front(); el != nil; el = el.Next() {
|
||||
file := el.Value
|
||||
if file.Link == "" {
|
||||
// TODO: fix the file?
|
||||
fmt.Printf("File %s has no link, skipping\n", file.Path)
|
||||
// will be caught by torrent manager's repairAll
|
||||
// just skip it for now
|
||||
continue
|
||||
}
|
||||
filename := filepath.Base(file.Path)
|
||||
|
||||
Reference in New Issue
Block a user