- Uses getopt to handle the command line in a more standard way

- Organized code so the ui can be either qt or curses



git-svn-id: http://galileo.dmi.unict.it/svn/relational/trunk@223 014f5005-505e-4b48-8d0a-63407b615a7c
This commit is contained in:
LtWorf 2010-03-21 12:55:32 +00:00
parent c282873c17
commit f1018b20f8
2 changed files with 72 additions and 36 deletions

View File

@ -100,3 +100,5 @@
- Automatically fills some fields in the survey (Rev 217) - Automatically fills some fields in the survey (Rev 217)
- When a query fails, shows the message of the exception (Rev220) - When a query fails, shows the message of the exception (Rev220)
- Improved tokenizer for select in optimizations, now can accept operators in identifiers (Rev220) - Improved tokenizer for select in optimizations, now can accept operators in identifiers (Rev220)
- Uses getopt to handle the command line in a more standard way
- Organized code so the ui can be either qt or curses

View File

@ -21,17 +21,12 @@
import sys import sys
import os import os
import sip import getopt
from PyQt4 import QtCore, QtGui
from relational_gui import maingui, about
from relational import relation, parser from relational import relation, parser
version="0.11" version="0.11"
about.version=version
if __name__ == "__main__":
if len (sys.argv) > 1 and sys.argv[1] == "-v":
def printver():
print "Relational" print "Relational"
print "This program comes with ABSOLUTELY NO WARRANTY." print "This program comes with ABSOLUTELY NO WARRANTY."
print "This is free software, and you are welcome to redistribute it" print "This is free software, and you are welcome to redistribute it"
@ -41,12 +36,51 @@ if __name__ == "__main__":
print "Version: %s"%version print "Version: %s"%version
sys.exit(0) sys.exit(0)
def printhelp(code=0):
print "Relational"
print
print "Usage: %s [options] [files]" % sys.argv[0]
print
print " -v Print version and exits"
print " -h Print this help and exits"
print " -q Uses QT user interface (default)"
print " -c Uses curses user interface"
sys.exit(code)
if __name__ == "__main__":
x11=True #Will try to use the x11 interface
#Try to run the psyco optimizer
try: try:
import psyco import psyco
psyco.full() psyco.full()
except: except:
pass pass
#Getting command line
try:
switches,files=getopt.getopt(sys.argv[1:],"vhqc")
except:
printhelp(1)
for i in switches:
if i[0]=='-v':
printver()
elif i[0]=='-h':
printhelp()
elif i[0]=='-q':
x11=True
elif i[0]=='-c':
x11=False
if x11:
import sip
from PyQt4 import QtCore, QtGui
from relational_gui import maingui, about
about.version=version
app = QtGui.QApplication(sys.argv) app = QtGui.QApplication(sys.argv)
Form = QtGui.QWidget() Form = QtGui.QWidget()
@ -56,15 +90,15 @@ if __name__ == "__main__":
ui = maingui.Ui_Form() ui = maingui.Ui_Form()
ui.setupUi(Form) ui.setupUi(Form)
for i in range(1,len(sys.argv)): for i in range(len(files)):
f=sys.argv[i].split('/') f=files[i].split('/')
defname=f[len(f)-1].lower() defname=f[len(f)-1].lower()
if (defname.endswith(".csv") or defname.endswith(".tlb")): #removes the extension if (defname.endswith(".csv") or defname.endswith(".tlb")): #removes the extension
defname=defname[:-4] defname=defname[:-4]
print 'Loading file "%s" with name "%s"' % (sys.argv[i],defname) print 'Loading file "%s" with name "%s"' % (files[i],defname)
ui.loadRelation(sys.argv[i],defname) ui.loadRelation(files[i],defname)
Form.show() Form.show()
sys.exit(app.exec_()) sys.exit(app.exec_())
else: #TODO load with curses interface
pass