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
|