start a 'view patch' window
This commit is contained in:
parent
b047d70679
commit
f2281a2102
21
send.go
21
send.go
|
@ -96,7 +96,28 @@ func doRegister(newurl string) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// gets the patch
|
||||||
|
// todo: move to forgepb
|
||||||
func getPatch(pbfile string) (*forgepb.Patchset, error) {
|
func getPatch(pbfile string) (*forgepb.Patchset, error) {
|
||||||
|
url := me.urlbase + "/patchsetget?filename=" + pbfile
|
||||||
|
log.Info("getPatch() url", url)
|
||||||
|
body, err := me.forge.HttpPost(url, nil)
|
||||||
|
if err != nil {
|
||||||
|
log.Info("httpPost() failed:", err)
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
log.Info("getPatch() len(body)", len(body))
|
||||||
|
var pset *forgepb.Patchset
|
||||||
|
pset = new(forgepb.Patchset)
|
||||||
|
err = pset.Unmarshal(body)
|
||||||
|
if err != nil {
|
||||||
|
log.Info("Unmarshal failed", err)
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return pset, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func savePatch(pbfile string) (*forgepb.Patchset, error) {
|
||||||
url := me.urlbase + "/patchsetget?filename=" + pbfile
|
url := me.urlbase + "/patchsetget?filename=" + pbfile
|
||||||
log.Info("getPatch() url", url)
|
log.Info("getPatch() url", url)
|
||||||
body, err := me.forge.HttpPost(url, nil)
|
body, err := me.forge.HttpPost(url, nil)
|
||||||
|
|
|
@ -13,14 +13,15 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type patchesWindow struct {
|
type patchesWindow struct {
|
||||||
once sync.Once // only init() the window once
|
once sync.Once // only init() the window once
|
||||||
win *gadgets.BasicWindow // the patches window
|
win *gadgets.BasicWindow // the patches window
|
||||||
stack *gui.Node // the top box set as vertical
|
stack *gui.Node // the top box set as vertical
|
||||||
// shelf *gui.Node // the first box in the stack, set as horizontal
|
shelf *gui.Node // the first box in the stack, set as horizontal
|
||||||
grid *gui.Node // the list of available patches
|
grid *gui.Node // the list of available patches
|
||||||
summary *patchSummary // summary of current patches
|
summary *patchSummary // summary of current patches
|
||||||
setgrid *gui.Node // the list of each patchset
|
setgrid *gui.Node // the list of each patchset
|
||||||
setlist map[string]*forgepb.Patchset // a map of the patch names to the protobuf
|
setlist map[string]*forgepb.Patchset // a map of the patch names to the protobuf
|
||||||
|
setwin map[string]*patchWindow // a map of the patch names to the protobuf
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *patchesWindow) Hidden() bool {
|
func (r *patchesWindow) Hidden() bool {
|
||||||
|
@ -84,6 +85,7 @@ func (r *patchesWindow) initWindow() {
|
||||||
// add the grid
|
// add the grid
|
||||||
r.setgrid = g.NewGrid("", 0, 0)
|
r.setgrid = g.NewGrid("", 0, 0)
|
||||||
r.setlist = make(map[string]*forgepb.Patchset)
|
r.setlist = make(map[string]*forgepb.Patchset)
|
||||||
|
r.setwin = make(map[string]*patchWindow)
|
||||||
|
|
||||||
// query for current patchsets
|
// query for current patchsets
|
||||||
lines, err := listPatches()
|
lines, err := listPatches()
|
||||||
|
@ -108,12 +110,30 @@ func (r *patchesWindow) addPatchset(line string) {
|
||||||
r.setgrid.NewLabel(subject)
|
r.setgrid.NewLabel(subject)
|
||||||
r.setgrid.NewLabel(author)
|
r.setgrid.NewLabel(author)
|
||||||
r.setgrid.NewButton("Download", func() {
|
r.setgrid.NewButton("Download", func() {
|
||||||
|
pset, err := savePatch(name)
|
||||||
|
if err != nil {
|
||||||
|
log.Info(name, "failed to download", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
r.setlist[name] = pset
|
||||||
|
})
|
||||||
|
r.setgrid.NewButton("View", func() {
|
||||||
|
// has the window already been created?
|
||||||
|
win := r.setwin[name]
|
||||||
|
if win != nil {
|
||||||
|
win.Toggle()
|
||||||
|
log.Info("TRYING TO TOGGLE WINDOW")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// get the patch and make the window
|
||||||
pset, err := getPatch(name)
|
pset, err := getPatch(name)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Info(name, "failed to download", err)
|
log.Info(name, "failed to download", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
r.setlist[name] = pset
|
r.setlist[name] = pset
|
||||||
|
r.setwin[name] = makePatchWindow(pset)
|
||||||
})
|
})
|
||||||
r.setgrid.NewButton("Dump", func() {
|
r.setgrid.NewButton("Dump", func() {
|
||||||
pset := r.setlist[name]
|
pset := r.setlist[name]
|
||||||
|
|
|
@ -85,26 +85,6 @@ func (r *patchesWindow) submitPatchesBox(box *gui.Node) *patchSummary {
|
||||||
me.patchWin.addPatchset(line)
|
me.patchWin.addPatchset(line)
|
||||||
})
|
})
|
||||||
|
|
||||||
/*
|
|
||||||
s.grid.NewButton("Apply Latest Patchset", func() {
|
|
||||||
lastp := lastPatch()
|
|
||||||
pset, err := getPatch(lastp)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if _, _, _, err := IsEverythingOnDevel(); err != nil {
|
|
||||||
log.Info("You can only apply patches to the devel branch")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if IsAnythingDirty() {
|
|
||||||
log.Info("You can't apply patches when repos are dirty")
|
|
||||||
me.forge.PrintHumanTable(me.found)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
applyPatchset(pset)
|
|
||||||
})
|
|
||||||
*/
|
|
||||||
|
|
||||||
// disable these until there are not dirty repos
|
// disable these until there are not dirty repos
|
||||||
// s.reason.Disable()
|
// s.reason.Disable()
|
||||||
s.submitB.Disable()
|
s.submitB.Disable()
|
|
@ -0,0 +1,114 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
"sync"
|
||||||
|
|
||||||
|
"go.wit.com/lib/gadgets"
|
||||||
|
"go.wit.com/lib/protobuf/forgepb"
|
||||||
|
|
||||||
|
"go.wit.com/gui"
|
||||||
|
)
|
||||||
|
|
||||||
|
type patchWindow struct {
|
||||||
|
once sync.Once // only init() the window once
|
||||||
|
win *gadgets.BasicWindow // the patches window
|
||||||
|
stack *gui.Node // the top box set as vertical
|
||||||
|
shelf *gui.Node // the first box in the stack, set as horizontal
|
||||||
|
grid *gui.Node // the list of available patches
|
||||||
|
summary *patchSummary // summary of current patches
|
||||||
|
setgrid *gui.Node // the list of each patchset
|
||||||
|
pset *forgepb.Patchset // the patchset in question
|
||||||
|
}
|
||||||
|
|
||||||
|
// todo: autogenerate these or make them standared 'gui' package functions
|
||||||
|
// make this an go interface somehow
|
||||||
|
|
||||||
|
// is the window hidden right now?
|
||||||
|
func (w *patchWindow) Hidden() bool {
|
||||||
|
return w.win.Hidden()
|
||||||
|
}
|
||||||
|
|
||||||
|
// switches between the window being visable or hidden on the desktop
|
||||||
|
func (w *patchWindow) Toggle() {
|
||||||
|
if w.Hidden() {
|
||||||
|
w.Show()
|
||||||
|
} else {
|
||||||
|
w.Hide()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// hides the window completely
|
||||||
|
func (w *patchWindow) Show() {
|
||||||
|
w.win.Show()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w *patchWindow) Hide() {
|
||||||
|
w.win.Hide()
|
||||||
|
}
|
||||||
|
|
||||||
|
// should be the first box/widget in the window
|
||||||
|
// greys out the window to the user
|
||||||
|
func (w *patchWindow) Disable() {
|
||||||
|
w.stack.Disable()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w *patchWindow) Enable() {
|
||||||
|
w.stack.Enable()
|
||||||
|
}
|
||||||
|
|
||||||
|
// you can only have one of these
|
||||||
|
func makePatchWindow(pset *forgepb.Patchset) *patchWindow {
|
||||||
|
pw := new(patchWindow)
|
||||||
|
|
||||||
|
// sync.Once()
|
||||||
|
pw.win = gadgets.RawBasicWindow("Patcheset for")
|
||||||
|
pw.win.Make()
|
||||||
|
|
||||||
|
pw.stack = pw.win.Box().NewBox("bw vbox", false)
|
||||||
|
// me.reposwin.Draw()
|
||||||
|
pw.win.Custom = func() {
|
||||||
|
// sets the hidden flag to false so Toggle() works
|
||||||
|
pw.win.Hide()
|
||||||
|
}
|
||||||
|
|
||||||
|
grid := pw.stack.NewGrid("", 0, 0)
|
||||||
|
|
||||||
|
grid.NewLabel(pset.GitAuthorName)
|
||||||
|
|
||||||
|
/*
|
||||||
|
r.shelf = r.initGroup()
|
||||||
|
group1 := r.stack.NewGroup("stuff")
|
||||||
|
vbox := group1.Box()
|
||||||
|
vbox.Vertical()
|
||||||
|
*/
|
||||||
|
|
||||||
|
g := pw.stack.NewGroup("PatchSet List")
|
||||||
|
|
||||||
|
// add the patch grid
|
||||||
|
g.NewGrid("", 0, 0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
for i, line := range lines {
|
||||||
|
log.Info(i, line)
|
||||||
|
r.addFile(line)
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
return pw
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *patchWindow) addPatchset(line string) {
|
||||||
|
parts := strings.Split(line, "Author:")
|
||||||
|
author := parts[1]
|
||||||
|
parts = strings.Fields(parts[0])
|
||||||
|
name := parts[0]
|
||||||
|
subject := strings.Join(parts[1:], " ")
|
||||||
|
r.setgrid.NewLabel(name)
|
||||||
|
r.setgrid.NewLabel(subject)
|
||||||
|
r.setgrid.NewLabel(author)
|
||||||
|
r.setgrid.NewButton("Download", func() {
|
||||||
|
})
|
||||||
|
r.setgrid.NewButton("Apply", func() {
|
||||||
|
})
|
||||||
|
r.setgrid.NextRow()
|
||||||
|
}
|
Loading…
Reference in New Issue