]> granicus.if.org Git - python/commitdiff
Merged revisions 68470 via svnmerge from
authorHirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp>
Sat, 10 Jan 2009 09:35:47 +0000 (09:35 +0000)
committerHirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp>
Sat, 10 Jan 2009 09:35:47 +0000 (09:35 +0000)
svn+ssh://pythondev@svn.python.org/python/trunk

........
  r68470 | hirokazu.yamamoto | 2009-01-10 18:18:16 +0900 | 1 line

  Added helper script to build Tcl/Tk.
........

PC/VC6/build_tkinter.py [new file with mode: 0644]

diff --git a/PC/VC6/build_tkinter.py b/PC/VC6/build_tkinter.py
new file mode 100644 (file)
index 0000000..f2e3c41
--- /dev/null
@@ -0,0 +1,81 @@
+import os\r
+import sys\r
+import subprocess\r
+\r
+TCL_MAJOR = 8\r
+TCL_MINOR = 5\r
+TCL_PATCH = 2\r
+\r
+TIX_MAJOR = 8\r
+TIX_MINOR = 4\r
+TIX_PATCH = 3\r
+\r
+def abspath(name):\r
+    par = os.path.pardir\r
+    return os.path.abspath(os.path.join(__file__, par, par, par, par, name))\r
+\r
+TCL_DIR = abspath("tcl%d.%d.%d" % (TCL_MAJOR, TCL_MINOR, TCL_PATCH))\r
+TK_DIR  = abspath("tk%d.%d.%d"  % (TCL_MAJOR, TCL_MINOR, TCL_PATCH))\r
+TIX_DIR = abspath("tix%d.%d.%d" % (TIX_MAJOR, TIX_MINOR, TIX_PATCH))\r
+OUT_DIR = abspath("tcltk")\r
+\r
+def have_args(*a):\r
+    return any(s in sys.argv[1:] for s in a)\r
+\r
+def enter(dir):\r
+    os.chdir(os.path.join(dir, "win"))\r
+\r
+def main():\r
+    debug = have_args("-d", "--debug")\r
+    clean = have_args("clean")\r
+    install = have_args("install")\r
+    tcl = have_args("tcl")\r
+    tk = have_args("tk")\r
+    tix = have_args("tix")\r
+    if not(tcl) and not(tk) and not(tix):\r
+        tcl = tk = tix = True\r
+\r
+    def nmake(makefile, *a):\r
+        args = ["nmake", "/nologo", "/f", makefile, "DEBUG=%d" % debug]\r
+        args.extend(a)\r
+        subprocess.check_call(args)\r
+\r
+    if tcl:\r
+        enter(TCL_DIR)\r
+        def nmake_tcl(*a):\r
+            nmake("makefile.vc", *a)\r
+        if clean:\r
+            nmake_tcl("clean")\r
+        elif install:\r
+            nmake_tcl("install", "INSTALLDIR=" + OUT_DIR)\r
+        else:\r
+            nmake_tcl()\r
+\r
+    if tk:\r
+        enter(TK_DIR)\r
+        def nmake_tk(*a):\r
+            nmake("makefile.vc", "TCLDIR=" + TCL_DIR, *a)\r
+        if clean:\r
+            nmake_tk("clean")\r
+        elif install:\r
+            nmake_tk("install", "INSTALLDIR=" + OUT_DIR)\r
+        else:\r
+            nmake_tk()\r
+\r
+    if tix:\r
+        enter(TIX_DIR)\r
+        def nmake_tix(*a):\r
+            nmake("python.mak",\r
+                  "TCL_MAJOR=%d" % TCL_MAJOR,\r
+                  "TCL_MINOR=%d" % TCL_MINOR,\r
+                  "TCL_PATCH=%d" % TCL_PATCH,\r
+                  "MACHINE=IX86", *a)\r
+        if clean:\r
+            nmake_tix("clean")\r
+        elif install:\r
+            nmake_tix("install", "INSTALL_DIR=" + OUT_DIR)\r
+        else:\r
+            nmake_tix()\r
+\r
+if __name__ == '__main__':\r
+    main()\r