Unify window and mainWindow
This commit is contained in:
parent
adf0ef3a89
commit
6eff6887e7
34
x/window.go
34
x/window.go
@ -18,7 +18,6 @@ import "github.com/jezek/xgbutil/keybind"
|
|||||||
import "github.com/jezek/xgbutil/mousebind"
|
import "github.com/jezek/xgbutil/mousebind"
|
||||||
import "github.com/jezek/xgbutil/xgraphics"
|
import "github.com/jezek/xgbutil/xgraphics"
|
||||||
|
|
||||||
type mainWindow struct { *window }
|
|
||||||
type window struct {
|
type window struct {
|
||||||
backend *Backend
|
backend *Backend
|
||||||
hierarchy *system.Hierarchy
|
hierarchy *system.Hierarchy
|
||||||
@ -28,6 +27,7 @@ type window struct {
|
|||||||
|
|
||||||
title string
|
title string
|
||||||
|
|
||||||
|
leader *window
|
||||||
modalParent *window
|
modalParent *window
|
||||||
hasModal bool
|
hasModal bool
|
||||||
shy bool
|
shy bool
|
||||||
@ -63,28 +63,24 @@ func (this *windowLink) NotifyMinimumSizeChange () {
|
|||||||
func (this *Backend) NewWindow (
|
func (this *Backend) NewWindow (
|
||||||
bounds image.Rectangle,
|
bounds image.Rectangle,
|
||||||
) (
|
) (
|
||||||
output tomo.MainWindow,
|
output tomo.Window,
|
||||||
err error,
|
err error,
|
||||||
) {
|
) {
|
||||||
this.assert()
|
this.assert()
|
||||||
window, err := this.newWindow(bounds, false)
|
return this.newWindow(bounds, false)
|
||||||
|
|
||||||
output = mainWindow { window: window }
|
|
||||||
return output, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (this *Backend) NewPlainWindow (
|
func (this *Backend) NewPlainWindow (
|
||||||
bounds image.Rectangle,
|
bounds image.Rectangle,
|
||||||
) (
|
) (
|
||||||
output tomo.MainWindow,
|
output tomo.Window,
|
||||||
err error,
|
err error,
|
||||||
) {
|
) {
|
||||||
this.assert()
|
this.assert()
|
||||||
window, err := this.newWindow(bounds, false)
|
window, err := this.newWindow(bounds, false)
|
||||||
window.setType("dock")
|
window.setType("dock")
|
||||||
|
|
||||||
output = mainWindow { window: window }
|
return window, err
|
||||||
return output, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (this *Backend) newWindow (
|
func (this *Backend) newWindow (
|
||||||
@ -100,6 +96,7 @@ func (this *Backend) newWindow (
|
|||||||
window := &window { backend: this }
|
window := &window { backend: this }
|
||||||
link := &windowLink { window: window }
|
link := &windowLink { window: window }
|
||||||
window.hierarchy = this.system.NewHierarchy(link)
|
window.hierarchy = this.system.NewHierarchy(link)
|
||||||
|
window.leader = window
|
||||||
|
|
||||||
window.xWindow, err = xwindow.Generate(this.x)
|
window.xWindow, err = xwindow.Generate(this.x)
|
||||||
if err != nil { return }
|
if err != nil { return }
|
||||||
@ -247,18 +244,23 @@ func (this *window) NewModal (bounds image.Rectangle) (tomo.Window, error) {
|
|||||||
return modal, err
|
return modal, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (this mainWindow) NewChild (bounds image.Rectangle) (tomo.Window, error) {
|
func (this *window) NewChild (bounds image.Rectangle) (tomo.Window, error) {
|
||||||
|
leader := this.leader
|
||||||
|
|
||||||
child, err := this.backend.newWindow (
|
child, err := this.backend.newWindow (
|
||||||
bounds.Add(this.metrics.bounds.Min), false)
|
bounds.Add(this.metrics.bounds.Min), false)
|
||||||
|
child.leader = leader
|
||||||
if err != nil { return nil, err }
|
if err != nil { return nil, err }
|
||||||
child.setClientLeader(this.window)
|
|
||||||
this.setClientLeader(this.window)
|
child.setClientLeader(leader)
|
||||||
|
leader.setClientLeader(leader)
|
||||||
|
|
||||||
icccm.WmTransientForSet (
|
icccm.WmTransientForSet (
|
||||||
this.backend.x,
|
this.backend.x,
|
||||||
this.xWindow.Id,
|
child.xWindow.Id,
|
||||||
this.xWindow.Id)
|
leader.xWindow.Id)
|
||||||
this.setType("UTILITY")
|
child.setType("UTILITY")
|
||||||
// this.inheritProperties(this.window)
|
// child.inheritProperties(leader.window)
|
||||||
return this, err
|
return this, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user