topical media & game development
lib-of-vs-libs-QTDevWin-CIncludes-Script.h / h
/*
File: Script.h
Contains: Script Manager interfaces
Version: Technology: Mac OS 8
Release: QuickTime 6.0.2
Copyright: (c) 1986-2001 by Apple Computer, Inc., all rights reserved
Bugs?: For bug reports, consult the following page on
the World Wide Web:
http://developer.apple.com/bugreporter/
*/
ifndef __SCRIPT__
define __SCRIPT__
ifndef __MACTYPES__
include <MacTypes.h>
endif
ifndef __QUICKDRAW__
include <Quickdraw.h>
endif
ifndef __INTLRESOURCES__
include <IntlResources.h>
endif
ifndef __EVENTS__
include <Events.h>
endif
if PRAGMA_ONCE
#pragma once
endif
ifdef __cplusplus
extern "C" {
endif
if PRAGMA_IMPORT
#pragma import on
endif
if PRAGMA_STRUCT_ALIGN
#pragma options align=mac68k
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(push, 2)
#elif PRAGMA_STRUCT_PACK
#pragma pack(2)
endif
/* Meta script codes:*/
enum {
smSystemScript = -1, /* designates system script.*/
smCurrentScript = -2, /* designates current font script.*/
smAllScripts = -3 /* designates any script*/
};
/*
Script codes:
These specify a Mac OS encoding that is related to a FOND ID range.
Some of the encodings have several variants (e.g. for different localized systems)
which all share the same script code.
Not all of these script codes are currently supported by Apple software.
Notes:
- Script code 0 (smRoman) is also used (instead of smGreek) for the Greek encoding
in the Greek localized system.
- Script code 28 (smEthiopic) is also used for the Inuit encoding in the Inuktitut
system.
*/
enum {
smRoman = 0,
smJapanese = 1,
smTradChinese = 2, /* Traditional Chinese*/
smKorean = 3,
smArabic = 4,
smHebrew = 5,
smGreek = 6,
smCyrillic = 7,
smRSymbol = 8, /* Right-left symbol*/
smDevanagari = 9,
smGurmukhi = 10,
smGujarati = 11,
smOriya = 12,
smBengali = 13,
smTamil = 14,
smTelugu = 15,
smKannada = 16, /* Kannada/Kanarese*/
smMalayalam = 17,
smSinhalese = 18,
smBurmese = 19,
smKhmer = 20, /* Khmer/Cambodian*/
smThai = 21,
smLao = 22,
smGeorgian = 23,
smArmenian = 24,
smSimpChinese = 25, /* Simplified Chinese*/
smTibetan = 26,
smMongolian = 27,
smEthiopic = 28,
smGeez = 28, /* Synonym for smEthiopic*/
smCentralEuroRoman = 29, /* For Czech, Slovak, Polish, Hungarian, Baltic langs*/
smVietnamese = 30,
smExtArabic = 31, /* extended Arabic*/
smUninterp = 32 /* uninterpreted symbols, e.g. palette symbols*/
};
/* Extended script code for full Unicode input*/
enum {
smUnicodeScript = 0x7E
};
/* Obsolete script code names (kept for backward compatibility):*/
enum {
smChinese = 2, /* (Use smTradChinese or smSimpChinese)*/
smRussian = 7, /* Use smCyrillic*/
/* smMaldivian = 25: deleted, no code for Maldivian*/
smLaotian = 22, /* Use smLao */
smAmharic = 28, /* Use smEthiopic or smGeez*/
smSlavic = 29, /* Use smCentralEuroRoman*/
smEastEurRoman = 29, /* Use smCentralEuroRoman*/
smSindhi = 31, /* Use smExtArabic*/
smKlingon = 32
};
/*
Language codes:
These specify a language implemented using a particular Mac OS encoding.
Not all of these language codes are currently supported by Apple software.
*/
enum {
langEnglish = 0, /* smRoman script*/
langFrench = 1, /* smRoman script*/
langGerman = 2, /* smRoman script*/
langItalian = 3, /* smRoman script*/
langDutch = 4, /* smRoman script*/
langSwedish = 5, /* smRoman script*/
langSpanish = 6, /* smRoman script*/
langDanish = 7, /* smRoman script*/
langPortuguese = 8, /* smRoman script*/
langNorwegian = 9, /* smRoman script*/
langHebrew = 10, /* smHebrew script*/
langJapanese = 11, /* smJapanese script*/
langArabic = 12, /* smArabic script*/
langFinnish = 13, /* smRoman script*/
langGreek = 14, /* Greek script using smRoman script code*/
langIcelandic = 15, /* modified smRoman/Icelandic script*/
langMaltese = 16, /* Roman script*/
langTurkish = 17, /* modified smRoman/Turkish script*/
langCroatian = 18, /* modified smRoman/Croatian script*/
langTradChinese = 19, /* Chinese (Mandarin) in traditional characters*/
langUrdu = 20, /* smArabic script*/
langHindi = 21, /* smDevanagari script*/
langThai = 22, /* smThai script*/
langKorean = 23 /* smKorean script*/
};
enum {
langLithuanian = 24, /* smCentralEuroRoman script*/
langPolish = 25, /* smCentralEuroRoman script*/
langHungarian = 26, /* smCentralEuroRoman script*/
langEstonian = 27, /* smCentralEuroRoman script*/
langLatvian = 28, /* smCentralEuroRoman script*/
langSami = 29, /* language of the Sami people of N. Scandinavia */
langFaroese = 30, /* modified smRoman/Icelandic script */
langFarsi = 31, /* modified smArabic/Farsi script*/
langPersian = 31, /* Synonym for langFarsi*/
langRussian = 32, /* smCyrillic script*/
langSimpChinese = 33, /* Chinese (Mandarin) in simplified characters*/
langFlemish = 34, /* smRoman script*/
langIrishGaelic = 35, /* smRoman or modified smRoman/Celtic script (without dot above) */
langAlbanian = 36, /* smRoman script*/
langRomanian = 37, /* modified smRoman/Romanian script*/
langCzech = 38, /* smCentralEuroRoman script*/
langSlovak = 39, /* smCentralEuroRoman script*/
langSlovenian = 40, /* modified smRoman/Croatian script*/
langYiddish = 41, /* smHebrew script*/
langSerbian = 42, /* smCyrillic script*/
langMacedonian = 43, /* smCyrillic script*/
langBulgarian = 44, /* smCyrillic script*/
langUkrainian = 45, /* modified smCyrillic/Ukrainian script*/
langByelorussian = 46, /* smCyrillic script*/
langBelorussian = 46 /* Synonym for langByelorussian */
};
enum {
langUzbek = 47, /* Cyrillic script*/
langKazakh = 48, /* Cyrillic script*/
langAzerbaijani = 49, /* Azerbaijani in Cyrillic script*/
langAzerbaijanAr = 50, /* Azerbaijani in Arabic script*/
langArmenian = 51, /* smArmenian script*/
langGeorgian = 52, /* smGeorgian script*/
langMoldavian = 53, /* smCyrillic script*/
langKirghiz = 54, /* Cyrillic script*/
langTajiki = 55, /* Cyrillic script*/
langTurkmen = 56, /* Cyrillic script*/
langMongolian = 57, /* Mongolian in smMongolian script*/
langMongolianCyr = 58, /* Mongolian in Cyrillic script*/
langPashto = 59, /* Arabic script*/
langKurdish = 60, /* smArabic script*/
langKashmiri = 61, /* Arabic script*/
langSindhi = 62, /* Arabic script*/
langTibetan = 63, /* smTibetan script*/
langNepali = 64, /* smDevanagari script*/
langSanskrit = 65, /* smDevanagari script*/
langMarathi = 66, /* smDevanagari script*/
langBengali = 67, /* smBengali script*/
langAssamese = 68, /* smBengali script*/
langGujarati = 69, /* smGujarati script*/
langPunjabi = 70 /* smGurmukhi script*/
};
enum {
langOriya = 71, /* smOriya script*/
langMalayalam = 72, /* smMalayalam script*/
langKannada = 73, /* smKannada script*/
langTamil = 74, /* smTamil script*/
langTelugu = 75, /* smTelugu script*/
langSinhalese = 76, /* smSinhalese script*/
langBurmese = 77, /* smBurmese script*/
langKhmer = 78, /* smKhmer script*/
langLao = 79, /* smLao script*/
langVietnamese = 80, /* smVietnamese script*/
langIndonesian = 81, /* smRoman script*/
langTagalog = 82, /* Roman script*/
langMalayRoman = 83, /* Malay in smRoman script*/
langMalayArabic = 84, /* Malay in Arabic script*/
langAmharic = 85, /* smEthiopic script*/
langTigrinya = 86, /* smEthiopic script*/
langOromo = 87, /* smEthiopic script*/
langSomali = 88, /* smRoman script*/
langSwahili = 89, /* smRoman script*/
langKinyarwanda = 90, /* smRoman script*/
langRuanda = 90, /* synonym for langKinyarwanda*/
langRundi = 91, /* smRoman script*/
langNyanja = 92, /* smRoman script*/
langChewa = 92, /* synonym for langNyanja*/
langMalagasy = 93, /* smRoman script*/
langEsperanto = 94 /* Roman script*/
};
enum {
langWelsh = 128, /* modified smRoman/Celtic script*/
langBasque = 129, /* smRoman script*/
langCatalan = 130, /* smRoman script*/
langLatin = 131, /* smRoman script*/
langQuechua = 132, /* smRoman script*/
langGuarani = 133, /* smRoman script*/
langAymara = 134, /* smRoman script*/
langTatar = 135, /* Cyrillic script*/
langUighur = 136, /* Arabic script*/
langDzongkha = 137, /* (lang of Bhutan) smTibetan script*/
langJavaneseRom = 138, /* Javanese in smRoman script*/
langSundaneseRom = 139, /* Sundanese in smRoman script*/
langGalician = 140, /* smRoman script*/
langAfrikaans = 141 /* smRoman script */
};
enum {
langBreton = 142, /* smRoman or modified smRoman/Celtic script */
langInuktitut = 143, /* Inuit script using smEthiopic script code */
langScottishGaelic = 144, /* smRoman or modified smRoman/Celtic script */
langManxGaelic = 145, /* smRoman or modified smRoman/Celtic script */
langIrishGaelicScript = 146, /* modified smRoman/Gaelic script (using dot above) */
langTongan = 147, /* smRoman script */
langGreekPoly = 148, /* smGreek script */
langGreenlandic = 149 /* smRoman script */
};
enum {
langUnspecified = 32767 /* Special code for use in resources (such as 'itlm') */
};
/*
Obsolete language code names (kept for backward compatibility):
Misspelled, ambiguous, misleading, considered pejorative, archaic, etc.
*/
enum {
langPortugese = 8, /* Use langPortuguese*/
langMalta = 16, /* Use langMaltese*/
langYugoslavian = 18, /* (use langCroatian, langSerbian, etc.)*/
langChinese = 19, /* (use langTradChinese or langSimpChinese)*/
langLettish = 28, /* Use langLatvian */
langLapponian = 29, /* Use langSami*/
langLappish = 29, /* Use langSami*/
langSaamisk = 29, /* Use langSami */
langFaeroese = 30, /* Use langFaroese */
langIrish = 35, /* Use langIrishGaelic */
langGalla = 87, /* Use langOromo */
langAfricaans = 141 /* Use langAfrikaans */
};
/*
Region codes:
These typically specify a combination of a language code and a particular region.
Some of these numeric values are reserved just for extra resource IDs associated
with certain regions; these are not actual region codes, and are noted in the comments.
Not all of the region codes are currently supported by Apple software.
When relevant, the following list also provides:
- The Apple part number (P/N) code for software localized for the specified region.
- The two-letter ISO language and country codes (from ISO 639 and ISO 3166). The
language code (lowercase) is first, then '_', then the country code (uppercase).
*/
enum {
/* P/N ISO codes comments*/
verUS = 0, /* en_US*/
verFrance = 1, /* F fr_FR*/
verBritain = 2, /* B en_GB*/
verGermany = 3, /* D de_DE*/
verItaly = 4, /* T it_IT*/
verNetherlands = 5, /* N nl_NL*/
verFlemish = 6, /* FN nl_BE Flemish (Dutch) for Belgium */
verSweden = 7, /* S sv_SE*/
verSpain = 8, /* E es_ES Spanish for Spain*/
verDenmark = 9, /* DK da_DK*/
verPortugal = 10, /* PO pt_PT Portuguese for Portugal*/
verFrCanada = 11, /* C fr_CA French for Canada*/
verNorway = 12, /* H no_NO Bokm.l*/
verIsrael = 13, /* HB iw_IL Hebrew*/
verJapan = 14, /* J ja_JP*/
verAustralia = 15, /* X en_AU English for Australia*/
verArabic = 16, /* AB ar Arabic for N Africa, Arabian peninsula, Levant*/
verFinland = 17, /* K fi_FI*/
verFrSwiss = 18, /* SF fr_CH French Swiss*/
verGrSwiss = 19, /* SD de_CH German Swiss*/
verGreece = 20, /* GR el_GR Monotonic Greek (modern)*/
verIceland = 21, /* IS is_IS*/
verMalta = 22, /* MA mt_MT*/
verCyprus = 23, /* CY _CY Greek or Turkish language? Checking...*/
verTurkey = 24, /* TU tr_TR*/
verYugoCroatian = 25 /* YU Croatian for Yugoslavia; now use verCroatia (68)*/
};
enum {
verNetherlandsComma = 26, /* ID for KCHR resource - Dutch*/
verBelgiumLuxPoint = 27, /* ID for KCHR resource - Belgium*/
verCanadaComma = 28, /* ID for KCHR resource - Canadian ISO*/
verCanadaPoint = 29, /* ID for KCHR resource - Canadian; now unused*/
vervariantPortugal = 30, /* ID for resource; now unused*/
vervariantNorway = 31, /* ID for resource; now unused*/
vervariantDenmark = 32 /* ID for KCHR resource - Danish Mac Plus*/
};
enum {
verIndiaHindi = 33, /* hi_IN Hindi for India*/
verPakistanUrdu = 34, /* UR ur_PK Urdu for Pakistan */
verTurkishModified = 35,
verItalianSwiss = 36, /* ST it_CH Italian Swiss*/
verInternational = 37, /* Z en English for international use */
/* 38 is unassigned*/
verRomania = 39, /* RO ro_RO*/
verGreecePoly = 40, /* Polytonic Greek (classical) */
verLithuania = 41, /* LT lt_LT*/
verPoland = 42, /* PL pl_PL*/
verHungary = 43, /* MG hu_HU*/
verEstonia = 44, /* EE et_EE*/
verLatvia = 45, /* LV lv_LV*/
verSami = 46, /* se */
verFaroeIsl = 47, /* FA fo_FO */
verIran = 48, /* PS fa_IR Persian/Farsi*/
verRussia = 49, /* RS ru_RU Russian*/
verIreland = 50, /* GA ga_IE Irish Gaelic for Ireland (without dot above) */
verKorea = 51, /* KH ko_KR*/
verChina = 52, /* CH zh_CN Simplified Chinese*/
verTaiwan = 53, /* TA zh_TW Traditional Chinese*/
verThailand = 54, /* TH th_TH*/
verScriptGeneric = 55, /* SS Generic script system (no language or script) */
verCzech = 56, /* CZ cs_CZ*/
verSlovak = 57, /* SL sk_SK*/
verFarEastGeneric = 58, /* FE Generic Far East system (no language or script) */
verMagyar = 59, /* Unused; see verHungary*/
verBengali = 60, /* bn Bangladesh or India*/
verByeloRussian = 61 /* BY be_BY*/
};
enum {
verUkraine = 62, /* UA uk_UA*/
/* 63 is unassigned*/
verGreeceAlt = 64, /* unused */
verSerbian = 65, /* SR sr_YU, sh_YU */
verSlovenian = 66, /* SV sl_SI */
verMacedonian = 67, /* MD mk_MK */
verCroatia = 68, /* CR hr_HR, sh_HR*/
/* 69 is unassigned*/
/* 70 is unassigned*/
verBrazil = 71, /* BR pt_BR Portuguese for Brazil*/
verBulgaria = 72, /* BG bg_BG*/
verCatalonia = 73, /* CA ca_ES Catalan for Spain*/
verMultilingual = 74, /* ZM (no language or script)*/
verScottishGaelic = 75, /* GD gd*/
verManxGaelic = 76, /* GV gv Isle of Man*/
verBreton = 77, /* BZ br*/
verNunavut = 78, /* IU iu_CA Inuktitut for Canada*/
verWelsh = 79, /* CU cy*/
/* 80 is ID for KCHR resource - Canadian CSA*/
verIrishGaelicScript = 81, /* GS ga_IE Irish Gaelic for Ireland (using dot above)*/
verEngCanada = 82, /* V en_CA English for Canada*/
verBhutan = 83, /* BH dz_BT Dzongkha for Bhutan*/
verArmenian = 84, /* HY hy_AM*/
verGeorgian = 85, /* KR ka_GE*/
verSpLatinAmerica = 86, /* LA es Spanish for Latin America*/
/* 87 is ID for KCHR resource - Spanish ISO*/
verTonga = 88, /* TS to_TO*/
/* 89 is ID for KCHR resource - Polish Modified*/
/* 90 is ID for KCHR resource - Catalan ISO*/
verFrenchUniversal = 91, /* fr French generic*/
verAustria = 92, /* AU de_AT German for Austria*/
/* Y 93 is unused alternate for verSpLatinAmerica*/
verGujarati = 94, /* gu_IN*/
verPunjabi = 95, /* pa Pakistan or India*/
verIndiaUrdu = 96, /* ur_IN Urdu for India*/
verVietnam = 97 /* vi_VN*/
};
enum {
verFrBelgium = 98, /* BF fr_BE French for Belgium */
verUzbek = 99, /* BD uz_UZ */
verSingapore = 100, /* SG */
verNynorsk = 101, /* NY _NO Norwegian Nynorsk */
verAfrikaans = 102, /* AK af_ZA */
verEsperanto = 103, /* eo */
verMarathi = 104, /* mr_IN */
verTibetan = 105, /* bo */
verNepal = 106, /* ne_NP */
verGreenland = 107 /* kl */
};
/*
Other extra resource IDs assigned in the same number space:
179 is ID for KCHR & itl_ resources - Cornish
581 is ID for KCHR resource - Irish Gaelic script alternate
582 is ID for KCHR resource - Ogham
779 is ID for KCHR resource - Welsh alternate
1111 is ID for KCHR resource - French numeric
*/
/*
Obsolete region code names (kept for backward compatibility):
Misspelled or alternate form, ambiguous, misleading, considered pejorative, archaic, etc.
*/
enum {
verFrBelgiumLux = 6, /* Incorrect; 6 is Flemish, not French, for Belgium; use verFlemish */
verBelgiumLux = 6, /* Use verFlemish*/
verArabia = 16, /* Use verArabic*/
verYugoslavia = 25, /* Use verYugoCroatian (same number, now unused), or newer verCroatia*/
verIndia = 33, /* Use verIndiaHindi*/
verPakistan = 34, /* Use verPakistanUrdu */
verRumania = 39, /* Alternate for verRomania */
verGreekAncient = 40, /* Use verGreecePoly */
verLapland = 46, /* Use verSami */
verFaeroeIsl = 47, /* Use verFaroeIsl */
verGenericFE = 58, /* Use verFarEastGeneric */
verBelarus = 61, /* Alternate for verByelorussian */
verUkrania = 62, /* Use verUkraine*/
verAlternateGr = 64, /* Use verGreeceAlt */
verSerbia = 65, /* Alternate for verSerbian */
verSlovenia = 66, /* Alternate for verSlovenian */
verMacedonia = 67, /* Alternate for verMacedonian */
verBrittany = 77, /* Alternate for verBreton */
verWales = 79, /* Alternate for verWelsh */
verArmenia = 84, /* Alternate for verArmenian */
verGeorgia = 85, /* Alternate for verGeorgian */
verAustriaGerman = 92, /* Use verAustria */
verTibet = 105 /* Use verTibetan */
};
enum {
minCountry = verUS,
maxCountry = verGreenland
};
enum {
/* Calendar Codes */
calGregorian = 0,
calArabicCivil = 1,
calArabicLunar = 2,
calJapanese = 3,
calJewish = 4,
calCoptic = 5,
calPersian = 6
};
enum {
/* Integer Format Codes */
intWestern = 0,
intArabic = 1,
intRoman = 2,
intJapanese = 3,
intEuropean = 4,
intOutputMask = 0x8000
};
enum {
/* CharByte byte types */
smSingleByte = 0,
smFirstByte = -1,
smLastByte = 1,
smMiddleByte = 2
};
enum {
/* CharType field masks */
smcTypeMask = 0x000F,
smcReserved = 0x00F0,
smcClassMask = 0x0F00,
smcOrientationMask = 0x1000, /*two-byte script glyph orientation*/
smcRightMask = 0x2000,
smcUpperMask = 0x4000,
smcDoubleMask = 0x8000
};
enum {
/* Basic CharType character types */
smCharPunct = 0x0000,
smCharAscii = 0x0001,
smCharEuro = 0x0007,
smCharExtAscii = 0x0007, /* More correct synonym for smCharEuro */
/* Additional CharType character types for script systems */
smCharKatakana = 0x0002, /*Japanese Katakana*/
smCharHiragana = 0x0003, /*Japanese Hiragana*/
smCharIdeographic = 0x0004, /*Hanzi, Kanji, Hanja*/
smCharTwoByteGreek = 0x0005, /*2-byte Greek in Far East systems*/
smCharTwoByteRussian = 0x0006, /*2-byte Cyrillic in Far East systems*/
smCharBidirect = 0x0008, /*Arabic/Hebrew*/
smCharContextualLR = 0x0009, /*Contextual left-right: Thai, Indic scripts*/
smCharNonContextualLR = 0x000A, /*Non-contextual left-right: Cyrillic, Greek*/
smCharHangul = 0x000C, /*Korean Hangul*/
smCharJamo = 0x000D, /*Korean Jamo*/
smCharBopomofo = 0x000E, /*Chinese Bopomofo*/
smCharGanaKana = 0x000F, /*Shared for Japanese Hiragana & Katakana*/
/* old names for some of above, for backward compatibility */
smCharFISKana = 0x0002, /*Katakana*/
smCharFISGana = 0x0003, /*Hiragana*/
smCharFISIdeo = 0x0004 /*Hanzi, Kanji, Hanja*/
};
enum {
smCharFISGreek = 0x0005, /*2-byte Greek in Far East systems*/
smCharFISRussian = 0x0006, /*2-byte Cyrillic in Far East systems*/
/* CharType classes for punctuation (smCharPunct) */
smPunctNormal = 0x0000,
smPunctNumber = 0x0100,
smPunctSymbol = 0x0200,
smPunctBlank = 0x0300, /* Additional CharType classes for punctuation in two-byte systems */
smPunctRepeat = 0x0400, /* repeat marker */
smPunctGraphic = 0x0500, /* line graphics */
/* CharType Katakana and Hiragana classes for two-byte systems */
smKanaSmall = 0x0100, /*small kana character*/
smKanaHardOK = 0x0200, /*can have dakuten*/
smKanaSoftOK = 0x0300, /*can have dakuten or han-dakuten*/
/* CharType Ideographic classes for two-byte systems */
smIdeographicLevel1 = 0x0000, /*level 1 char*/
smIdeographicLevel2 = 0x0100, /*level 2 char*/
smIdeographicUser = 0x0200, /*user char*/
/* old names for above, for backward compatibility */
smFISClassLvl1 = 0x0000, /*level 1 char*/
smFISClassLvl2 = 0x0100, /*level 2 char*/
smFISClassUser = 0x0200, /*user char*/
/* CharType Jamo classes for Korean systems */
smJamoJaeum = 0x0000, /*simple consonant char*/
smJamoBogJaeum = 0x0100, /*complex consonant char*/
smJamoMoeum = 0x0200, /*simple vowel char*/
smJamoBogMoeum = 0x0300 /*complex vowel char*/
};
enum {
/* CharType glyph orientation for two-byte systems */
smCharHorizontal = 0x0000, /* horizontal character form, or for both */
smCharVertical = 0x1000, /* vertical character form */
/* CharType directions */
smCharLeft = 0x0000,
smCharRight = 0x2000, /* CharType case modifers */
smCharLower = 0x0000,
smCharUpper = 0x4000, /* CharType character size modifiers (1 or multiple bytes). */
smChar1byte = 0x0000,
smChar2byte = 0x8000
};
enum {
/* TransliterateText target types for Roman */
smTransAscii = 0, /*convert to ASCII*/
smTransNative = 1, /*convert to font script*/
smTransCase = 0xFE, /*convert case for all text*/
smTransSystem = 0xFF, /*convert to system script*/
/* TransliterateText target types for two-byte scripts */
smTransAscii1 = 2, /*1-byte Roman*/
smTransAscii2 = 3, /*2-byte Roman*/
smTransKana1 = 4, /*1-byte Japanese Katakana*/
smTransKana2 = 5 /*2-byte Japanese Katakana*/
};
enum {
smTransGana2 = 7, /*2-byte Japanese Hiragana (no 1-byte Hiragana)*/
smTransHangul2 = 8, /*2-byte Korean Hangul*/
smTransJamo2 = 9, /*2-byte Korean Jamo*/
smTransBopomofo2 = 10, /*2-byte Chinese Bopomofo*/
/* TransliterateText target modifiers */
smTransLower = 0x4000, /*target becomes lowercase*/
smTransUpper = 0x8000, /*target becomes uppercase*/
/* TransliterateText resource format numbers */
smTransRuleBaseFormat = 1, /*Rule based trsl resource format */
smTransHangulFormat = 2, /*Table based Hangul trsl resource format*/
/* TransliterateText property flags */
smTransPreDoubleByting = 1, /*Convert all text to double byte before transliteration*/
smTransPreLowerCasing = 2 /*Convert all text to lower case before transliteration*/
};
enum {
/* TransliterateText source mask - general */
smMaskAll = (long)0xFFFFFFFF, /*Convert all text*/
/* TransliterateText source masks */
smMaskAscii = 0x00000001, /*2^smTransAscii*/
smMaskNative = 0x00000002, /*2^smTransNative*/
/* TransliterateText source masks for two-byte scripts */
smMaskAscii1 = 0x00000004, /*2^smTransAscii1*/
smMaskAscii2 = 0x00000008, /*2^smTransAscii2*/
smMaskKana1 = 0x00000010, /*2^smTransKana1*/
smMaskKana2 = 0x00000020, /*2^smTransKana2*/
smMaskGana2 = 0x00000080, /*2^smTransGana2*/
smMaskHangul2 = 0x00000100, /*2^smTransHangul2*/
smMaskJamo2 = 0x00000200, /*2^smTransJamo2*/
smMaskBopomofo2 = 0x00000400 /*2^smTransBopomofo2*/
};
enum {
/* Result values from GetScriptManagerVariable and SetScriptManagerVariable calls. */
smNotInstalled = 0, /*routine not available in script*/
smBadVerb = -1, /*Bad verb passed to a routine*/
smBadScript = -2 /*Bad script code passed to a routine*/
};
enum {
/* Values for script redraw flag. */
smRedrawChar = 0, /*Redraw character only*/
smRedrawWord = 1, /*Redraw entire word (2-byte systems)*/
smRedrawLine = -1 /*Redraw entire line (bidirectional systems)*/
};
enum {
/* GetScriptManagerVariable and SetScriptManagerVariable verbs */
smVersion = 0, /*Script Manager version number*/
smMunged = 2, /*Globals change count*/
smEnabled = 4, /*Count of enabled scripts, incl Roman*/
smBidirect = 6, /*At least one bidirectional script*/
smFontForce = 8, /*Force font flag*/
smIntlForce = 10, /*Force intl flag*/
smForced = 12, /*Script was forced to system script*/
smDefault = 14, /*Script was defaulted to Roman script*/
smPrint = 16, /*Printer action routine*/
smSysScript = 18, /*System script*/
smLastScript = 20, /*Last keyboard script*/
smKeyScript = 22, /*Keyboard script*/
smSysRef = 24, /*System folder refNum*/
smKeyCache = 26, /*obsolete*/
smKeySwap = 28, /*Swapping table handle*/
smGenFlags = 30, /*General flags long*/
smOverride = 32, /*Script override flags*/
smCharPortion = 34, /*Ch vs SpExtra proportion*/
/* New for System 7.0: */
smDoubleByte = 36, /*Flag for double-byte script installed*/
smKCHRCache = 38, /*Returns pointer to KCHR cache*/
smRegionCode = 40, /*Returns current region code (verXxx)*/
smKeyDisableState = 42 /*Returns current keyboard disable state*/
};
enum {
/* GetScriptVariable and SetScriptVariable verbs. */
/* Note: Verbs private to script systems are negative, while */
/* those general across script systems are non-negative. */
smScriptVersion = 0, /*Script software version*/
smScriptMunged = 2, /*Script entry changed count*/
smScriptEnabled = 4, /*Script enabled flag*/
smScriptRight = 6, /*Right to left flag*/
smScriptJust = 8, /*Justification flag*/
smScriptRedraw = 10, /*Word redraw flag*/
smScriptSysFond = 12, /*Preferred system font*/
smScriptAppFond = 14, /*Preferred Application font*/
smScriptBundle = 16, /*Beginning of itlb verbs*/
smScriptNumber = 16, /*Script itl0 id*/
smScriptDate = 18, /*Script itl1 id*/
smScriptSort = 20, /*Script itl2 id*/
smScriptFlags = 22, /*flags word*/
smScriptToken = 24, /*Script itl4 id*/
smScriptEncoding = 26, /*id of optional itl5, if present*/
smScriptLang = 28 /*Current language for script*/
};
enum {
smScriptNumDate = 30, /*Script Number/Date formats.*/
smScriptKeys = 32, /*Script KCHR id*/
smScriptIcon = 34, /*ID # of SICN or kcs#/kcs4/kcs8 suite*/
smScriptPrint = 36, /*Script printer action routine*/
smScriptTrap = 38, /*Trap entry pointer*/
smScriptCreator = 40, /*Script file creator*/
smScriptFile = 42, /*Script file name*/
smScriptName = 44, /*Script name*/
/* There is a hole here for old Kanji private verbs 46-76 */
/* New for System 7.0: */
smScriptMonoFondSize = 78, /*default monospace FOND (hi) & size (lo)*/
smScriptPrefFondSize = 80, /*preferred FOND (hi) & size (lo)*/
smScriptSmallFondSize = 82, /*default small FOND (hi) & size (lo)*/
smScriptSysFondSize = 84, /*default system FOND (hi) & size (lo)*/
smScriptAppFondSize = 86, /*default app FOND (hi) & size (lo)*/
smScriptHelpFondSize = 88, /*default Help Mgr FOND (hi) & size (lo)*/
smScriptValidStyles = 90, /*mask of valid styles for script*/
smScriptAliasStyle = 92 /*style (set) to use for aliases*/
};
/* special negative verbs for Get/SetScriptVariable that were associated with WorldScriptI */
/* move them here to be public */
enum {
/* WorldScript private verbs */
smLayoutCache = -309, /* HiWrd(param) is # entries, LoWrd is max input length*/
smOldVerbSupport = -311, /* param is added to old verbs to map to WSI verb*/
smSetKashidas = -291, /* param is ON or OFF, old verb = -36*/
smSetKashProp = -287, /* param is kashida proportion, old verb = -32*/
smScriptSysBase = -281, /* param is associated font to use w/ system font (old verb = -26)*/
smScriptAppBase = -283, /* param is associated font to use w/ app font (old verb = -28)*/
smScriptFntBase = -285, /* param is associated font to use w/ all other fonts (old verb = -30)*/
smScriptLigatures = -263, /* old verb = -8*/
smScriptNumbers = -267 /* old verb = -12*/
};
enum {
/* Special script code values for International Utilities */
iuSystemScript = -1, /* <obsolete> system script */
iuCurrentScript = -2 /* <obsolete> current script (for font of grafPort) */
};
enum {
/* Negative verbs for KeyScript */
smKeyNextScript = -1, /* Switch to next available script */
smKeySysScript = -2, /* Switch to the system script */
smKeySwapScript = -3, /* Switch to previously-used script */
/* New for System 7.0: */
smKeyNextKybd = -4, /* Switch to next keyboard in current keyscript */
smKeySwapKybd = -5, /* Switch to previously-used keyboard in current keyscript */
smKeyDisableKybds = -6, /* Disable keyboards not in system or Roman script */
smKeyEnableKybds = -7, /* Re-enable keyboards for all enabled scripts */
smKeyToggleInline = -8, /* Toggle inline input for current keyscript */
smKeyToggleDirection = -9, /* Toggle default line direction (TESysJust) */
smKeyNextInputMethod = -10, /* Switch to next input method in current keyscript */
smKeySwapInputMethod = -11, /* Switch to last-used input method in current keyscript */
smKeyDisableKybdSwitch = -12, /* Disable switching from the current keyboard */
smKeySetDirLeftRight = -15, /* Set default line dir to left-right, align left */
smKeySetDirRightLeft = -16, /* Set default line dir to right-left, align right */
smKeyRoman = -17 /* Set keyscript to Roman. Does nothing if Roman-only system, unlike KeyScript(smRoman) which forces an update to current default Roman keyboard */
};
/* Optional font and keyboard script synchronization */
enum {
/* One more flag in the smGenFlags long. */
smfDisableKeyScriptSync = 27 /*Disable font and keyboard script synchronization*/
};
enum {
/* We should define masks, too. */
smfDisableKeyScriptSyncMask = 1L << smfDisableKeyScriptSync /*Disable font and keyboard script synchronization mask*/
};
enum {
/* Force keyboard script switching flag and mask for zero and positive KeyScript verbs */
smKeyForceKeyScriptBit = 7, /* Force keyboard script switching flag */
smKeyForceKeyScriptMask = 1 << smKeyForceKeyScriptBit /* its mask */
};
enum {
/* Bits in the smScriptFlags word */
/* (bits above 8 are non-static) */
smsfIntellCP = 0, /*Script has intelligent cut & paste*/
smsfSingByte = 1, /*Script has only single bytes*/
smsfNatCase = 2, /*Native chars have upper & lower case*/
smsfContext = 3, /*Script is contextual*/
smsfNoForceFont = 4, /*Script will not force characters*/
smsfB0Digits = 5, /*Script has alternate digits at B0-B9*/
smsfAutoInit = 6, /*Auto initialize the script*/
smsfUnivExt = 7, /*Script is handled by universal extension*/
smsfSynchUnstyledTE = 8, /*Script synchronizes for unstyled TE*/
smsfForms = 13, /*Uses contextual forms for letters*/
smsfLigatures = 14, /*Uses contextual ligatures*/
smsfReverse = 15, /*Reverses native text, right-left*/
/* Bits in the smGenFlags long. */
/* First (high-order) byte is set from itlc flags byte. */
smfShowIcon = 31, /*Show icon even if only one script*/
smfDualCaret = 30, /*Use dual caret for mixed direction text*/
smfNameTagEnab = 29, /*Reserved for internal use*/
smfUseAssocFontInfo = 28 /*Use the associated font info for FontMetrics calls <48>*/
};
enum {
/* Roman script constants */
/* The following are here for backward compatibility, but should not be used. */
/* This information should be obtained using GetScript. */
romanSysFond = 0x3FFF, /*system font id number*/
romanAppFond = 3, /*application font id number*/
romanFlags = 0x0007, /*roman settings*/
/* Script Manager font equates. */
smFondStart = 0x4000, /*start from 16K*/
smFondEnd = 0xC000, /*past end of range at 48K*/
/* Miscellaneous font equates. */
smUprHalfCharSet = 0x80 /*first char code in top half of std char set*/
};
enum {
/* Character Set Extensions */
diaeresisUprY = 0xD9,
fraction = 0xDA,
intlCurrency = 0xDB,
leftSingGuillemet = 0xDC,
rightSingGuillemet = 0xDD,
fiLigature = 0xDE,
flLigature = 0xDF,
dblDagger = 0xE0,
centeredDot = 0xE1,
baseSingQuote = 0xE2,
baseDblQuote = 0xE3,
perThousand = 0xE4,
circumflexUprA = 0xE5,
circumflexUprE = 0xE6,
acuteUprA = 0xE7,
diaeresisUprE = 0xE8,
graveUprE = 0xE9,
acuteUprI = 0xEA,
circumflexUprI = 0xEB,
diaeresisUprI = 0xEC,
graveUprI = 0xED,
acuteUprO = 0xEE,
circumflexUprO = 0xEF,
appleLogo = 0xF0,
graveUprO = 0xF1,
acuteUprU = 0xF2,
circumflexUprU = 0xF3,
graveUprU = 0xF4,
dotlessLwrI = 0xF5,
circumflex = 0xF6,
tilde = 0xF7,
macron = 0xF8,
breveMark = 0xF9,
overDot = 0xFA,
ringMark = 0xFB,
cedilla = 0xFC,
doubleAcute = 0xFD,
ogonek = 0xFE,
hachek = 0xFF
};
enum {
/* ScriptTokenType values */
tokenIntl = 4, /*the itl resource number of the tokenizer*/
tokenEmpty = -1 /*used internally as an empty flag*/
};
enum {
tokenUnknown = 0, /*chars that do not match a defined token type*/
tokenWhite = 1, /*white space*/
tokenLeftLit = 2, /*literal begin*/
tokenRightLit = 3, /*literal end*/
tokenAlpha = 4, /*alphabetic*/
tokenNumeric = 5, /*numeric*/
tokenNewLine = 6, /*new line*/
tokenLeftComment = 7, /*open comment*/
tokenRightComment = 8, /*close comment*/
tokenLiteral = 9, /*literal*/
tokenEscape = 10, /*character escape (e.g. '\' in "\n", "\t")*/
tokenAltNum = 11, /*alternate number (e.g.
tokenRealNum = 12, /*real number*/
tokenAltReal = 13, /*alternate real number*/
tokenReserve1 = 14, /*reserved*/
tokenReserve2 = 15, /*reserved*/
tokenLeftParen = 16, /*open parenthesis*/
tokenRightParen = 17, /*close parenthesis*/
tokenLeftBracket = 18, /*open square bracket*/
tokenRightBracket = 19 /*close square bracket*/
};
enum {
tokenLeftCurly = 20, /*open curly bracket*/
tokenRightCurly = 21, /*close curly bracket*/
tokenLeftEnclose = 22, /*open guillemet*/
tokenRightEnclose = 23, /*close guillemet*/
tokenPlus = 24,
tokenMinus = 25,
tokenAsterisk = 26, /*times/multiply*/
tokenDivide = 27,
tokenPlusMinus = 28, /*plus or minus symbol*/
tokenSlash = 29,
tokenBackSlash = 30,
tokenLess = 31, /*less than symbol*/
tokenGreat = 32, /*greater than symbol*/
tokenEqual = 33,
tokenLessEqual2 = 34, /*less than or equal, 2 characters (e.g. <=)*/
tokenLessEqual1 = 35, /*less than or equal, 1 character*/
tokenGreatEqual2 = 36, /*greater than or equal, 2 characters (e.g. >=)*/
tokenGreatEqual1 = 37, /*greater than or equal, 1 character*/
token2Equal = 38, /*double equal (e.g. ==)*/
tokenColonEqual = 39 /*colon equal*/
};
enum {
tokenNotEqual = 40, /*not equal, 1 character*/
tokenLessGreat = 41, /*less/greater, Pascal not equal (e.g. <>)*/
tokenExclamEqual = 42, /*exclamation equal, C not equal (e.g. !=)*/
tokenExclam = 43, /*exclamation point*/
tokenTilde = 44, /*centered tilde*/
tokenComma = 45,
tokenPeriod = 46,
tokenLeft2Quote = 47, /*open double quote*/
tokenRight2Quote = 48, /*close double quote*/
tokenLeft1Quote = 49, /*open single quote*/
tokenRight1Quote = 50, /*close single quote*/
token2Quote = 51, /*double quote*/
token1Quote = 52, /*single quote*/
tokenSemicolon = 53,
tokenPercent = 54,
tokenCaret = 55,
tokenUnderline = 56,
tokenAmpersand = 57,
tokenAtSign = 58,
tokenBar = 59 /*vertical bar*/
};
enum {
tokenQuestion = 60,
tokenPi = 61, /*lower-case pi*/
tokenRoot = 62, /*square root symbol*/
tokenSigma = 63, /*capital sigma*/
tokenIntegral = 64, /*integral sign*/
tokenMicro = 65,
tokenCapPi = 66, /*capital pi*/
tokenInfinity = 67,
tokenColon = 68,
tokenHash = 69, /*e.g. #*/
tokenDollar = 70,
tokenNoBreakSpace = 71, /*non-breaking space*/
tokenFraction = 72,
tokenIntlCurrency = 73,
tokenLeftSingGuillemet = 74,
tokenRightSingGuillemet = 75,
tokenPerThousand = 76,
tokenEllipsis = 77,
tokenCenterDot = 78,
tokenNil = 127
};
enum {
delimPad = -2, /* obsolete, misspelled token names kept for backward compatibility */
tokenTilda = 44,
tokenCarat = 55
};
enum {
/* Table selectors for GetItlTable */
smWordSelectTable = 0, /* get word select break table from 'itl2' */
smWordWrapTable = 1, /* get word wrap break table from 'itl2' */
smNumberPartsTable = 2, /* get default number parts table from 'itl4' */
smUnTokenTable = 3, /* get unToken table from 'itl4' */
smWhiteSpaceList = 4, /* get white space list from 'itl4' */
iuWordSelectTable = 0, /* <obsolete> get word select break table from 'itl2' */
iuWordWrapTable = 1, /* <obsolete> get word wrap break table from 'itl2' */
iuNumberPartsTable = 2, /* <obsolete> get default number parts table from 'itl4' */
iuUnTokenTable = 3, /* <obsolete> get unToken table from 'itl4' */
iuWhiteSpaceList = 4 /* <obsolete> get white space list from 'itl4' */
};
/* end of stuff moved from Packages.h */
enum {
tokenOK = 0, /* TokenResults */
tokenOverflow = 1, /* TokenResults */
stringOverflow = 2, /* TokenResults */
badDelim = 3, /* TokenResults */
badEnding = 4, /* TokenResults */
crash = 5 /* TokenResults */
};
typedef SInt8 TokenResults;
typedef char CharByteTable[256];
/* "TokenType" was renamed to "ScriptTokenType" because of a name collision in QuickTime 3.0 on other OS's*/
typedef short ScriptTokenType;
if TARGET_OS_MAC
typedef ScriptTokenType TokenType;
endif /* TARGET_OS_MAC */
typedef ScriptTokenType DelimType[2];
typedef ScriptTokenType CommentType[4];
struct TokenRec {
ScriptTokenType theToken;
Ptr position; /*pointer into original source*/
long length; /*length of text in original source*/
StringPtr stringPosition; /*Pascal/C string copy of identifier*/
};
typedef struct TokenRec TokenRec;
typedef TokenRec * TokenRecPtr;
struct TokenBlock {
Ptr source; /*pointer to stream of characters*/
long sourceLength; /*length of source stream*/
Ptr tokenList; /*pointer to array of tokens*/
long tokenLength; /*maximum length of TokenList*/
long tokenCount; /*number tokens generated by tokenizer*/
Ptr stringList; /*pointer to stream of identifiers*/
long stringLength; /*length of string list*/
long stringCount; /*number of bytes currently used*/
Boolean doString; /*make strings & put into StringList*/
Boolean doAppend; /*append to TokenList rather than replace*/
Boolean doAlphanumeric; /*identifiers may include numeric*/
Boolean doNest; /*do comments nest?*/
ScriptTokenType leftDelims[2];
ScriptTokenType rightDelims[2];
ScriptTokenType leftComment[4];
ScriptTokenType rightComment[4];
ScriptTokenType escapeCode; /*escape symbol code*/
ScriptTokenType decimalCode;
Handle itlResource; /*handle to itl4 resource of current script*/
long reserved[8]; /*must be zero!*/
};
typedef struct TokenBlock TokenBlock;
typedef TokenBlock * TokenBlockPtr;
EXTERN_API( short )
GetSysDirection (void) TWOWORDINLINE(0x3EB8, 0x0BAC);
EXTERN_API( void )
SetSysDirection (short value) TWOWORDINLINE(0x31DF, 0x0BAC);
EXTERN_API( short )
FontScript (void) FOURWORDINLINE(0x2F3C, 0x8200, 0x0000, 0xA8B5);
EXTERN_API( short )
IntlScript (void) FOURWORDINLINE(0x2F3C, 0x8200, 0x0002, 0xA8B5);
EXTERN_API( void )
KeyScript (short code) FOURWORDINLINE(0x2F3C, 0x8002, 0x0004, 0xA8B5);
EXTERN_API( Boolean )
IsCmdChar (const EventRecord * event,
short test) FOURWORDINLINE(0x2F3C, 0x8206, 0xFFD0, 0xA8B5);
EXTERN_API( short )
FontToScript (short fontNumber) FOURWORDINLINE(0x2F3C, 0x8202, 0x0006, 0xA8B5);
EXTERN_API( long )
GetScriptManagerVariable (short selector) FOURWORDINLINE(0x2F3C, 0x8402, 0x0008, 0xA8B5);
EXTERN_API( OSErr )
SetScriptManagerVariable (short selector,
long param) FOURWORDINLINE(0x2F3C, 0x8206, 0x000A, 0xA8B5);
EXTERN_API( long )
GetScriptVariable (short script,
short selector) FOURWORDINLINE(0x2F3C, 0x8404, 0x000C, 0xA8B5);
EXTERN_API( OSErr )
SetScriptVariable (short script,
short selector,
long param) FOURWORDINLINE(0x2F3C, 0x8208, 0x000E, 0xA8B5);
EXTERN_API( short )
CharacterByteType (Ptr textBuf,
short textOffset,
ScriptCode script) FOURWORDINLINE(0x2F3C, 0xC206, 0x0010, 0xA8B5);
EXTERN_API( short )
CharacterType (Ptr textBuf,
short textOffset,
ScriptCode script) FOURWORDINLINE(0x2F3C, 0xC206, 0x0012, 0xA8B5);
EXTERN_API( OSErr )
TransliterateText (Handle srcHandle,
Handle dstHandle,
short target,
long srcMask,
ScriptCode script) FOURWORDINLINE(0x2F3C, 0xC20E, 0x0018, 0xA8B5);
EXTERN_API( Boolean )
FillParseTable (CharByteTable table,
ScriptCode script) FOURWORDINLINE(0x2F3C, 0xC204, 0x0022, 0xA8B5);
EXTERN_API( Handle )
GetIntlResource (short theID) THREEWORDINLINE(0x3F3C, 0x0006, 0xA9ED);
EXTERN_API( void )
ClearIntlResourceCache (void) THREEWORDINLINE(0x3F3C, 0x0018, 0xA9ED);
EXTERN_API( void )
GetIntlResourceTable (ScriptCode script,
short tableCode,
Handle * itlHandle,
long * offset,
long * length) THREEWORDINLINE(0x3F3C, 0x0024, 0xA9ED);
if CALL_NOT_IN_CARBON
if CALL_NOT_IN_CARBON
EXTERN_API( UniversalProcPtr )
GetScriptUtilityAddress (short selector,
Boolean Before,
ScriptCode script) FOURWORDINLINE(0x2F3C, 0xC404, 0x0038, 0xA8B5);
EXTERN_API( void )
SetScriptUtilityAddress (short selector,
Boolean Before,
UniversalProcPtr routineAddr,
ScriptCode script) FOURWORDINLINE(0x2F3C, 0xC008, 0x003A, 0xA8B5);
EXTERN_API( UniversalProcPtr )
GetScriptQDPatchAddress (short trapNum,
Boolean Before,
Boolean forPrinting,
ScriptCode script) FOURWORDINLINE(0x2F3C, 0xC406, 0x003C, 0xA8B5);
EXTERN_API( void )
SetScriptQDPatchAddress (short trapNum,
Boolean Before,
Boolean forPrinting,
UniversalProcPtr routineAddr,
ScriptCode script) FOURWORDINLINE(0x2F3C, 0xC00A, 0x003E, 0xA8B5);
EXTERN_API( void )
SetIntlResource (short refNum,
short theID,
Handle intlHandle) THREEWORDINLINE(0x3F3C, 0x0008, 0xA9ED);
EXTERN_API( short )
CharByte (Ptr textBuf,
short textOffset) FOURWORDINLINE(0x2F3C, 0x8206, 0x0010, 0xA8B5);
EXTERN_API( short )
CharType (Ptr textBuf,
short textOffset) FOURWORDINLINE(0x2F3C, 0x8206, 0x0012, 0xA8B5);
EXTERN_API( OSErr )
Transliterate (Handle srcHandle,
Handle dstHandle,
short target,
long srcMask) FOURWORDINLINE(0x2F3C, 0x820E, 0x0018, 0xA8B5);
EXTERN_API( Boolean )
ParseTable (CharByteTable table) FOURWORDINLINE(0x2F3C, 0x8204, 0x0022, 0xA8B5);
endif /* CALL_NOT_IN_CARBON */
endif /* CALL_NOT_IN_CARBON */
EXTERN_API( TokenResults )
IntlTokenize (TokenBlockPtr tokenParam) FOURWORDINLINE(0x2F3C, 0x8204, 0xFFFA, 0xA8B5);
if OLDROUTINENAMES
define SetSysJust(newJust) SetSysDirection(newJust)
define GetSysJust() GetSysDirection()
define Font2Script(fontNumber) FontToScript(fontNumber)
define GetEnvirons(verb) GetScriptManagerVariable(verb)
define SetEnvirons(verb, param) SetScriptManagerVariable(verb, param)
define GetScript(script, verb) GetScriptVariable(script, verb)
define SetScript(script, verb, param) SetScriptVariable(script, verb, param)
define IUGetIntl(theID) GetIntlResource(theID)
define IUSetIntl(refNum, theID, intlHandle) SetIntlResource(refNum, theID, intlHandle)
define IUClearCache() ClearIntlResourceCache()
define IUGetItlTable(script, tableCode, itlHandle, offset, length) \
GetIntlResourceTable(script, tableCode, itlHandle, offset, length)
endif /* OLDROUTINENAMES */
if PRAGMA_STRUCT_ALIGN
#pragma options align=reset
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(pop)
#elif PRAGMA_STRUCT_PACK
#pragma pack()
endif
ifdef PRAGMA_IMPORT_OFF
#pragma import off
#elif PRAGMA_IMPORT
#pragma import reset
endif
ifdef __cplusplus
}
endif
endif /* __SCRIPT__ */
(C) Æliens
04/09/2009
You may not copy or print any of this material without explicit permission of the author or the publisher.
In case of other copyright issues, contact the author.