summaryrefslogtreecommitdiff
path: root/newctrl/textfield_darwin.go
diff options
context:
space:
mode:
authorPietro Gagliardi <[email protected]>2014-10-18 17:03:38 -0400
committerPietro Gagliardi <[email protected]>2014-10-18 17:03:38 -0400
commitaed423a09f35e26a318bd44a6670d4222906de9a (patch)
tree01ad31d5c137859dfeae5f42094834b405971177 /newctrl/textfield_darwin.go
parent62048303a34f6cac733798651adb53b640e2114a (diff)
Remvoed the newctrl working directory.
Diffstat (limited to 'newctrl/textfield_darwin.go')
-rw-r--r--newctrl/textfield_darwin.go75
1 files changed, 0 insertions, 75 deletions
diff --git a/newctrl/textfield_darwin.go b/newctrl/textfield_darwin.go
deleted file mode 100644
index bf63073..0000000
--- a/newctrl/textfield_darwin.go
+++ /dev/null
@@ -1,75 +0,0 @@
-// 16 july 2014
-
-package ui
-
-import (
- "unsafe"
-)
-
-// #include "objc_darwin.h"
-import "C"
-
-type textfield struct {
- *controlSingleObject
- changed *event
- invalid C.id
- chainpreferredSize func(d *sizing) (int, int)
-}
-
-func finishNewTextField(id C.id) *textfield {
- t := &textfield{
- controlSingleObject: newControlSingleObject(id),
- changed: newEvent(),
- }
- C.textfieldSetDelegate(t.id, unsafe.Pointer(t))
- t.chainpreferredSize = t.fpreferredSize
- t.fpreferredSize = t.xpreferredSize
- return t
-}
-
-func newTextField() *textfield {
- return finishNewTextField(C.newTextField())
-}
-
-func newPasswordField() *textfield {
- return finishNewTextField(C.newPasswordField())
-}
-
-func (t *textfield) Text() string {
- return C.GoString(C.textfieldText(t.id))
-}
-
-func (t *textfield) SetText(text string) {
- ctext := C.CString(text)
- defer C.free(unsafe.Pointer(ctext))
- C.textfieldSetText(t.id, ctext)
-}
-
-func (t *textfield) OnChanged(f func()) {
- t.changed.set(f)
-}
-
-func (t *textfield) Invalid(reason string) {
- if t.invalid != nil {
- C.textfieldCloseInvalidPopover(t.invalid)
- t.invalid = nil
- }
- if reason == "" {
- return
- }
- creason := C.CString(reason)
- defer C.free(unsafe.Pointer(creason))
- t.invalid = C.textfieldOpenInvalidPopover(t.id, creason)
-}
-
-//export textfieldChanged
-func textfieldChanged(data unsafe.Pointer) {
- t := (*textfield)(data)
- t.changed.fire()
-}
-
-func (t *textfield) xpreferredSize(d *sizing) (width, height int) {
- _, height = t.chainpreferredSize(d)
- // the returned width is based on the contents; use this instead
- return C.textfieldWidth, height
-}