eric6_compare.py

changeset 3669
ac84ac3c0f05
parent 3656
441956d8fce5
child 3670
f0cb7579c0b4
equal deleted inserted replaced
3668:0e83d06e5429 3669:ac84ac3c0f05
1 #!/usr/bin/env python3
2 # -*- coding: utf-8 -*-
3
4 # Copyright (c) 2006 - 2014 Detlev Offenbach <detlev@die-offenbachs.de>
5 #
6
7 """
8 Eric5 Compare.
9
10 This is the main Python script that performs the necessary initialization
11 of the Compare module and starts the Qt event loop. This is a standalone
12 version of the integrated Compare module.
13 """
14
15 from __future__ import unicode_literals
16 try: # Only for Py2
17 import Utilities.compatibility_fixes # __IGNORE_WARNING__
18 except (ImportError):
19 pass
20
21 import sys
22
23 for arg in sys.argv:
24 if arg.startswith("--config="):
25 import Globals
26 configDir = arg.replace("--config=", "")
27 Globals.setConfigDir(configDir)
28 sys.argv.remove(arg)
29 break
30
31 from Globals import AppInfo
32
33 from Toolbox import Startup
34
35
36 def createMainWidget(argv):
37 """
38 Function to create the main widget.
39
40 @param argv list of commandline parameters (list of strings)
41 @return reference to the main widget (QWidget)
42 """
43 from UI.CompareDialog import CompareWindow
44 if len(argv) >= 6:
45 # assume last two entries are the files to compare
46 return CompareWindow([(argv[-5], argv[-2]), (argv[-3], argv[-1])])
47 elif len(argv) >= 2:
48 return CompareWindow([("", argv[-2]), ("", argv[-1])])
49 else:
50 return CompareWindow()
51
52
53 def main():
54 """
55 Main entry point into the application.
56 """
57 options = [
58 ("--config=configDir",
59 "use the given directory as the one containing the config files"),
60 ]
61 appinfo = AppInfo.makeAppInfo(sys.argv,
62 "Eric5 Compare",
63 "",
64 "Simple graphical compare tool",
65 options)
66 res = Startup.simpleAppStartup(sys.argv,
67 appinfo,
68 createMainWidget)
69 sys.exit(res)
70
71 if __name__ == '__main__':
72 main()

eric ide

mercurial