Bug 470455 - test_database_sync_embed_visits.js leaks, r=sdwilsh
[wine-gecko.git] / modules / freetype2 / builds / mac / README
blobedd57b1da732ad4f68e448c76b8c2c503fc87742
1 This folder contains
3   * Makefile skeltons for Apple MPW (Macintosh's Programmers Workshop)
5   * Python script to generate MPW makefile from skelton
7   * Metrowerks CodeWarrior 9.0 project file in XML format
9 ------------------------------------------------------------
11 1. What is this
12 ---------------
14 Files in this directory are designed to build FreeType
15 running on classic MacOS. To build FreeType running on
16 Mac OS X, build as the system is UNIX.
18 However, Mac OS X is most useful to manipulate files in
19 vanilla FreeType to fit classic MacOS.
21 The information about MacOS specific API is written in
22 appendix of this document.
24 2. Requirement
25 --------------
27 You can use MPW: a free-charged developer environment
28 by Apple, or CodeWarrior: a commercial developer
29 environment by Metrowerks. GCC for MPW and Symantec
30 "Think C" are not tested at present.
33   2-1. Apple MPW
34   --------------
36   Following C compilers are tested:
38       m68k target:      Apple SC  8.9.0d3e1
39       ppc  target:      Apple MrC 5.0.0d3c1
41   The final MPW-GM (official release on 1999/Dec) is too
42   old and cannot compile FreeType, because bundled C
43   compilers cannot search header files in sub directories.
44   Updating by the final MPW-PR (pre-release on 2001/Feb)
45   is required.
47   Required files are downloadable from:
49       http://developer.apple.com/tools/mpw-tools/index.html
51   Also you can find documents how to update by MPW-PR.
53   Python is required to restore MPW makefiles from the
54   skeltons. Python bundled to Mac OS X is enough. For
55   classic MacOS, MacPython is available:
57       http://homepages.cwi.nl/~jack/macpython/
59   MPW requires all files are typed by resource fork.
60   ResEdit bundled to MPW is enough. In Mac OS X,
61   /Developer/Tools/SetFile of DevTool is useful to
62   manipulate from commandline.
64   2-2. Metrowerks CodeWarriror
65   ----------------------------
67   XML project file is generated and tested by
68   CodeWarriror 9.0.  Older versions are not tested
69   at all. At present, static library for ppc target
70   is available in the project file.
73 3. How to build
74 ---------------
76   3-1. Apple MPW
77   --------------
78   Detailed building procedure by Apple MPW is
79   described in following.
81     3-1-1. Generate MPW makefiles from the skeltons
82     ------------------------------------------------
84     Here are 4 skeltons for following targets are
85     included.
87     - FreeType.m68k_far.make.txt
88       Ancient 32bit binary executable format for
89       m68k MacOS: System 6, with 32bit addressing
90       mode (far-pointer-model) So-called "Toolbox"
91       API is used.
93     - FreeType.m68k_cfm.make.txt
94       CFM binary executable format for m68k MacOS:
95       System 7. So-called "Toolbox" API is used.
97     - FreeType.ppc_classic.make.txt
98       CFM binary executable format for ppc MacOS:
99       System 7, MacOS 8, MacOS 9. So-called "Toolbox"
100       API is used.
102     - FreeType.ppc_classic.make.txt
103       CFM binary executable format for ppc MacOS:
104       MacOS 9. Carbon API is used.
106     At present, static library is only supported,
107     although targets except of m68k_far are capable
108     to use shared library.
110     MPW makefile syntax uses 8bit characters. To keep
111     from violating them during version control, here
112     we store skeltons in pure ASCII format. You must
113     generate MPW makefile by Python script ascii2mpw.py.
115     In Mac OS X terminal, you can convert as:
117         python builds/mac/ascii2mpw.py \
118                 < builds/mac/FreeType.m68k_far.make.txt \
119                 > FreeType.m68k_far.make
121     The skeltons are designed to use in the top
122     directory where there are builds, include, src etc.
123     You must name the generated MPW makefile by removing
124     ".txt" from source skelton name.
126     3-1-2. Add resource forks to related files
127     ------------------------------------------
129     MPW's Make and C compilers cannot recognize files
130     without resource fork. You have to add resource
131     fork to the files that MPW uses. In Mac OS X
132     terminal of the system, you can do as:
134         find . -name '*.[ch]' -exec \
135                 /Developer/Tools/SetFile -a l -c "MPS " -t TEXT \{\} \;
137         find . -name '*.make' -exec \
138                 /Developer/Tools/SetFile -a l -c "MPS " -t TEXT \{\} \;
141     3-1-3. Open MPW shell and build
142     -------------------------------
144     Open MPW shell and go to the top directory that
145     FreeType sources are extracted (MPW makefile must
146     be located in there), from "Set Directory" in
147     "Directory" menu.
149     Choose "Build" from "Build" menu, and type the
150     name of project by removing ".make" from MPW
151     makefile, as: FreeType.m68k_far
153     If building is successfully finished, you can find
154     built library in objs/ directory.
157   3-2. Metrowerks CodeWarrior
158   ---------------------------
160   Detailed building procedure by Metrowerks
161   CodeWarrior (CW) 9.0 is described in following.
163     3-2-1. Import XML project file
164     ------------------------------
166     CW XML project file is not ready for double-
167     click. Start CodeWarrior IDE, and choose
168     "Import project" in "File" menu. Choose XML
169     project file: builds/mac/ftlib.prj.xml.
170     In next, you will be asked where to save CW
171     native project file: you must choose
172     "builds/mac/ftlib.prj". The project file is
173     designed with relative path from there. After
174     CW native project file is generated, it is
175     automatically loaded, small project window
176     titled "ftlib.prj" is displayed.
178     3-2-2. Building
179     ---------------
180     Choose "Make" from "Project" menu. If building
181     is successfully finished, you can find built
182     library at objs/FreeTypeLib.
184 4. TODO
185 -------
187   4-1. All modules should be included
188   -----------------------------------
190   At present, MPW makefiles and CW project file are
191   just updated versions of these by Leonard. Some
192   modules are added after the last maintenance, they
193   are not included.
195   4-2. Working test with ftdemos
196   ------------------------------
198   At present, MPW makefiles and CW project file can
199   build FreeType for classic MacOS. But their working
200   behaviours are not tested at all. Building ftdemos
201   for classic MacOS and working test is required.
203   4-3. Porting Jam onto MPW
204   -------------------------
206   FreeType uses Jam (and FT-Jam) for unified cross-
207   platform building tool. At present, Jam is not ported
208   to MPW. To update classic MacOS support easily,
209   building by Jam is expected on MPW.
212 APPENDIX I
213 ----------
215   A-1. Framework dependencies
216   ---------------------------
218   src/base/ftmac.c adds two Mac-specific features to
219   FreeType. These features are based on MacOS libraries.
221   * accessing resource-fork font
222   The fonts for classic MacOS store their graphical data
223   in resource forks which cannot be accessed via ANSI C
224   functions. FreeType2 provides functions to handle such
225   resource fork fonts, they are based on File Manager
226   framework of MacOS. In addition, HFS and HFS+ file
227   system driver of Linux is supported. Following
228   functions are for this purpose.
230     FT_New_Face_From_Resource()
231     FT_New_Face_From_FSSpec()
232     FT_New_Face_From_FSRef()
234   * resolving font name to font file
235   The font menu of MacOS application prefers font name
236   written in FOND resource than sfnt resource. FreeType2
237   provides functions to find font file by name in MacOS
238   application, they are based on QuickDraw Font Manager
239   and Apple Type Service framework of MacOS.
241     FT_GetFile_From_Mac_Name()
242     FT_GetFile_From_Mac_ATS_Name()
244   Working functions for each MacOS are summarized as
245   following.
247   upto MacOS 6:
248     not tested (you have to obtain MPW 2.x)
250   MacOS 7.x, 8.x, 9.x (without CarbonLib):
251     FT_GetFile_From_Mac_Name()
252     FT_New_Face_From_Resource()
253     FT_New_Face_From_FSSpec()
255   MacOS 9.x (with CarbonLib):
256     FT_GetFile_From_Mac_Name()
257     FT_New_Face_From_Resource()
258     FT_New_Face_From_FSSpec()
259     FT_New_Face_From_FSRef()
261   Mac OS X upto 10.4.x:
262     FT_GetFile_From_Mac_Name()     deprecated
263     FT_New_Face_From_FSSpec()      deprecated
264     FT_GetFile_From_Mac_ATS_Name() deprecated?
265     FT_New_Face_From_FSRef()
267   A-2. Deprecated Functions
268   -------------------------
270     A-2-1. FileManager
271     ------------------
273     For convenience to write MacOS application, ftmac.c
274     provides functions to specify a file by FSSpec and FSRef,
275     because the file identification pathname had ever been
276     unrecommended method in MacOS programming.
278     Toward to MacOS X 10.4 & 5, Carbon functions using FSSpec
279     datatype is noticed as deprecated, and recommended to
280     migrate to FSRef datatype. The big differences of FSRef
281     against FSSpec are explained in Apple TechNotes 2078.
283     http://developer.apple.com/technotes/tn2002/tn2078.html
285     - filename length: the max length of file
286     name of FSRef is 255 chars (it is limit of HFS+),
287     that of FSSpec is 31 chars (it is limit of HFS).
289     - filename encoding: FSSpec is localized by
290     legacy encoding for each language system,
291     FSRef is Unicode enabled.
293     A-2-2. FontManager
294     ------------------
296     Following functions receive QuickDraw fontname:
298       FT_GetFile_From_Mac_Name()
300     QuickDraw is deprecated and replaced by Quartz
301     since Mac OS X 10.4. They are still kept for
302     backward compatibility. By undefinition of
303     HAVE_QUICKDRAW in building, you can change these
304     functions to return FT_Err_Unimplemented always.
306     Replacement functions are added for migration.
308       FT_GetFile_From_Mac_ATS_Name()
310     They are usable on Mac OS X only. On older systems,
311     these functions return FT_Err_Unimplemented always.
313     The detailed incompatibilities and possibility
314     of FontManager emulation without QuickDraw is
315     explained in
317       http://www.gyve.org/~mpsuzuki/ats_benchmark.html
319   A-3. Framework Availabilities
320   -----------------------------
322   The framework of MacOS are often revised, especially
323   when new format of binary executable is introduced.
324   Following table is the minimum version of frameworks
325   to use functions used in FreeType2. The table is
326   extracted from MPW header files for assembly language.
328   *** NOTE ***
329   The conditional definition of available data type
330   in MPW compiler is insufficient. You can compile
331   program using FSRef data type for older systems
332   (MacOS 7, 8) that don't know FSRef data type.
335                                       +-------------------+-----------------------------+
336            CPU                        |      mc680x0      |           PowerPC           |
337                                       +---------+---------+---------+---------+---------+
338   Binary Executable Format            | Classic | 68K-CFM | CFM     | CFM     | Mach-O  |
339                                       +---------+---------+---------+---------+---------+
340        Framework API                  | Toolbox | Toolbox | Toolbox | Carbon  | Carbon  |
341                                       +---------+---------+---------+---------+---------+
343                                       +---------+---------+---------+---------+---------+
344                                       |    ?(*) |Interface|Interface|CarbonLib|Mac OS X |
345                                       |         |Lib      |Lib      |         |         |
346 * Files.h                             +---------+---------+---------+---------+---------+
347 PBGetFCBInfoSync()                    |    o    | 7.1-    | 7.1-    | 1.0-    |    o    |
348 FSMakeFSSpec()                        |    o    | 7.1-    | 7.1-    | 1.0-    |    o    |
349 FSGetForkCBInfo()                     |    o    |   (**)  | 9.0-    | 1.0-    |    o    |
350 FSpMakeFSRef()                        |    o    |   (**)  | 9.0-    | 1.0-    |    o    |
351 FSGetCatalogInfo()                    |    o    |   (**)  | 9.0-    | 1.0-    |   -10.3 |
352 FSPathMakeRef()                       |    x    |    x    |    x    | 1.1-    |   -10.3 |
353                                       +---------+---------+---------+---------+---------+
355                                       +---------+---------+---------+---------+---------+
356                                       |    ?(*) |Font     |Font     |CarbonLib|Mac OS X |
357                                       |         |Manager  |Manager  |         |         |
358 * Fonts.h                             +---------+---------+---------+---------+---------+
359 FMCreateFontFamilyIterator()          |    x    |    x    | 9.0-    | 1.0-    |   -10.3 |
360 FMDisposeFontFamilyIterator()         |    x    |    x    | 9.0-    | 1.0-    |   -10.3 |
361 FMGetNextFontFamily()                 |    x    |    x    | 9.0-    | 1.0-    |   -10.3 |
362 FMGetFontFamilyName()                 |    x    |    x    | 9.0-    | 1.0-    |   -10.3 |
363 FMCreateFontFamilyInstanceIterator()  |    x    |    x    | 9.0-    | 1.0-    |   -10.3 |
364 FMDisposeFontFamilyInstanceIterator() |    x    |    x    | 9.0-    | 1.0-    |   -10.3 |
365 FMGetNextFontFamilyInstance()         |    x    |    x    | 9.0-    | 1.0-    |   -10.3 |
366                                       +---------+---------+---------+---------+---------+
368                                       +---------+---------+---------+---------+---------+
369                                       |    -    |    -    |    -    |CarbonLib|Mac OS X |
370 * ATSFont.h (***)                     +---------+---------+---------+---------+---------+
371 ATSFontFindFromName()                 |    x    |    x    |    x    |    x    |    o    |
372 ATSFontGetFileSpecification()         |    x    |    x    |    x    |    x    |    o    |
373                                       +---------+---------+---------+---------+---------+
375     (*)
376     In the "Classic": the original binary executable
377     format, these framework functions are directly
378     transformed to MacOS system call. Therefore, the
379     exact availability should be checked by running
380     system.
382     (**)
383     InterfaceLib is bundled to MacOS and its version
384     is usually equal to MacOS. There's no separate
385     update for InterfaceLib. It is supposed that
386     there's no InterfaceLib 9.x for m68k platforms.
387     In fact, these functions are FSRef dependent.
389     (***)
390     ATSUI framework is available on ATSUnicode 8.5 on
391     ppc Toolbox CFM, CarbonLib 1.0 too. But its base:
392     ATS font manager is not published in these versions.
394 ------------------------------------------------------------
395 Last update: 2007-Feb-01, by Alexei Podtelezhnikov.
397 Currently maintained by
398         suzuki toshiya, <mpsuzuki@hiroshima-u.ac.jp>
399 Originally prepared by
400         Leonard Rosenthol, <leonardr@lazerware.com>
401         Just van Rossum, <just@letterror.com>
403 This directory is now actively maintained as part of the FreeType Project.