diff options
| author | Pietro Gagliardi <[email protected]> | 2014-03-09 16:02:17 -0400 |
|---|---|---|
| committer | Pietro Gagliardi <[email protected]> | 2014-03-09 16:02:17 -0400 |
| commit | b9f0ad90ec3568cbb1a7a2452d51395377c03a99 (patch) | |
| tree | 8887a96143833845ec479589e903e43c809961ba /combobox.go | |
| parent | a7ec908ebd5e344628717cab874919dfc29cd58c (diff) | |
Steamrolled errors under panic() in Combobox/Listbox.Append()/InsertBefore() because screw Windows being different.
Diffstat (limited to 'combobox.go')
| -rw-r--r-- | combobox.go | 19 |
1 files changed, 9 insertions, 10 deletions
diff --git a/combobox.go b/combobox.go index 42e10ac..54403b1 100644 --- a/combobox.go +++ b/combobox.go @@ -36,25 +36,23 @@ func NewEditableCombobox(items ...string) *Combobox { } // Append adds items to the end of the Combobox's list. -func (c *Combobox) Append(what ...string) (err error) { +// Append will panic if something goes wrong on platforms that do not abort themselves. +func (c *Combobox) Append(what ...string) { c.lock.Lock() defer c.lock.Unlock() if c.created { for i, s := range what { - err := c.sysData.append(s) - if err != nil { - return fmt.Errorf("error adding element %d in Combobox.Append() (%q): %v", i, s, err) - } + c.sysData.append(s) } - return nil + return } c.initItems = append(c.initItems, what...) - return nil } // InsertBefore inserts a new item in the Combobox before the item at the given position. It panics if the given index is out of bounds. -func (c *Combobox) InsertBefore(what string, before int) (err error) { +// InsertBefore will also panic if something goes wrong on platforms that do not abort themselves. +func (c *Combobox) InsertBefore(what string, before int) { c.lock.Lock() defer c.lock.Unlock() @@ -64,7 +62,8 @@ func (c *Combobox) InsertBefore(what string, before int) (err error) { if before < 0 || before >= c.sysData.len() { goto badrange } - return c.sysData.insertBefore(what, before) + c.sysData.insertBefore(what, before) + return } if before < 0 || before >= len(c.initItems) { goto badrange @@ -73,7 +72,7 @@ func (c *Combobox) InsertBefore(what string, before int) (err error) { m = append(m, c.initItems[:before]...) m = append(m, what) c.initItems = append(m, c.initItems[before:]...) - return nil + return badrange: panic(fmt.Errorf("index %d out of range in Combobox.InsertBefore()", before)) } |
