From ffa1bbe0b91a8c812ddcea5c5d65e55f60d07f33 Mon Sep 17 00:00:00 2001 From: Pietro Gagliardi Date: Mon, 30 Jun 2014 22:48:12 -0400 Subject: Restored the previous new API. I'm going to change it so that events are callbacks rather than using a window handler, but other than that... yeah. --- button.go | 24 +++--------------------- 1 file changed, 3 insertions(+), 21 deletions(-) (limited to 'button.go') diff --git a/button.go b/button.go index 96a68ed..c4143aa 100644 --- a/button.go +++ b/button.go @@ -2,18 +2,8 @@ package ui -import ( - "sync" -) - // A Button represents a clickable button with some text. type Button struct { - // Clicked gets a message when the button is clicked. - // You cannot change it once the Window containing the Button has been created. - // If you do not respond to this signal, nothing will happen. - Clicked chan struct{} - - lock sync.Mutex created bool sysData *sysData initText string @@ -24,15 +14,11 @@ func NewButton(text string) (b *Button) { return &Button{ sysData: mksysdata(c_button), initText: text, - Clicked: newEvent(), } } // SetText sets the button's text. func (b *Button) SetText(text string) { - b.lock.Lock() - defer b.lock.Unlock() - if b.created { b.sysData.setText(text) return @@ -42,9 +28,6 @@ func (b *Button) SetText(text string) { // Text returns the button's text. func (b *Button) Text() string { - b.lock.Lock() - defer b.lock.Unlock() - if b.created { return b.sysData.text() } @@ -52,10 +35,9 @@ func (b *Button) Text() string { } func (b *Button) make(window *sysData) error { - b.lock.Lock() - defer b.lock.Unlock() - - b.sysData.event = b.Clicked + b.sysData.event = func() { + window.winhandler.Event(Clicked, b) + } err := b.sysData.make(window) if err != nil { return err -- cgit v1.2.3