complete software group screen

This commit is contained in:
lizhi-rocky
2010-08-02 16:19:59 +08:00
parent 62e5b2b075
commit 5688e9974b
7 changed files with 109 additions and 214 deletions

BIN
data/linxlogo.gif Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

View File

@@ -1,13 +1,7 @@
#!/usr/bin/python
''' handle gui button related commands.'''
''' handle commands.'''
import ri_tk as display
import ri_widget
import ri_data
import re
import copy
import sys
def quit():
''' correspond to quit button '''
@@ -40,163 +34,6 @@ def next():
else:
ri_widget.MessageBox.dict["next"].show()
def serial_no_init():
display.var_dict['serial_no.number'].set(value=ri_data.SerialNumber.value)
def serial_no_quit():
ri_data.SerialNumber.value = display.var_dict['serial_no.number'].get()
def mount_list_init():
''' initialize mount list '''
l = []
for m in ri_data.MountPoint.list:
# get size from Partition info
sz = ri_data.Partition.get_size(m.device)
if not sz:
sz = ri_data.Raid.get_size(m.device)
print m.device, m.directory, m.filesystem, m.format, sz
s = m.device.ljust(10) + m.directory.ljust(10) + m.filesystem.ljust(10) + m.format.ljust(4) + sz.ljust(6)
l.append(s)
display.var_dict['mount.list'].set(value=tuple([str(i) for i in l]))
def mount_list_modify(*args):
''' modify an item in mount list '''
tw = ri_widget.TopWindow.dict['mount_list_modify']
tw.show()
def mp_top_init():
''' mount dir top window initialize '''
ml_win = ri_widget.Widget.dict['mount.list'].tk_widget
idxs = ml_win.curselection()
if len(idxs) == 1:
idx = int(idxs[0])
mp = ri_data.MountPoint.list[idx]
dev = mp.device
dir = mp.directory
fs = mp.filesystem
fm = mp.format
sz = mp.size
display.var_dict['mp_top_dev'].set(value=dev)
display.var_dict['mp_top_size'].set(value=sz)
display.var_dict['mp_top_dir'].set(value=dir)
if fm == 'yes':
ri_widget.Widget.dict['mp_top_format'].tk_widget.select()
else:
ri_widget.Widget.dict['mp_top_not_format'].tk_widget.select()
fs_values = eval(display.var_dict['mp_top_fs'].get())
for i in range(len(fs_values)):
if fs == fs_values[i]:
ri_widget.Widget.dict['mp_top_fs'].tk_widget.selection_set(i)
def mp_top_ok():
''' mount dir top window OK '''
l = []
for itm in eval(display.var_dict['mount.list'].get()):
dev = itm.split()[0]
dev2 = display.var_dict['mp_top_dev'].get()
if dev == dev2:
sz = display.var_dict['mp_top_size'].get()
dir = display.var_dict['mp_top_dir'].get()
fm = display.var_dict['mp_top_format'].get()
idxs2 = ri_widget.Widget.dict['mp_top_fs'].tk_widget.curselection()
if len(idxs2):
idx2 = int(idxs2[0])
fs = eval(display.var_dict['mp_top_fs'].get())[idx2]
else:
fs = ''
s2 = dev.ljust(10) + dir.ljust(10) + fs.ljust(10) + fm.ljust(4) + sz.ljust(6)
l.append(s2)
# make change in internal data structure
ri_data.MountPoint.change(dev2, dir, fs, fm)
else:
l.append(itm)
display.var_dict['mount.list'].set(value=tuple(l))
ri_widget.TopWindow.dict['mount_list_modify'].hide()
def mp_top_cancel():
''' mount dir top window cancel '''
ri_widget.TopWindow.dict['mount_list_modify'].hide()
pass
def network_init():
''' network initialize '''
display.var_dict['network_host_name']. set(value=ri_data.Network.hostname)
ri_widget.Widget.dict['network_config_%s' %(ri_data.Network.configuration and ri_data.Network.configuration or 'static')].tk_widget.invoke()
display.var_dict['network_domain_name']. set(value=ri_data.Network.domain)
display.var_dict['network_ip']. set(value=ri_data.Network.ip)
display.var_dict['network_subnet_mask']. set(value=ri_data.Network.mask)
display.var_dict['network_gateway']. set(value=ri_data.Network.gateway)
display.var_dict['network_primary_dns']. set(value=ri_data.Network.primary_dns)
display.var_dict['network_secondary_dns'].set(value=ri_data.Network.secondary_dns)
def network_quit():
''' network quit '''
ri_data.Network.hostname = display.var_dict['network_host_name'].get()
ri_data.Network.configuration = display.var_dict['network_config_method'].get()
ri_data.Network.domain = display.var_dict['network_domain_name'].get()
ri_data.Network.ip = display.var_dict['network_ip'].get()
ri_data.Network.mask = display.var_dict['network_subnet_mask'].get()
ri_data.Network.gateway = display.var_dict['network_gateway'].get()
ri_data.Network.primary_dns = display.var_dict['network_primary_dns'].get()
ri_data.Network.secondary_dns = display.var_dict['network_secondary_dns'].get()
def ncm_dynamic():
''' when radio button ncm dynamic is checked, several data entry will be set 'disable' '''
for n in ('network_domain_name','network_ip','network_subnet_mask','network_gateway','network_primary_dns','network_secondary_dns'):
ri_widget.Widget.dict[n].tk_widget.configure(state='disable')
def ncm_static():
''' when radio button ncm static is checked, several data entry will be set 'normal' '''
for n in ('network_domain_name','network_ip','network_subnet_mask','network_gateway','network_primary_dns','network_secondary_dns'):
ri_widget.Widget.dict[n].tk_widget.configure(state='normal')
class GroupCheck(object):
''' A function class called whenever the group checkbox is clicked '''
dict={}
def __init__(self, n):
self.name = n
GroupCheck.dict[n] = self
def __call__(self):
print self.name
display.SoftwarePackageWindow.dict[self.name].show()
def software_group_construct(w):
''' draw group information on, based on actual data
w - Widget instance '''
for g in ri_data.Group.dict.values():
display.SoftwarePackageWindow(g)
mdt = [ m for m in ri_data.Group.dict.values() if m.install == 'mandatory' ]
opt = [ o for o in ri_data.Group.dict.values() if o.install != 'mandatory' ]
wit = w.widgets.pop()
for i in mdt:
wi = copy.deepcopy(wit)
wi.attr['text'] = i.name
vn = "software_group_%s" %(i.name)
wi.attr['variable'] = vn
wi.variables = [(vn, 'StringVar', ''),]
idx = mdt.index(i)
wi.grid_location.dict['column'] = idx % int(w.grid_management.columns)
wi.grid_location.dict['row'] = idx / int(w.grid_management.columns)
gc = GroupCheck(i.name)
setattr(sys.modules[__name__], vn, gc)
wi.attr['command'] = vn
w.add_sub_widget(wi)
def software_group_init():
pass
def software_group_quit():
pass
def software_group_item():
pass
from ri_tk_cmd import *

View File

@@ -6,8 +6,8 @@ from xml.dom import minidom
from xml.dom.ext import PrettyPrint
# xml file names
install_xml = '../../xml/install.xml'
config_xml = './config.xml'
install_xml = '../xml/install.xml'
config_xml = '../xml/config.xml'
def to_xml_attr(doc, node, cls, name):
''' This method is called by to_xml. Its function is to create an attribute, and set its value based on Network data member
@@ -361,6 +361,7 @@ g_node - group node '''
elif grp_chld.nodeName == 'optional':
g.optional.extend([[pkg.attributes['name'].value, pkg.attributes['install'].value] for pkg in grp_chld.childNodes
if pkg.nodeType == pkg.ELEMENT_NODE and pkg.nodeName == 'package'])
g.selection = grp_chld.attributes['selection'].value
init_from_xml = init_from_install_xml
@staticmethod
def to_xml(doc, p_node):
@@ -397,6 +398,9 @@ p_node - xml node (parent node)'''
if g.optional:
optl = doc.createElement('optional')
sel_attr = doc.createAttribute('selection')
sel_attr.value = g.selection
optl.setAttributeNode(sel_attr)
for o in g.optional:
pkg = doc.createElement('package')
pname_attr = doc.createAttribute('name')

View File

@@ -184,24 +184,40 @@ def destroy_top_window(w):
w.tk_widget.destroy()
class SoftwarePackageWindow():
''' Toplevel window for a group of software packages '''
''' Toplevel window for a group of software packages
class member
---------------------------
dict - class static member
---------------------------
instance member
---------------------------
group - data layer group instance
win - Tk widget
selection - StringVar variable for 'select_all'
opt_vars - a list to hold variables containing status for optional packages
opt_chks - a list to hold Checkbuttons for optional packages
'''
dict = {}
def __init__(self, g):
self.group = g
self.optional = []
self.opt_vars = []
self.opt_chks = []
SoftwarePackageWindow.dict[g.name] = self
def select_all(self):
''' callback function for check button select_all '''
self.group.selection = self.selection.get()
print self.group.selection
if self.selection.get() == 'all':
for ck in self.opt_chks:
ck.configure(state='disable')
def ok(self):
''' callback function for button OK '''
self.group.selection = self.selection.get()
for i in range(len(self.group.optional)):
# install field, yes or no
self.group.optional[i][1] = self.optional[i].get()
self.group.optional[i][1] = self.opt_vars[i].get()
self.win.destroy()
def cancel(self):
@@ -241,7 +257,7 @@ class SoftwarePackageWindow():
Tkinter.Label(fr1, text=self.group.mandatory[i]).grid(column=i%5, row=i/5, sticky='NWES')
Tkinter.Label(win, text='Optional').grid(column=0, row=3)
self.selection = Tkinter.StringVar(value="")
self.selection = Tkinter.StringVar(value=self.group.selection)
chk_sa = Tkinter.Checkbutton(win, text='Select all', command=self.select_all, variable=self.selection, onvalue='all', offvalue='manual')
chk_sa.grid(column=1, row=3)
if self.group.selection == 'all':
@@ -270,16 +286,20 @@ class SoftwarePackageWindow():
for i in range(len(self.group.optional)):
name, y_n = self.group.optional[i]
v = Tkinter.StringVar(value='no')
self.optional.append(v)
chk = Tkinter.Checkbutton(fr2, text=name, onvalue='yes', offvalue='no', variable=self.optional[i])
chk.grid(column=i%5, row=i/5, sticky='NWES')
self.opt_vars.append(v)
chk = Tkinter.Checkbutton(fr2, text=name, onvalue='yes', offvalue='no', variable=self.opt_vars[i])
self.opt_chks.append(chk)
chk.grid(column=i%5, row=i/5, sticky='NWS')
if y_n == 'yes':
chk.select()
else:
chk.deselect()
if self.group.selection == 'all':
chk.configure(state='disable')
Tkinter.Button(win, text='OK', command=self.ok).grid(column=0, row=6)
Tkinter.Button(win, text='Cancel', command=self.cancel).grid(column=1, row=6)
Tkinter.Button(win, text='OK', command=self.ok).grid(column=0, row=6, pady=2)
Tkinter.Button(win, text='Cancel', command=self.cancel).grid(column=1, row=6, pady=2)
win.after_idle(lambda : cnv1.configure(scrollregion=(0,0, fr1.winfo_width(), fr1.winfo_height())))
win.after_idle(lambda : cnv2.configure(scrollregion=(0,0, fr2.winfo_width(), fr2.winfo_height())))
@@ -293,5 +313,5 @@ class SoftwarePackageWindow():
pass
else:
break
win.wait_window()

View File

@@ -7,6 +7,7 @@ import ri_data
import sys
import getopt
from xml.dom import minidom
import os.path
def print_usages():
print 'Usages: %s [-b|--begin step_name] [interface_xml_file] [install_xml_file]' %sys.argv[0]
@@ -34,8 +35,11 @@ else:
xmldoc = minidom.parse(itf_xml)
ri_data.install_xml = ins_xml
ri_data.init_from_xml()
#ri_data.init()
if os.path.isfile(ins_xml):
ri_data.init_from_xml()
else:
ri_data.init()
ri_widget.construct(xmldoc.firstChild)
@@ -49,7 +53,7 @@ main_sequence = ri_widget.Sequence.dict[main_sequence_name]
if begin_step is None:
begin_step = main_sequence.steps[0]
else:
main_sequence.set_step(begin_step)
main_sequence.set_current_step(begin_step)
ri_widget.Widget.dict[begin_step].show()

View File

@@ -1,7 +1,6 @@
<?xml version='1.0' encoding='UTF-8'?>
<install>
<serial-number>
</serial-number>
<serial-number>123456789012</serial-number>
<partitions unit='sectors'>
<partition device='sda1' start='63' id='83' size='195318207'/>
<partition device='sda2' start='195318270' id='82' size='3903795'/>
@@ -20,16 +19,16 @@
</raids>
<mount-points>
<mount-point device='sda2' directory='' file-system='' format='no'/>
<mount-point device='sda3' directory='' file-system='ext3' format='no'/>
<mount-point device='sda4' directory='/' file-system='ext2' format='no'/>
<mount-point device='sda3' directory='' file-system='' format='no'/>
<mount-point device='sda4' directory='' file-system='' format='no'/>
<mount-point device='sdb2' directory='' file-system='' format='no'/>
<mount-point device='sdb3' directory='' file-system='' format='no'/>
<mount-point device='sdb3' directory='/olp' file-system='reiserfs' format='yes'/>
<mount-point device='sdb4' directory='' file-system='' format='no'/>
<mount-point device='md0' directory='/opt' file-system='reiserfs' format='yes'/>
<mount-point device='md0' directory='' file-system='' format='no'/>
</mount-points>
<network domain='' secondary_dns='' ip='' hostname='lizhi' mask='' primary_dns='' configuration='dynamic' gateway=''/>
<groups>
<group name='development' install='no'>
<group name='development' install='yes'>
<description>
开发类包括 C、C++Fortran、DDD 等开发工具。
开发类软件包分为必选包和可选包,当选择安装该类后,必选包是默认安装的,可选包可以自由选择安装。
@@ -42,7 +41,7 @@
<package name='m4'/>
<package name='make'/>
</mandatory>
<optional>
<optional selection='all'>
<package name='ant' install='no'/>
<package name='Archive-Zip' install='no'/>
<package name='autogen' install='no'/>
@@ -86,7 +85,7 @@
<package name='trac' install='no'/>
</optional>
</group>
<group name='office' install='no'>
<group name='office' install='yes'>
<description>
办公类包括 OpenOffice.org 等办公软件。
办公类都是必选软件包,当选择安装该类后,必选包是默认安装的。
@@ -95,12 +94,12 @@
<package name='openoffice'/>
</mandatory>
</group>
<group name='kde' install='no'>
<group name='kde' install='yes'>
<description>
KDE是一种著名的自由图形工作环境,整个系统采用Qt程序库
KDE桌面类都是可选软件包可以自由选择安装。
</description>
<optional>
<optional selection='all'>
<package name='kde-i18n-zh_CN' install='no'/>
<package name='kdeaccessibility' install='no'/>
<package name='kdeaddons' install='no'/>
@@ -186,7 +185,7 @@
<package name='xkeyboard-config'/>
<package name='x11-fonts-chinese'/>
</mandatory>
<optional>
<optional selection='manual'>
<package name='arts' install='no'/>
<package name='atk' install='no'/>
<package name='cairo' install='no'/>
@@ -228,7 +227,7 @@
网络工具类包括 tcpdump 等网络工具。
网络工具类都是可选软件包,可以自由选择安装。
</description>
<optional>
<optional selection='manual'>
<package name='libpcap' install='no'/>
<package name='tcpdump' install='no'/>
<package name='wireshark' install='no'/>
@@ -239,7 +238,7 @@
通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统
虚拟机类都是可选软件包,可以自由选择安装
</description>
<optional>
<optional selection='manual'>
<package name='qemu-kvm' install='no'/>
<package name='bridge-utils' install='no'/>
<package name='uml-utilities' install='no'/>
@@ -336,18 +335,18 @@
<package name='which'/>
<package name='zlib'/>
</mandatory>
<optional>
<package name='adjtimex' install='yes'/>
<optional selection='manual'>
<package name='adjtimex' install='no'/>
<package name='at' install='no'/>
<package name='audit' install='no'/>
<package name='bc' install='no'/>
<package name='beecrypt' install='no'/>
<package name='cdrtools' install='yes'/>
<package name='cdrtools' install='no'/>
<package name='cpufrequtils' install='no'/>
<package name='dialog' install='no'/>
<package name='dosfstools' install='no'/>
<package name='ed' install='no'/>
<package name='expat' install='yes'/>
<package name='expat' install='no'/>
<package name='gawk' install='no'/>
<package name='gettext' install='no'/>
<package name='hdparm' install='no'/>
@@ -378,7 +377,7 @@
<package name='usbutils' install='no'/>
<package name='texi2html' install='no'/>
<package name='wget' install='no'/>
<package name='xfsprogs' install='yes'/>
<package name='xfsprogs' install='no'/>
<package name='zip' install='no'/>
</optional>
</group>
@@ -387,7 +386,7 @@
网络服务类包括各种网络服务包。
网络服务类都是可选软件包,可以自由选择安装。
</description>
<optional>
<optional selection='manual'>
<package name='apache' install='no'/>
<package name='apr' install='no'/>
<package name='bind' install='no'/>
@@ -431,7 +430,7 @@
<package name='dbus-glib-1'/>
<package name='firefox'/>
</mandatory>
<optional>
<optional selection='manual'>
<package name='amsn' install='no'/>
<package name='thunderbird' install='no'/>
</optional>
@@ -441,7 +440,7 @@
多媒体类包括各种媒体库。
多媒体类都是可选软件包,可以自由选择安装。
</description>
<optional>
<optional selection='manual'>
<package name='alsa-lib' install='no'/>
<package name='alsa-oss' install='no'/>
<package name='alsa-utils' install='no'/>

View File

@@ -410,19 +410,49 @@ row 4 | |
<grid_location row='0' column='0'/>
</widget>
<widget type='Frame' name='software_group_content' construct='software_group_construct'>
<grid_management rows='x' columns='3'>
<configure column='0' weight='1'/>
<configure column='1' weight='1'/>
<configure column='2' weight='1'/>
<widget type='Frame' name='software_group_content'>
<grid_management rows='4' columns='1'>
<configure row='1' weight='1'/>
<configure row='3' weight='1'/>
</grid_management>
<grid_location row='0' column='1' sticky='NSWE' />
<action init='software_group_init' quit='software_group_quit'/>
<!-- a template for software group item -->
<widget type='Checkbutton' name='software-group-item'>
<widget_attribute text='' command='software_group_item' variable='' onvalue='on' offvalue='off'/>
<widget type='Label'>
<widget_attribute text='Mandatory'/>
<grid_location row='0' column='0'/>
</widget>
<widget type='Frame' construct='software_group_mandatory_construct'>
<grid_management rows='x' columns='3'>
<configure column='0' weight='1'/>
<configure column='1' weight='1'/>
<configure column='2' weight='1'/>
</grid_management>
<grid_location row='1' column='0'/>
<!-- a template for software group mandatory item -->
<widget type='Button' name='software-group-mandatory-item' >
<widget_attribute text='' command='software_group_mandatory_item'/>
<grid_location row='0' column='0' sticky='W'/>
</widget>
</widget>
<widget type='Label'>
<widget_attribute text='Optional'/>
<grid_location row='2' column='0'/>
</widget>
<widget type='Frame' construct='software_group_optional_construct'>
<grid_management rows='x' columns='3'>
<configure column='0' weight='1'/>
<configure column='1' weight='1'/>
<configure column='2' weight='1'/>
</grid_management>
<grid_location row='3' column='0'/>
<action quit='software_group_optional_quit'/>
<!-- a template for software group optional item -->
<widget type='Checkbutton' name='software-group-optional-item'>
<widget_attribute text='' variable='' command='' onvalue='yes' offvalue='no'/>
<grid_location row='0' column='0' sticky='W'/>
</widget>
</widget>
</widget>
</widget>
@@ -521,6 +551,7 @@ row 4 | |
<!--
<top_window name='software_package_template' construct='software_package_construct'>
-->
<!--
<top_window name='software_package_template'>
<grid_management rows='4' columns='2'>
<configure row='1' weight='1'/>
@@ -557,7 +588,7 @@ row 4 | |
<grid_location row='3' column='1' sticky='NSW'/>
</widget>
</top_window>
-->
<message key='#os-name'>
<English>Rocky 4.2</English>
<Chinese>磐石 4.2</Chinese>