summaryrefslogtreecommitdiffstats
path: root/xsetup.py
blob: a9822fb1e165a9583829dca268bdf7ccf7120b6d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#
# xsetup.py - handles anaconda specific XFree86 needs
#
# Michael Fulbright <msf@redhat.com>
#
# Copyright 2002,2003 Red Hat, Inc.
#
# This software may be freely redistributed under the terms of the GNU
# library public license.
#
# You should have received a copy of the GNU Library Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
#

#
# should probably go in rhpl
#
import string
import rhpl
from rhpl.translate import _

class XSetup:
    def __init__(self, xserver):
	self.skipx = 0
	self.imposed_sane_default = 0
	self.xserver = xserver

    def write(self, fn, mouse, keyboard):
        self.xserver.keyboard = keyboard
        self.xserver.mousehw = mouse
        self.xserver.generateConfig()
        self.xserver.writeConfig(filename=fn+"/xorg.conf")

    def writeKS(self, f, desktop=None):
        # FIXME: we really should have at least the startxonboot and
        # defaultdesktop bits on s390
        if rhpl.getArch() == "s390":
            return
        
	if self.skipx:
	    f.write("skipx\n")
	    return

        args = self.getArgList(self.xserver.hwstate.get_resolution(),
			       self.xserver.hwstate.get_colordepth())
	if desktop: 
	    rl = desktop.getDefaultRunLevel() 
	    if rl and str(rl) == '5': 
		args = args + ['--startxonboot'] 
	    gui = desktop.getDefaultDesktop() 
	    if gui: 
		args = args + ['--defaultdesktop', string.lower(gui)] 

        if args != []:
            f.write("xconfig %s\n" % string.join(args, " "))

        monitorArgs = self.getMonitorArgList()
        if monitorArgs != []:
            f.write("monitor %s\n" % string.join(monitorArgs, " "))

    def getMonitorArgList(self):
        args = []
        monitor = self.xserver.monitorhw

        if monitor.getMonitorHorizSync() is not None:
            args += [ "--hsync", monitor.getMonitorHorizSync() ]

        if monitor.getMonitorVertSync() is not None:
            args += [ "--vsync", monitor.getMonitorVertSync() ]

        return args

    def getArgList(self, res, depth):
        args = []
	vc = self.xserver.videohw

	args = args + [ "--driver", '"' + vc.primaryCard().getDriver() + '"' ]
	vram = vc.primaryCard().getVideoRam()
	if vram is not None:
	    args = args + [ "--videoram", vram]

        # XXX this isn't really quite right, but it works for the way
        # things are now
        args = args + [ "--resolution", res ]
        args = args + [ "--depth", str(depth) ]

        return args