1 |
|
---|
2 | from config import Config
|
---|
3 | from i18n import setLanguage
|
---|
4 | from sound import initializeSound
|
---|
5 | from util import secondaryInstallation
|
---|
6 | from const import VERSION
|
---|
7 |
|
---|
8 | import os
|
---|
9 | import sys
|
---|
10 |
|
---|
11 | #--------------------------------------------------------------------------------------
|
---|
12 |
|
---|
13 | ## @package mlx.mlx
|
---|
14 | #
|
---|
15 | # The main program.
|
---|
16 | #
|
---|
17 | # This module contains the main program of the logger as well as the \ref
|
---|
18 | # restart "restart" handling.
|
---|
19 |
|
---|
20 | #--------------------------------------------------------------------------------------
|
---|
21 |
|
---|
22 | instance = None
|
---|
23 |
|
---|
24 | #--------------------------------------------------------------------------------------
|
---|
25 |
|
---|
26 | class StdIOHandler(object):
|
---|
27 | """Handler for the standard I/O messages."""
|
---|
28 | def __init__(self, gui):
|
---|
29 | """Construct the handler."""
|
---|
30 | self._gui = gui
|
---|
31 |
|
---|
32 | def write(self, text):
|
---|
33 | """Write the given text into the log."""
|
---|
34 | self._gui.writeStdIO(text)
|
---|
35 |
|
---|
36 | #--------------------------------------------------------------------------------------
|
---|
37 |
|
---|
38 | def restart(args = []):
|
---|
39 | """Restart the program with the given arguments."""
|
---|
40 | #print "Restarting with args", args
|
---|
41 | programPath = os.path.join(os.path.dirname(sys.argv[0]),
|
---|
42 | "runmlx.exe" if os.name=="nt" else "runmlx.sh")
|
---|
43 | if os.name=="nt":
|
---|
44 | import win32api
|
---|
45 | try:
|
---|
46 | programPath = win32api.GetShortPathName(programPath)
|
---|
47 | except:
|
---|
48 | programPath = os.path.join(os.path.dirname(sys.argv[0]),
|
---|
49 | "runmlx.bat")
|
---|
50 | programPath = win32api.GetShortPathName(programPath)
|
---|
51 |
|
---|
52 | args = [programPath] + args
|
---|
53 |
|
---|
54 | instance.close()
|
---|
55 | os.execv(programPath, args)
|
---|
56 |
|
---|
57 | #--------------------------------------------------------------------------------------
|
---|
58 |
|
---|
59 | def main():
|
---|
60 | """The main operation of the program."""
|
---|
61 | from singleton import SingleInstance, raiseCallbackWrapper
|
---|
62 |
|
---|
63 | global instance
|
---|
64 | instance = SingleInstance("mlx" + ("-secondary" if secondaryInstallation
|
---|
65 | else ""), raiseCallbackWrapper)
|
---|
66 | if not instance: return
|
---|
67 |
|
---|
68 | programDirectory = os.path.dirname(sys.argv[0])
|
---|
69 |
|
---|
70 | config = Config()
|
---|
71 | config.load()
|
---|
72 |
|
---|
73 | secondaryArgs = ["secondary"] if secondaryInstallation else []
|
---|
74 | if "usedeflang" not in sys.argv and config.setupLocale():
|
---|
75 | restart(["usedeflang"] + secondaryArgs)
|
---|
76 |
|
---|
77 | setLanguage(programDirectory, config.getLanguage())
|
---|
78 |
|
---|
79 | from .gui.gui import GUI
|
---|
80 | gui = GUI(programDirectory, config)
|
---|
81 |
|
---|
82 | sys.stdout = StdIOHandler(gui)
|
---|
83 | sys.stderr = StdIOHandler(gui)
|
---|
84 |
|
---|
85 | print "MAVA Logger X " + VERSION + " debug log"
|
---|
86 | print "The initial configuration:"
|
---|
87 | config.log()
|
---|
88 |
|
---|
89 | initializeSound(os.path.join(programDirectory, "sounds"))
|
---|
90 |
|
---|
91 | try:
|
---|
92 | gui.build(programDirectory)
|
---|
93 |
|
---|
94 | gui.run()
|
---|
95 | finally:
|
---|
96 | gui.flushStdIO()
|
---|
97 | sys.stdout = sys.__stdout__
|
---|
98 | sys.stderr = sys.__stderr__
|
---|
99 |
|
---|
100 | config.save()
|
---|
101 |
|
---|
102 | if gui.toRestart:
|
---|
103 | restart(secondaryArgs)
|
---|
104 |
|
---|
105 | #--------------------------------------------------------------------------------------
|
---|
106 |
|
---|
107 | if __name__ == "__main__":
|
---|
108 | if instance:
|
---|
109 | main()
|
---|