Jack Jansen | 9de05f4 | 2001-03-20 23:30:38 +0000 | [diff] [blame] | 1 | Changes in 2.1b2 since 2.0 |
Jack Jansen | 538bd13 | 2000-10-19 21:58:27 +0000 | [diff] [blame] | 2 | -------------------------- |
Jack Jansen | ecbc1cc | 1998-01-06 12:13:16 +0000 | [diff] [blame] | 3 | |
Jack Jansen | 26d7c14 | 2000-09-11 22:47:12 +0000 | [diff] [blame] | 4 | These release notes refer to Mac-specific changes only. See NEWS (in the Misc folder) |
Jack Jansen | 9de05f4 | 2001-03-20 23:30:38 +0000 | [diff] [blame] | 5 | for machine-independent changes. Changes since 2.1b1 are |
Jack Jansen | cbe7b1c | 2001-03-06 22:42:12 +0000 | [diff] [blame] | 6 | marked with [*] and at the bottom of the list. |
Jack Jansen | ecbc1cc | 1998-01-06 12:13:16 +0000 | [diff] [blame] | 7 | |
Jack Jansen | 9de05f4 | 2001-03-20 23:30:38 +0000 | [diff] [blame] | 8 | - This release is Carbon-based, so it runs natively on MacOS 8.6 or |
Jack Jansen | 2b73fe9 | 2001-03-27 21:38:55 +0000 | [diff] [blame] | 9 | later and MacOSX. (Note that on MacOSX MacPython will run as a normal Mac application, |
| 10 | if you want to run Python from the BSD commandline get a unix-Python distribution |
| 11 | from www.python.org). |
Jack Jansen | cbe7b1c | 2001-03-06 22:42:12 +0000 | [diff] [blame] | 12 | - Alternatively there is a classic PPC interpreter as well. There are two reasons you |
| 13 | might want to use this: (a) you have a pre-MacOS9 system and don't want to install |
| 14 | CarbonLib, or (b) you need Tkinter, for which no Carbon version is available yet. |
Jack Jansen | 2f9a9e3 | 2001-02-17 22:03:42 +0000 | [diff] [blame] | 15 | - Distutils is included and seems to work. |
| 16 | - There's a new module (package, actually) mkcwproject which builds CodeWarrior |
| 17 | projects from simple templates. See Distutils or :Mac:scripts:genpluginprojects.py |
| 18 | for examples of use. |
Jack Jansen | 2b73fe9 | 2001-03-27 21:38:55 +0000 | [diff] [blame] | 19 | - The Numerical extension has moved to :Lib:site-python from :Extensions. As Numerical |
| 20 | is now distutils-based you can easily install newer versions when they become |
| 21 | available. |
Jack Jansen | 2f9a9e3 | 2001-02-17 22:03:42 +0000 | [diff] [blame] | 22 | - Windows and Dialogs can now be different beasts, so you may have to call |
| 23 | dlg.GetDialogWindow() where you used to be able to call window methods straight |
| 24 | on the dialog. This also has consequences for code using FrameWork.DialogWindow. |
| 25 | THIS IS AN INCOMPATIBLE CHANGE. |
| 26 | - ctl.GetControlDataHandle() has been renamed to GetControlData_Handle(), and similarly |
| 27 | for the other variants of GetControlData and SetControlData. This was needed |
| 28 | because Carbon defines a completely different routine with the name GetControlDataHandle. |
| 29 | THIS IS AN INCOMPATIBLE CHANGE. |
| 30 | - Method mac.xstat() has disappeared. THIS IS AN INCOMPATIBLE CHANGE. |
| 31 | - Menu.SetPopupData() and GetPopupData() are gone. Use SetPopupMenuHandle() and |
| 32 | SetPopupMenuID() (and the getters) in stead. THIS IS AN INCOMPATIBLE CHANGE. |
| 33 | - Various methods have disappeared when running under Carbon. The script |
| 34 | :Mac:scripts:missingcarbonmethods.py can check your sources, but you need unix to run |
| 35 | it. Or use it as documentation and search by hand. THIS IS AN INCOMPATIBLE CHANGE. |
| 36 | - The good news is that "direct access to toolbox structs" still works from Python, |
| 37 | so Python programmers have a lot less to fix than C programmers. |
| 38 | That's because the lowlevel code simply uses the accessors internally. The accessors |
| 39 | are available both in Carbon and Classic MacPython. |
| 40 | - Scrap under Carbon is, you guessed it, the Carbon Scrap Manager. Some workarounds are |
| 41 | provided, though. THIS IS AN INCOMPATIBLE CHANGE. |
| 42 | - The Internet Config routines that are missing from Carbon have been removed. This |
| 43 | is no problem if you use the "ic" module, but may be if you use "icglue" directly. |
| 44 | THIS IS AN INCOMPATIBLE CHANGE. |
| 45 | - Various old toolbox names (CountMItems, EnableItem, etc) have disappeared. Use the |
| 46 | new forms (CountMenuItems, EnableMenuItem, etc). THIS IS AN INCOMPATIBLE CHANGE. |
| 47 | - Waste now uses Waste 2.0. |
| 48 | - The default memory size for the interpreter has been upped again. |
| 49 | - The MacOS error messages have been updated to reflect the current state of |
| 50 | things. This was long overdue. |
| 51 | - The crash in BuildApplication has been fixed. |
| 52 | - struct.pack related problems (in Audio_Mac, for example) have been fixed. |
| 53 | - (src/dev/cvs only): The project files now use the .mcp extension in stead of .prj. |
| 54 | Projects for almost all plugins and the img modules are automatically generated |
| 55 | with :Mac:scripts:genpluginprojects.py (also called by fullbuild). The .mcp files |
| 56 | are not in the repository, if you don't want to use genpluginprojects you can import |
| 57 | the .mcp.xml files in CodeWarrior. |
Jack Jansen | 24033e3 | 2001-02-27 23:24:07 +0000 | [diff] [blame] | 58 | - ConfigurePython has been replace by two applets: ConfigurePythonClassic and |
| 59 | ConfigurePythonCarbon. These will select either execution model for machines |
Jack Jansen | 9de05f4 | 2001-03-20 23:30:38 +0000 | [diff] [blame] | 60 | supporting both, and it will also build all the standard applets. |
Jack Jansen | cbe7b1c | 2001-03-06 22:42:12 +0000 | [diff] [blame] | 61 | - PythonInterpreterCarbon and PythonInterpreterClassic are now files of type "Atmp", not |
| 62 | "APPL", so there should not be any confusion as to what the real application is |
Jack Jansen | 9de05f4 | 2001-03-20 23:30:38 +0000 | [diff] [blame] | 63 | (PythonInterpreter). |
| 64 | - A BBEdit language module by Chris Stern is included in the :Mac:Contrib folder. |
Jack Jansen | 8ef786e | 2001-03-15 14:27:09 +0000 | [diff] [blame] | 65 | - The ConfigurePython applets will now detect if the preference file refers to a different |
Jack Jansen | 9de05f4 | 2001-03-20 23:30:38 +0000 | [diff] [blame] | 66 | folder than where they live. They offer to remove the preference file in this case. |
| 67 | - Import case-check was broken in 2.1b1, this is fixed. [*] |
| 68 | - A side-effect of the previous fix is that getpass works again. [*] |
| 69 | - BuildApplication was broken under Carbon. Fixed. [*] |
Jack Jansen | 46e1302 | 2000-09-24 22:01:53 +0000 | [diff] [blame] | 70 | |
Jack Jansen | 26d7c14 | 2000-09-11 22:47:12 +0000 | [diff] [blame] | 71 | |
| 72 | What is not in this distribution |
| 73 | -------------------------------- |
| 74 | |
Jack Jansen | 2f9a9e3 | 2001-02-17 22:03:42 +0000 | [diff] [blame] | 75 | - The garbage collection mods have not been enabled, mainly due to lack of test-time. |
Jack Jansen | 8ef786e | 2001-03-15 14:27:09 +0000 | [diff] [blame] | 76 | - Stackless Python/microthreads hasn't been ported to 2.1 yet. If/when it becomes available |
Jack Jansen | de51909 | 2000-10-12 21:21:43 +0000 | [diff] [blame] | 77 | Just will undoubtedly announce it on pythonmac-sig and the MacPython homepage. |
Jack Jansen | 26d7c14 | 2000-09-11 22:47:12 +0000 | [diff] [blame] | 78 | |
| 79 | Known problems |
| 80 | -------------- |
| 81 | |
| 82 | This list is far from complete, more problems may be listed on the MacPython homepage, |
| 83 | http://www.cwi.nl/~jack/macpython.html. |
| 84 | |
Jack Jansen | 9de05f4 | 2001-03-20 23:30:38 +0000 | [diff] [blame] | 85 | - Tkinter does not work under Carbon. |
Jack Jansen | 26d7c14 | 2000-09-11 22:47:12 +0000 | [diff] [blame] | 86 | - The IDE and Tkinter do not work together. Run tkinter programs under PythonInterpreter. |
Jack Jansen | 4c52203 | 2001-03-08 23:07:16 +0000 | [diff] [blame] | 87 | - After running a Tkinter program your menubar may end up dead, with command-alt-escape |
| 88 | the only way to terminate Python. |
| 89 | - Tkinter file events do not work, unless you have opened the file through Tcl (but then |
| 90 | you cannot access it from Python). |
Jack Jansen | 26d7c14 | 2000-09-11 22:47:12 +0000 | [diff] [blame] | 91 | - Aliases do not work in sys.path entries. |
Jack Jansen | 2f9a9e3 | 2001-02-17 22:03:42 +0000 | [diff] [blame] | 92 | - The menu bar isn't always correctly restored before MacPython turns to <<terminated>>. |
| 93 | - Under Carbon only you may occasionally see a spurious KeyboardInterrupt. I have absolutely |
| 94 | no clue as to what is causing this. |
Jack Jansen | 4c52203 | 2001-03-08 23:07:16 +0000 | [diff] [blame] | 95 | - PythonInterpreter used interactively will eat a lot of processor cycles. You should use |
| 96 | PythonIDE for interactive work and PythonInterpreter for scripts only. |
Jack Jansen | 8ef786e | 2001-03-15 14:27:09 +0000 | [diff] [blame] | 97 | - Under MacOSX Public Beta ConfigurePython cannot put PythonCore in the global CFMSupport |
| 98 | folder. Therefore applets have to live in the Python folder, otherwise they cannot find |
| 99 | PythonCore. There is a workaround if you want to have an applet in a different folder: |
| 100 | put an alias PythonCoreCarbon (pointing to the PythonCoreCarbon in the Python folder) |
| 101 | in the same folder as your applet. |
| 102 | This problem should in all probability not occur in the release version of MacOSX. |