Cleaned up code a bit

This commit is contained in:
punkrockguy318 2006-10-14 22:13:58 +00:00
parent 1b2e04ee75
commit c8e12cb6db
3 changed files with 952 additions and 1390 deletions

View File

@ -2,6 +2,7 @@
Cleanup: Cleanup:
* Fixed silly hack when forcing GTK event processing. * Fixed silly hack when forcing GTK event processing.
* Accepted patch from Scott Brown on improved options file system * Accepted patch from Scott Brown on improved options file system
* Completely reworked glade handling
========================== version 0.5.1 ======================== ========================== version 0.5.1 ========================
Bug Fixes: Bug Fixes:
* Updated chooser filters * Updated chooser filters

211
gfceu
View File

@ -20,8 +20,9 @@ along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
""" """
############################################################################## # # # # # # # #
# Python imports # Python imports
import sys import sys
import os import os
import pickle import pickle
@ -29,11 +30,11 @@ import shutil
from optparse import OptionParser from optparse import OptionParser
from subprocess import Popen from subprocess import Popen
############################################################################## # # # # # # # #
# Messaging Functions # Messaging Functions
def gfceu_message(message, use_gtk=False): def gfceu_message(message, use_gtk=False):
""" """
gfceu_message() gqfceu_message()
This function prints messages to the user. This is generally used for status This function prints messages to the user. This is generally used for status
messages. However, it can be used for important messages as well. If a messages. However, it can be used for important messages as well. If a
@ -54,10 +55,10 @@ def gfceu_error(message, code, use_gtk=True, fatal=True):
TODO: This can be reworked to use the raise/except methods already defined TODO: This can be reworked to use the raise/except methods already defined
in the standard python language. One of these days... in the standard python language. One of these days...
""" """
print '################################################' print '# # # #'
print 'gfceu ERROR code '+str(code)+':' print 'gfceu ERROR code '+str(code)+':'
print message print message
print '################################################' print '# # # #'
if use_gtk: if use_gtk:
msgbox = gtk.MessageDialog(parent=None, flags=0, type=gtk.MESSAGE_ERROR, msgbox = gtk.MessageDialog(parent=None, flags=0, type=gtk.MESSAGE_ERROR,
buttons=gtk.BUTTONS_CLOSE) buttons=gtk.BUTTONS_CLOSE)
@ -68,7 +69,7 @@ def gfceu_error(message, code, use_gtk=True, fatal=True):
sys.exit(code) sys.exit(code)
############################################################################## # # # # # # # #
# Import libraries # Import libraries
try: try:
import pytgtk import pytgtk
@ -103,7 +104,7 @@ except ImportError:
have_gnomevfs = False have_gnomevfs = False
############################################################################### # # # # # # # #
# GFCEU Functions # GFCEU Functions
class game_options: class game_options:
@ -123,8 +124,6 @@ class game_options:
network_rom = False network_rom = False
def load_options(): def load_options():
global options, optionsfile global options, optionsfile
try: try:
@ -150,27 +149,25 @@ def give_widgets():
""" """
global xml, options global xml, options
try: try:
xml.get_widget('rom_entry').set_text(options.romfile) widgets['rom_entry'].set_text(options.romfile)
xml.get_widget('sound_check').set_active(options.sound_check) widgets['sound_check'].set_active(options.sound_check)
xml.get_widget('fullscreen_check').set_active(options.fullscreen_check) widgets['fullscreen_check'].set_active(options.fullscreen_check)
xml.get_widget('opengl_check').set_active(options.opengl_check) widgets['opengl_check'].set_active(options.opengl_check)
xml.get_widget('extra_entry').set_text(options.extra_entry) widgets['extra_entry'].set_text(options.extra_entry)
# Usability point: # Usability point:
# Users will probably not want to remember their previous network setting. # Users will probably not want to remember their previous network setting.
# Users may accidently be connecting to a remote server/hosting a game when # Users may accidently be connecting to a remote server/hosting a game when
# they were unaware. # they were unaware.
# No network is being set by default # No network is being set by default
xml.get_widget('no_network_radio').set_active(True) widgets['no_network_radio'].set_active(True)
xml.get_widget('join_add').set_text(options.join_add) widgets['join_add'].set_text(options.join_add)
xml.get_widget('join_port').set_value(float(options.join_port)) widgets['join_port'].set_value(float(options.join_port))
xml.get_widget('join_pass').set_text(options.join_pass) widgets['join_pass'].set_text(options.join_pass)
xml.get_widget('host_port').set_value(float(options.host_port)) widgets['host_port'].set_value(float(options.host_port))
xml.get_widget('host_pass').set_text(options.host_pass) widgets['host_pass'].set_text(options.host_pass)
except AttributeError: except AttributeError:
# When new widgets are added, old pickle files might break. # When new widgets are added, old pickle files might break.
@ -209,31 +206,24 @@ def set_options():
and stores it in the options object. and stores it in the options object.
""" """
global xml global xml
options.romfile = xml.get_widget('rom_entry').get_text() options.romfile = widgets['rom_entry'].get_text()
options.sound_check = xml.get_widget('sound_check').get_active() options.sound_check = widgets['sound_check'].get_active()
options.fullscreen_check = xml.get_widget('fullscreen_check').get_active() options.fullscreen_check = widgets['fullscreen_check'].get_active()
options.opengl_check = xml.get_widget('opengl_check').get_active() options.opengl_check = widgets['opengl_check'].get_active()
options.extra_entry = xml.get_widget('extra_entry').get_text() options.extra_entry = widgets['extra_entry'].get_text()
options.join_radio = xml.get_widget('join_radio').get_active() options.join_radio = widgets['join_radio'].get_active()
options.host_radio = xml.get_widget('host_radio').get_active() options.host_radio = widgets['host_radio'].get_active()
options.no_network_radio = xml.get_widget('no_network_radio').get_active() options.no_network_radio = widgets['no_network_radio'].get_active()
options.join_add = xml.get_widget('join_add').get_text() options.join_add = widgets['join_add'].get_text()
options.join_port = xml.get_widget('join_port').get_value() options.join_port = widgets['join_port'].get_value()
options.join_pass = xml.get_widget('join_pass').get_text() options.join_pass = widgets['join_pass'].get_text()
options.host_port = xml.get_widget('host_port').get_value() options.host_port = widgets['host_port'].get_value()
options.host_pass = xml.get_widget('host_pass').get_text() options.host_pass = widgets['host_pass'].get_text()
def end(widget,arg=0):
global xml, options, optionsfile
set_options()
save_options()
gtk.main_quit()
def launch(passed, local=False): def launch(passed, local=False):
global xml, options, fceu_server_binary, fceu_binary global xml, options, fceu_server_binary, fceu_binary
set_options() set_options()
@ -295,7 +285,7 @@ def launch(passed, local=False):
args.append(options.host_pass) args.append(options.host_pass)
pid = Popen(args).pid pid = Popen(args).pid
xml.get_widget('main_window').hide() widgets['main_window'].hide()
# os.system() is a blocker, so we must force # os.system() is a blocker, so we must force
# gtk to process our events. # gtk to process our events.
@ -305,7 +295,7 @@ def launch(passed, local=False):
os.system(command) os.system(command)
if options.host_radio: if options.host_radio:
os.kill(pid, 9) os.kill(pid, 9)
xml.get_widget('main_window').show() widgets['main_window'].show()
def find_binary(this_binary): def find_binary(this_binary):
path = os.getenv('PATH') path = os.getenv('PATH')
@ -328,14 +318,14 @@ def find_binary(this_binary):
return None return None
############################################################################## # # # # # # # #
# GTK Signal Handlers # GTK Signal Handlers
class GladeHandlers:
def launchbutton_clicked(arg1): def launchbutton_clicked(arg1):
global xml global xml
global options global options
options.romfile = xml.get_widget('rom_entry').get_text() options.romfile = widgets['rom_entry'].get_text()
if xml.get_widget('rom_entry').get_text() == '': if widgets['rom_entry'].get_text() == '':
gfceu_message('Please specify a ROM to open in the main tab.', True) gfceu_message('Please specify a ROM to open in the main tab.', True)
return return
if options.network_rom: if options.network_rom:
@ -368,11 +358,11 @@ def launchbutton_clicked(arg1):
launch('"'+romfile+'"') launch('"'+romfile+'"')
def about_clicked(arg1): def about_button_clicked(arg1):
global xml global xml
xml.get_widget('about_dialog').set_name('GNOME FCE Ultra '+version) widgets['about_dialog'].set_name('GNOME FCE Ultra '+version)
xml.get_widget('about_dialog').run() widgets['about_dialog'].run()
xml.get_widget('about_dialog').hide() widgets['about_dialog'].hide()
def browse_button_clicked(widget): def browse_button_clicked(widget):
global xml,options global xml,options
@ -416,34 +406,25 @@ def browse_button_clicked(widget):
if response == gtk.RESPONSE_OK: if response == gtk.RESPONSE_OK:
if chooser.get_filename(): if chooser.get_filename():
x = chooser.get_filename() x = chooser.get_filename()
xml.get_widget('rom_entry').set_text(x) widgets['rom_entry'].set_text(x)
options.romfile = x options.romfile = x
options.network_rom = False options.network_rom = False
elif chooser.get_uri(): elif chooser.get_uri():
x = chooser.get_uri() x = chooser.get_uri()
xml.get_widget('rom_entry').set_text(x) widgets['rom_entry'].set_text(x)
options.romfile = x options.romfile = x
options.network_rom = True options.network_rom = True
def gamepad_clicked(widget):
def gp1(widget): print widget.name
command = '-inputcfg gamepad1 /dev/null' d = {'gp1_button' : '1',
launch(command, True) 'gp2_button' : '2',
def gp2(widget): 'gp3_button' : '3',
command = '-inputcfg gamepad2 /dev/null' 'gp4_button' : '4'}
launch(command, True) command = '-inputcfg gamepad' + d[widget.name] + ' /dev/null'
def gp3(widget):
command = '-inputcfg gamepad3 /dev/null'
launch(command, True)
def gp4(widget):
command = '-inputcfg gamepad4 /dev/null'
launch(command, True) launch(command, True)
def config_help_button_clicked(arg1):
def confighelpbutton_clicked(arg1):
msgbox = gtk.MessageDialog(parent=None, flags=0, msgbox = gtk.MessageDialog(parent=None, flags=0,
type=gtk.MESSAGE_INFO, buttons=gtk.BUTTONS_CLOSE) type=gtk.MESSAGE_INFO, buttons=gtk.BUTTONS_CLOSE)
msgbox.set_markup("Once a gamepad is seleceted, a titlebar will be displayed\ msgbox.set_markup("Once a gamepad is seleceted, a titlebar will be displayed\
@ -456,15 +437,15 @@ def confighelpbutton_clicked(arg1):
def join_radio_clicked(arg1): def join_radio_clicked(arg1):
global options global options
xml.get_widget('join_frame').set_sensitive(True) widgets['join_frame'].set_sensitive(True)
xml.get_widget('host_frame').set_sensitive(False) widgets['host_frame'].set_sensitive(False)
options.join_radio = True options.join_radio = True
options.host_radio = False options.host_radio = False
options.no_network_radio = False options.no_network_radio = False
def host_radio_clicked(arg1): def host_radio_clicked(arg1):
global fceu_server_binary global fceu_server_binary
if xml.get_widget('host_radio').get_active(): if widgets['host_radio'].get_active():
fceu_server_binary = find_binary('fceu-server') fceu_server_binary = find_binary('fceu-server')
if fceu_server_binary == None: if fceu_server_binary == None:
if os.name == 'nt': if os.name == 'nt':
@ -475,27 +456,32 @@ def host_radio_clicked(arg1):
gfceu_error("The fceu server software cannot be found on \n\ gfceu_error("The fceu server software cannot be found on \n\
this system. Ensure that it is installed and in your path.", this system. Ensure that it is installed and in your path.",
101, True, False) 101, True, False)
xml.get_widget('no_network_radio').set_active(True) widgets['no_network_radio'].set_active(True)
options.no_network_radio = True options.no_network_radio = True
return False return False
gfceu_message("Using: "+fceu_server_binary) gfceu_message("Using: "+fceu_server_binary)
xml.get_widget('join_frame').set_sensitive(False) widgets['join_frame'].set_sensitive(False)
xml.get_widget('host_frame').set_sensitive(True) widgets['host_frame'].set_sensitive(True)
options.join_radio = False options.join_radio = False
options.host_radio = True options.host_radio = True
options.no_network_radio = False options.no_network_radio = False
def no_network_radio_clicked(arg1): def no_network_radio_clicked(arg1):
xml.get_widget('join_frame').set_sensitive(False) widgets['join_frame'].set_sensitive(False)
xml.get_widget('host_frame').set_sensitive(False) widgets['host_frame'].set_sensitive(False)
options.join_radio = False options.join_radio = False
options.host_radio = False options.host_radio = False
options.no_network_radio = True options.no_network_radio = True
def end(widget,arg=0):
global xml, options, optionsfile
set_options()
save_options()
gtk.main_quit()
############################################################################## ##############################################################################
# Globals # Globals
xml = None
options = None options = None
appconfigdir = os.getenv('HOME') + '/.gfceu' appconfigdir = os.getenv('HOME') + '/.gfceu'
old_optionsfile = os.getenv('HOME')+'/.gfceu_options' old_optionsfile = os.getenv('HOME')+'/.gfceu_options'
@ -505,9 +491,30 @@ fceu_server_binary = None
#version is defined earlier in the code #version is defined earlier in the code
#have_vfs is defined earlier in the code #have_vfs is defined earlier in the code
############################################################################## class WidgetsWrapper:
# The beloved main def __init__(self):
# Search for the glade file
# Check first in the directory of this script.
if os.path.isfile(os.path.dirname(sys.argv[0])+'/gfceu.glade'):
glade_file = os.path.dirname(sys.argv[0])+'/gfceu.glade'
# Then check in the share directory (installed)
elif os.path.isfile(os.path.dirname(sys.argv[0]) +\
'/../share/gfceu/gfceu.glade'):
glade_file = os.path.dirname(sys.argv[0])+'/../share/gfceu/gfceu.glade'
else:
print 'ERROR.'
print 'Could not find the glade interface file.'
print 'Try reinstalling the application.'
self.widgets = gtk.glade.XML(glade_file)
self.widgets.signal_autoconnect(GladeHandlers.__dict__)
def __getitem__(self, key):
return self.widgets.get_widget(key)
# # # # # # # #
# main
if __name__ == '__main__': if __name__ == '__main__':
# Parse options # Parse options
parser = OptionParser(version='%prog '+ version) parser = OptionParser(version='%prog '+ version)
@ -522,45 +529,11 @@ if __name__ == '__main__':
else: else:
gfceu_message('Using: '+fceu_binary) gfceu_message('Using: '+fceu_binary)
# Search for the glade file widgets = WidgetsWrapper()
# Check first in the directory of this script. widgets['main_window'].show_all()
if os.path.isfile(os.path.join(os.path.dirname(sys.argv[0]),'gfceu.glade')):
xml=gtk.glade.XML(os.path.join(os.path.dirname(sys.argv[0]),'gfceu.glade'))
# Then check in the share directory (installed)
elif os.path.isfile(os.path.dirname(sys.argv[0]) +\
'/../share/gfceu/gfceu.glade'):
xml=gtk.glade.XML(os.path.dirname(sys.argv[0])+\
'/../share/gfceu/gfceu.glade')
else:
gfceu_error('Could not find the glade interface file.\n\
Try reinstalling the application.', 3, True)
# Signal connections
dic = {
# Common
"on_launch_button_clicked" : launchbutton_clicked,
"on_about_button_clicked" : about_clicked,
"on_quit_button_clicked" : end,
# Main tab
"on_browse_button_clicked" : browse_button_clicked,
# Input tab
"on_gp1_button_clicked" : gp1,
"on_gp2_button_clicked" : gp2,
"on_gp3_button_clicked" : gp3,
"on_gp4_button_clicked" : gp4,
"on_config_help_button_clicked" : confighelpbutton_clicked,
# Network tab
"on_join_radio_clicked" : join_radio_clicked,
"on_host_radio_clicked" : host_radio_clicked,
"on_no_network_radio_clicked" : no_network_radio_clicked,
"on_main_window_delete" : end
}
xml.signal_autoconnect (dic)
setup_environment() setup_environment()
# Set the global options
options = game_options()
options = game_options()
load_options() load_options()
give_widgets() give_widgets()
try: try:

File diff suppressed because it is too large Load Diff