mirror of
https://github.com/Xpl0itU/WiiUDownloader.git
synced 2025-05-29 22:45:17 -04:00
Add cancel button
This commit is contained in:
parent
8213612319
commit
b6b4843d0c
2 changed files with 66 additions and 8 deletions
|
@ -42,7 +42,7 @@ func NewMainWindow(entries []wiiudownloader.TitleEntry) *MainWindow {
|
||||||
}
|
}
|
||||||
|
|
||||||
win.SetTitle("WiiUDownloaderGo")
|
win.SetTitle("WiiUDownloaderGo")
|
||||||
win.SetDefaultSize(400, 300)
|
win.SetDefaultSize(716, 400)
|
||||||
win.Connect("destroy", func() {
|
win.Connect("destroy", func() {
|
||||||
gtk.MainQuit()
|
gtk.MainQuit()
|
||||||
})
|
})
|
||||||
|
@ -359,7 +359,32 @@ func (mw *MainWindow) onAddToQueueClicked() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (mw *MainWindow) updateTitlesInQueue() {
|
||||||
|
store, err := mw.treeView.GetModel()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal("Unable to get tree view model:", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
storeRef := store.(*gtk.ListStore)
|
||||||
|
|
||||||
|
iter, _ := storeRef.GetIterFirst()
|
||||||
|
for iter != nil {
|
||||||
|
tid, _ := storeRef.GetValue(iter, TITLE_ID_COLUMN)
|
||||||
|
if tid != nil {
|
||||||
|
if tidStr, err := tid.GetString(); err == nil {
|
||||||
|
tidNum, _ := strconv.ParseUint(tidStr, 16, 64)
|
||||||
|
isInQueue := mw.isTitleInQueue(wiiudownloader.TitleEntry{TitleID: tidNum})
|
||||||
|
storeRef.SetValue(iter, IN_QUEUE_COLUMN, isInQueue)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if !storeRef.IterNext(iter) {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (mw *MainWindow) onDownloadQueueClicked() {
|
func (mw *MainWindow) onDownloadQueueClicked() {
|
||||||
|
queueCancelled := false
|
||||||
var wg sync.WaitGroup
|
var wg sync.WaitGroup
|
||||||
|
|
||||||
selectedPath, err := dialog.Directory().Title("Select a path to save the games to").Browse()
|
selectedPath, err := dialog.Directory().Title("Select a path to save the games to").Browse()
|
||||||
|
@ -374,14 +399,21 @@ func (mw *MainWindow) onDownloadQueueClicked() {
|
||||||
defer wg.Done()
|
defer wg.Done()
|
||||||
|
|
||||||
tidStr := fmt.Sprintf("%016x", title.TitleID)
|
tidStr := fmt.Sprintf("%016x", title.TitleID)
|
||||||
wiiudownloader.DownloadTitle(tidStr, fmt.Sprintf("%s/%s [%s]", selectedPath, title.Name, tidStr), mw.decryptContents, progressWindow)
|
if err := wiiudownloader.DownloadTitle(tidStr, fmt.Sprintf("%s/%s [%s]", selectedPath, title.Name, tidStr), mw.decryptContents, progressWindow); err != nil {
|
||||||
|
queueCancelled = true
|
||||||
|
}
|
||||||
mw.removeFromQueue(tidStr)
|
mw.removeFromQueue(tidStr)
|
||||||
}(title, selectedPath, &mw.progressWindow)
|
}(title, selectedPath, &mw.progressWindow)
|
||||||
|
|
||||||
|
if queueCancelled {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
}
|
}
|
||||||
|
mw.titleQueue = []wiiudownloader.TitleEntry{} // Clear the queue
|
||||||
mw.progressWindow.Window.Close()
|
mw.progressWindow.Window.Close()
|
||||||
mw.onAddToQueueClicked()
|
mw.updateTitlesInQueue()
|
||||||
}
|
}
|
||||||
|
|
||||||
func Main() {
|
func Main() {
|
||||||
|
|
|
@ -21,6 +21,8 @@ type ProgressWindow struct {
|
||||||
label *gtk.Label
|
label *gtk.Label
|
||||||
bar *gtk.ProgressBar
|
bar *gtk.ProgressBar
|
||||||
percentLabel *gtk.Label
|
percentLabel *gtk.Label
|
||||||
|
cancelButton *gtk.Button
|
||||||
|
cancelled bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func CreateProgressWindow(parent *gtk.Window) (ProgressWindow, error) {
|
func CreateProgressWindow(parent *gtk.Window) (ProgressWindow, error) {
|
||||||
|
@ -56,16 +58,33 @@ func CreateProgressWindow(parent *gtk.Window) (ProgressWindow, error) {
|
||||||
}
|
}
|
||||||
box.PackStart(percentLabel, false, false, 0)
|
box.PackStart(percentLabel, false, false, 0)
|
||||||
|
|
||||||
|
cancelButton, err := gtk.ButtonNewWithLabel("Cancel")
|
||||||
|
if err != nil {
|
||||||
|
return ProgressWindow{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
bottomhBox, err := gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, 5)
|
||||||
|
if err != nil {
|
||||||
|
return ProgressWindow{}, err
|
||||||
|
}
|
||||||
|
bottomhBox.PackEnd(cancelButton, false, false, 0)
|
||||||
|
box.PackEnd(bottomhBox, false, false, 0)
|
||||||
|
|
||||||
return ProgressWindow{
|
return ProgressWindow{
|
||||||
Window: win,
|
Window: win,
|
||||||
box: box,
|
box: box,
|
||||||
label: filenameLabel,
|
label: filenameLabel,
|
||||||
bar: progressBar,
|
bar: progressBar,
|
||||||
percentLabel: percentLabel,
|
percentLabel: percentLabel,
|
||||||
|
cancelButton: cancelButton,
|
||||||
|
cancelled: false,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func downloadFile(progressWindow *ProgressWindow, client *grab.Client, url string, outputPath string) error {
|
func downloadFile(progressWindow *ProgressWindow, client *grab.Client, url string, outputPath string) error {
|
||||||
|
if progressWindow.cancelled {
|
||||||
|
return fmt.Errorf("cancelled")
|
||||||
|
}
|
||||||
done := false
|
done := false
|
||||||
req, err := grab.NewRequest(outputPath, url)
|
req, err := grab.NewRequest(outputPath, url)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -82,13 +101,14 @@ func downloadFile(progressWindow *ProgressWindow, client *grab.Client, url strin
|
||||||
progressWindow.bar.SetFraction(resp.Progress())
|
progressWindow.bar.SetFraction(resp.Progress())
|
||||||
progressWindow.percentLabel.SetText(fmt.Sprintf("%.0f%%", 100*resp.Progress()))
|
progressWindow.percentLabel.SetText(fmt.Sprintf("%.0f%%", 100*resp.Progress()))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
if progressWindow.cancelled {
|
||||||
|
resp.Cancel()
|
||||||
|
break
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
*err = resp.Err()
|
*err = resp.Err()
|
||||||
|
|
||||||
glib.IdleAdd(func() {
|
|
||||||
progressWindow.Window.SetTitle("Download Complete")
|
|
||||||
})
|
|
||||||
done = true
|
done = true
|
||||||
}(&err)
|
}(&err)
|
||||||
|
|
||||||
|
@ -106,6 +126,9 @@ func downloadFile(progressWindow *ProgressWindow, client *grab.Client, url strin
|
||||||
}
|
}
|
||||||
|
|
||||||
func DownloadTitle(titleID string, outputDirectory string, doDecryption bool, progressWindow *ProgressWindow) error {
|
func DownloadTitle(titleID string, outputDirectory string, doDecryption bool, progressWindow *ProgressWindow) error {
|
||||||
|
progressWindow.cancelButton.Connect("clicked", func() {
|
||||||
|
progressWindow.cancelled = true
|
||||||
|
})
|
||||||
outputDir := strings.TrimRight(outputDirectory, "/\\")
|
outputDir := strings.TrimRight(outputDirectory, "/\\")
|
||||||
baseURL := fmt.Sprintf("http://ccs.cdn.c.shop.nintendowifi.net/ccs/download/%s", titleID)
|
baseURL := fmt.Sprintf("http://ccs.cdn.c.shop.nintendowifi.net/ccs/download/%s", titleID)
|
||||||
titleKeyBytes, err := hex.DecodeString(titleID)
|
titleKeyBytes, err := hex.DecodeString(titleID)
|
||||||
|
@ -214,9 +237,12 @@ func DownloadTitle(titleID string, outputDirectory string, doDecryption bool, pr
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if progressWindow.cancelled {
|
||||||
|
break
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if doDecryption {
|
if doDecryption && !progressWindow.cancelled {
|
||||||
if err := decryptContents(outputDir, progressWindow); err != nil {
|
if err := decryptContents(outputDir, progressWindow); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue