summaryrefslogtreecommitdiffstats
path: root/xsetup.py
blob: b1a0d603dc7d6ebda34870283ffd2dcc775911a1 (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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#
# 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 iutil
import rhpl.xserver as xserver
from rhpl.translate import _


import string
class XSetup:

    def __init__(self, hwstate):
	self.skipx = 0
	self.imposed_sane_default = 0
	self.xhwstate = hwstate

    #
    # mouse and keyboard maybe should be part of this object
    #
    # really all of this should be in rhpl probably
    #
    def write(self, fn, mouse, keyboard):
        # always turn dri on FIXME: except on ia64
        if iutil.getArch() == "ia64":
            self.xhwstate.set_dri_enabled(0)
        else:
            self.xhwstate.set_dri_enabled(1)

	#
	# XXX - cleanup monitor name to not include 'DDC Probed Monitor'
	#       in its string if its there.
	#
	#       This is around for legacy reasons.  The monitor description
	#       string passed around inside anaconda includes this prefix
	#       so that the UI can properly display the monitor as a DDC
	#       probed value versus a user selected value.
	#
	monname = self.xhwstate.get_monitor_name()
	if monname is not None:
	    ddc_monitor_string = _("DDC Probed Monitor")
	    if monname[:len(ddc_monitor_string)] == ddc_monitor_string:
		self.xhwstate.set_monitor_name(monname[len(ddc_monitor_string)+3:])
		
	outfile = fn + "/xorg.conf"
	xserver.writeXConfig(outfile, self.xhwstate, mouse, keyboard,
			     standalone = 0)

	# restore monitor name
	self.xhwstate.set_monitor_name(monname)

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

        args = self.getArgList(self.xhwstate.get_resolution(),
			       self.xhwstate.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)] 

	f.write("xconfig")
	for arg in args: 
	    f.write(" " + arg)
	f.write("\n")

    def getArgList(self, res, depth):
        args = []
        monitor = self.xhwstate.monitor
	vc = self.xhwstate.videocard

        args = args + [ "--card", '"' + vc.primaryCard().shortDescription() + '"' ]
	vram = vc.primaryCard().getVideoRam()
	if vram is not None:
	    args = args + [ "--videoram", vram]
        args = args + [ "--hsync", monitor.getMonitorHorizSync() ]
        args = args + [ "--vsync", monitor.getMonitorVertSync() ]

        # 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