Cleaned up code a bit
This commit is contained in:
parent
1b2e04ee75
commit
c8e12cb6db
|
@ -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
|
||||||
|
|
221
gfceu
221
gfceu
|
@ -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,13 +358,13 @@ 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
|
||||||
set_options()
|
set_options()
|
||||||
chooser = gtk.FileChooserDialog("Open...", None,
|
chooser = gtk.FileChooserDialog("Open...", None,
|
||||||
|
@ -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\
|
||||||
|
@ -454,17 +435,17 @@ def confighelpbutton_clicked(arg1):
|
||||||
msgbox.hide()
|
msgbox.hide()
|
||||||
|
|
||||||
|
|
||||||
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:
|
||||||
|
|
886
gfceu.glade
886
gfceu.glade
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue