// 11 february 2014 package ui // The sysData type contains all system data. It provides the system-specific underlying implementation. It is guaranteed to have the following by embedding: type cSysData struct { ctype int allocate func(x int, y int, width int, height int, d *sysSizeData) []*allocation spaced bool alternate bool // editable for Combobox, multi-select for listbox, password for lineedit handler AreaHandler // for Areas; TODO rename to areahandler close func() bool // provided by each Window post func(interface{}) // provided by each Window event func() // provided by each control } // this interface is used to make sure all sysDatas are synced var _xSysData interface { sysDataSizingFunctions make(window *sysData) error firstShow() error show() hide() setText(text string) setRect(x int, y int, width int, height int, winheight int) error isChecked() bool text() string append(string) insertBefore(string, int) selectedIndex() int selectedIndices() []int selectedTexts() []string setWindowSize(int, int) error setProgress(int) len() int setAreaSize(int, int) repaintAll() center() setChecked(bool) } = &sysData{} // this line will error if there's an inconsistency const ( c_window = iota c_button c_checkbox c_combobox c_lineedit c_label c_listbox c_progressbar c_area nctypes ) func mksysdata(ctype int) *sysData { s := &sysData{ cSysData: cSysData{ ctype: ctype, }, } return s }