Removed the initText parameter from sysData.make() and changed all invocations to call sysData.setText() separately; this avoids the need to check if sysData.setText() is valid. Also implemented that on GTK+.
This commit is contained in:
parent
81153617dc
commit
2647d28f2b
2
area.go
2
area.go
|
@ -288,7 +288,7 @@ func (a *Area) make(window *sysData) error {
|
||||||
defer a.lock.Unlock()
|
defer a.lock.Unlock()
|
||||||
|
|
||||||
a.sysData.handler = a.handler
|
a.sysData.handler = a.handler
|
||||||
err := a.sysData.make("", window)
|
err := a.sysData.make(window)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,10 +55,11 @@ func (b *Button) make(window *sysData) error {
|
||||||
defer b.lock.Unlock()
|
defer b.lock.Unlock()
|
||||||
|
|
||||||
b.sysData.event = b.Clicked
|
b.sysData.event = b.Clicked
|
||||||
err := b.sysData.make(b.initText, window)
|
err := b.sysData.make(window)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
b.sysData.setText(b.initText)
|
||||||
b.created = true
|
b.created = true
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -63,10 +63,11 @@ func (c *Checkbox) make(window *sysData) error {
|
||||||
c.lock.Lock()
|
c.lock.Lock()
|
||||||
defer c.lock.Unlock()
|
defer c.lock.Unlock()
|
||||||
|
|
||||||
err := c.sysData.make(c.initText, window)
|
err := c.sysData.make(window)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
c.sysData.setText(c.initText)
|
||||||
c.created = true
|
c.created = true
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -138,7 +138,7 @@ func (c *Combobox) make(window *sysData) (err error) {
|
||||||
c.lock.Lock()
|
c.lock.Lock()
|
||||||
defer c.lock.Unlock()
|
defer c.lock.Unlock()
|
||||||
|
|
||||||
err = c.sysData.make("", window)
|
err = c.sysData.make(window)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
3
label.go
3
label.go
|
@ -49,10 +49,11 @@ func (l *Label) make(window *sysData) error {
|
||||||
l.lock.Lock()
|
l.lock.Lock()
|
||||||
defer l.lock.Unlock()
|
defer l.lock.Unlock()
|
||||||
|
|
||||||
err := l.sysData.make(l.initText, window)
|
err := l.sysData.make(window)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
l.sysData.setText(l.initText)
|
||||||
l.created = true
|
l.created = true
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,10 +61,11 @@ func (l *LineEdit) make(window *sysData) error {
|
||||||
defer l.lock.Unlock()
|
defer l.lock.Unlock()
|
||||||
|
|
||||||
l.sysData.alternate = l.password
|
l.sysData.alternate = l.password
|
||||||
err := l.sysData.make(l.initText, window)
|
err := l.sysData.make(window)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
l.sysData.setText(l.initText)
|
||||||
l.created = true
|
l.created = true
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -139,7 +139,7 @@ func (l *Listbox) make(window *sysData) (err error) {
|
||||||
l.lock.Lock()
|
l.lock.Lock()
|
||||||
defer l.lock.Unlock()
|
defer l.lock.Unlock()
|
||||||
|
|
||||||
err = l.sysData.make("", window)
|
err = l.sysData.make(window)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,7 +47,7 @@ func (p *ProgressBar) make(window *sysData) error {
|
||||||
p.lock.Lock()
|
p.lock.Lock()
|
||||||
defer p.lock.Unlock()
|
defer p.lock.Unlock()
|
||||||
|
|
||||||
err := p.sysData.make("", window)
|
err := p.sysData.make(window)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@ type cSysData struct {
|
||||||
|
|
||||||
// this interface is used to make sure all sysDatas are synced
|
// this interface is used to make sure all sysDatas are synced
|
||||||
var _xSysData interface {
|
var _xSysData interface {
|
||||||
make(initText string, window *sysData) error
|
make(window *sysData) error
|
||||||
firstShow() error
|
firstShow() error
|
||||||
show()
|
show()
|
||||||
hide()
|
hide()
|
||||||
|
|
|
@ -64,7 +64,6 @@ var classTypes = [nctypes]*classData{
|
||||||
c_combobox: &classData{
|
c_combobox: &classData{
|
||||||
make: gtk_combo_box_text_new,
|
make: gtk_combo_box_text_new,
|
||||||
makeAlt: gtk_combo_box_text_new_with_entry,
|
makeAlt: gtk_combo_box_text_new_with_entry,
|
||||||
// TODO setText
|
|
||||||
text: gtk_combo_box_text_get_active_text,
|
text: gtk_combo_box_text_get_active_text,
|
||||||
append: gtk_combo_box_text_append_text,
|
append: gtk_combo_box_text_append_text,
|
||||||
insert: gtk_combo_box_text_insert_text,
|
insert: gtk_combo_box_text_insert_text,
|
||||||
|
@ -86,7 +85,6 @@ var classTypes = [nctypes]*classData{
|
||||||
c_listbox: &classData{
|
c_listbox: &classData{
|
||||||
make: gListboxNewSingle,
|
make: gListboxNewSingle,
|
||||||
makeAlt: gListboxNewMulti,
|
makeAlt: gListboxNewMulti,
|
||||||
// TODO setText
|
|
||||||
text: gListboxText,
|
text: gListboxText,
|
||||||
append: gListboxAppend,
|
append: gListboxAppend,
|
||||||
insert: gListboxInsert,
|
insert: gListboxInsert,
|
||||||
|
@ -112,7 +110,7 @@ var classTypes = [nctypes]*classData{
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *sysData) make(initText string, window *sysData) error {
|
func (s *sysData) make(window *sysData) error {
|
||||||
ct := classTypes[s.ctype]
|
ct := classTypes[s.ctype]
|
||||||
ret := make(chan *C.GtkWidget)
|
ret := make(chan *C.GtkWidget)
|
||||||
defer close(ret)
|
defer close(ret)
|
||||||
|
@ -152,7 +150,6 @@ func (s *sysData) make(initText string, window *sysData) error {
|
||||||
}
|
}
|
||||||
<-ret
|
<-ret
|
||||||
}
|
}
|
||||||
s.setText(initText)
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -183,9 +180,6 @@ func (s *sysData) hide() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *sysData) setText(text string) {
|
func (s *sysData) setText(text string) {
|
||||||
if classTypes[s.ctype].setText == nil { // does not have concept of text
|
|
||||||
return
|
|
||||||
}
|
|
||||||
ret := make(chan struct{})
|
ret := make(chan struct{})
|
||||||
defer close(ret)
|
defer close(ret)
|
||||||
uitask <- func() {
|
uitask <- func() {
|
||||||
|
|
|
@ -72,7 +72,7 @@ func (w *Window) Open(control Control) (err error) {
|
||||||
panic("window already open")
|
panic("window already open")
|
||||||
}
|
}
|
||||||
w.sysData.event = w.Closing
|
w.sysData.event = w.Closing
|
||||||
err = w.sysData.make(w.initTitle, nil)
|
err = w.sysData.make(nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("error opening window: %v", err)
|
return fmt.Errorf("error opening window: %v", err)
|
||||||
}
|
}
|
||||||
|
@ -87,6 +87,7 @@ func (w *Window) Open(control Control) (err error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("error setting window size (in Window.Open()): %v", err)
|
return fmt.Errorf("error setting window size (in Window.Open()): %v", err)
|
||||||
}
|
}
|
||||||
|
w.sysData.setText(w.initTitle)
|
||||||
// TODO separate showing?
|
// TODO separate showing?
|
||||||
err = w.sysData.firstShow()
|
err = w.sysData.firstShow()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
Loading…
Reference in New Issue