Changes

Jump to navigation Jump to search
528 bytes added ,  00:12, 15 April 2013
m
→‎Installing: link to existing mirror
< [[Aleph]] | [[Arabic and Hebrew]] >
 
=Aleph in ConTeXt: A Guide to the Perplexed=
(with apologies to Maimonides)
by Prof. [[User:Ishamid|Idris Samawi Hamid]] __TOC__
==Introduction==
[[Aleph ]] is a typesetting engine derived from Omega and eTeX. Reasons for Aleph:
# ConTeXt depends on the eTeX extensions, and even LaTeX now defaults to pdfeTeX.
''Aleph'', inheriting from ''Omega'', provides many ready-to-go filters, using a Times Roman like font for Latin, Greek, and Cyrillic scripts.
The ConTeXt module for this setup is called ''Gamma'' ([[source:m-gamma.tex|m-gamma.tex]]); this is a port of the ''Lambda'' (i.e., LaTeX) style files to ConTeXt. The font typescript is called type-omg.
==Installing==
Users of MiKTeX and other OS's will need to adjust the following instructions to their own setups.
* Make sure you have a very recent version of ConTeXt that supports the engine path mechanism. This mechanism allows <tt>texexec </tt> to manage two, e.g., <tt>cont-en.fmt </tt> files at once, one in <code>texmf/web2c/aleph</code> and one in <code>texmf/web2c/pdfetex</code>
How recent, you ask? Just be safe and get the latest <tt>:-)</tt>
* Some configuration points:
** Make sure you have the following line in <tt>texexec.ini</tt> set to "true":<texcode>set UseEnginePath to true</texcode>
** In <tt>texmf-local\web2c\texmf.cnf</tt>, <tt>texmf-local\web2c\context.cnf</tt>, and <tt>texmf\web2c\texmf.cnf</tt> comment out the following line
<texcode> extra_mem_bot.context = 2000000</texcode>
otherwise Aleph will crash under some conditions, like overfull boxes and the like...<br>The [[XeTeX]] developer found the source to this bug, and a fix; hopefully [[User:Oblomov|Giuseppe]] will get to it :-))
* Get the omega support files [http://ftp.cvut.cz/tex-archive/obsolete/systems/win32/fptex/0.7/package/omega.zip omega.zip] and [http://ftp.cvut.cz/tex-archive/obsolete/systems/win32/fptex/0.7/package/omegafonts.zip omegafonts.zip].
* Get rid of two directories from omega.zip (not really necessary but if you want to be efficient): <tt>texmf/eomega</tt> and <tt>texmf/omega/encodings</tt>
* Put support files in <tt>texmf-local</tt>.
* Replace the default uni2cuni.ocp and uni2cuni.otp with this one: [[Media:Uni2cuni.zip]] This contains two ocp's: uni2cuni.ocp and uni2cuni-math.ocp. uni2cuni-math is the equicalent of the old omega uni2cuni.
This makes r-l numeral labels with separators easier to handle. Always use something like $<numeral>$ or ${\tf <numeral>}$ for mathematics and decimal points. $<numeral>$ uses the default math font; ${\tf <numeral>}$ uses the digits from the main text font.
* Compile the Aleph format: <texcode>mktexlsr<br>texexec --make en -tex=aleph</texcode>
* Here is a test file. Note the preamble
<texcode> %tex=aleph output=dvipdfmx</texcode>
a. Make sure you have the following line in ConTeXt\tex\texmf-local\context\config\texexec.ini set to "true", viz., set UseEnginePath to true b. In texmf-local\web2c\texmf.cnf,texmf-local\web2c\context.cnf, andtexmf\web2c\texmf.cnf, comment this line as follows %extra_mem_bot.context = 2000000 otherwise aleph will crash under some conditions, like overfull boxes and the like... The XeTeX developer found the source to this bug, and a fix; hopefully Giuseppe will get to it-)) 3. Get the omega support files: http://www.ctan.org/get?fn=/systems/win32/fptex/0.7/package/omega.ziphttp://www.ctan.org/get?fn=/systems/win32/fptex/0.7/package/omegafonts.zip 4. Get rid of the following directories from omega.zip (not really necessary but if u want to beefficient): texmf/eomegatexmf/omega/encodings 5. Put support files in texmf-local; 6. Compile the Aleph format: mktexlsr texexec --make en -tex=aleph 7. Here is a test file. Note the preamble % tex=aleph output=dvipdfmx at the beginning of every aleph Aleph file.
'''===omarb.tex'''===
<texcode>
% tex=aleph output=dvipdfmx
\input m-usemodule[gamma.tex]\input type-omg.tex% perhaps \usetypescriptfile[type-omg] ?
\setupbodyfont[omlgc,12pt]
</texcode>
8. * For Arabic script you will probably want to use an [[Encodings_and_Regimes|encoding ]] that supports direct Arabic-script editing. There are three: utf-8, iso-8859-6 (apple-unixApple/Unix), and cp1256 (micro$oftMicrosoft). We can define the following, using ConTeXt macros for managing filter sequences. Maybe I will add these to [[source:m-gamma -tex|m-gamma]] and ask [[User:Hagen|Hans ]] to distribute. In the meantime, here are some definitions, samples of all three encodings, and an example of mixed lr-rl text:
'''===m-arabic-enc.tex'''===
<texcode>
% tex=aleph output=dvipdfmx
%\input m-usemodule[gamma.tex\input type-omg.tex]
\usetypescriptfile[type-omg]
\usetypescript[OmegaArab]
% For inner paragraph control within an LR paragraph
\def\ArabicTextUTF#1{definestartstop [arabictextutf] [commands=% {\textdir TRT\usefiltersequence[UTFArabic]% \switchtobodyfont[omarb]#1\textdir TLT% \clearocplists}usefiltersequence[UTFArabic]}]
\def\ArabicTextISO#1{definestartstop [arabictextiso] [commands=% {\textdir TRT\usefiltersequence[ISOArabic]% \switchtobodyfont[omarb]#1\textdir TLT% \clearocplists}usefiltersequence[ISOArabic]}]
\def\ArabicTextWIN#1{definestartstop [arabictextwin] [commands=% {\textdir TRT% \usefiltersequenceswitchtobodyfont[WINFArabicomarb]% \switchtobodyfontusefiltersequence[omarbWINArabic]}\def\ArabicTextUTF#1{\textdir TLTstartarabictextutf#1\stoparabictextutf}  \clearocplistsdef\ArabicTextISO#1{\startarabictextiso#1\stoparabictextiso\def\ArabicTextWIN#1{\startarabictextwin#1\stoparabictextwin}
% For global Arabic script
\startarabutf
اللَّهُمَّ صَلِّ عَلَى مُحَمَّدٍ ÙˆÙŽاللَّهُمَّ صَلِّ عَلَى مُحَمَّدٍ وَآلِ مُحَمَّدٍ ÙˆÙŽ ارْزُقْنِيآلِ مُحَمَّدٍ وَ ارْزُقْنِيالْيَقِينَ ÙˆÙŽ حُسْنَ الظَّنِّ بِكَالْيَقِينَ وَ حُسْنَ الظَّنِّ بِكَÙˆÙŽ أَثْبِتْ رَجَاءَكَ فِي قَلْبِيوَ أَثْبِتْ رَجَاءَكَ فِي قَلْبِيÙˆÙŽ اقْطَعْ رَجَائِي عَمَّنْ سِوَاكَوَ اقْطَعْ رَجَائِي عَمَّنْ سِوَاكَحَتَّى لَا أَرْجُوَ غَيْرَكَ ÙˆÙŽ لَاحَتَّى لَا أَرْجُوَ غَيْرَكَ وَ لَاأَثِقَ إِلَّا بِك‏أَثِقَ إِلَّا بِك‏
\stoparabutf
\blank
Here is some mixed {\em Arabic-} (\ArabicTextUTF{عربيعربي}) and
Latin-script. As you can see, Aleph does a very good job mixing
{\em LR} (\ArabicTextUTF{يساريسار-يمينيمين}) and {\em RL}(\ArabicTextUTF{يمينيمين-يساريسار}) texts. \ArabicTextUTF{Ùˆوهنا جملة منقطعة في وسط قرينةهنا جملة منقطعة في وسط قرينةلاتينيةلاتينية}. Aleph even does a great job breaking Arabic
phrases across lines.
==Going beyond==
The last example shows how to make and apply your own filter sequences beyond the basic Gamma module. To go further u need to learn some low* [[File:Utilities-level businessaleph. You will also need some working zip|utilities-aleph. I have put together a windows package that you can unzip to C:\ConTeXt. These utilities do work, but they are cobbled together from old fpTeX and MiKTeX versions. just place the tree in C:\ConTeXt\zip]]
1The last example shows how to make and apply your own filter sequences beyond the basic Gamma module. To go further you need to learn some low-level business. You will also need some [[File:Utilities-aleph.zip|working utilities]]. I have put together a windows package that you can unzip to <tt>C:\ConTeXt</tt>. These utilities do work, but they are cobbled together from old fpTeX and MiKTeX versions. ===Example: If you want to get the final Persian kaaf instead of the default Arabic one:===
Check to see if your glyph is in the Arabic font. The Arabic font is made of 6 raw fonts: 3 regular and three bold:
 C:\ConTeXt\tex\ texmf-local\/fonts\/type1\/public\/omega  omsea1, omsea1b,...omsea3b
Using a font viewer or editor you will find the Persian final kaaf in omsea2, named kafswashfin.
Now go to
 C:\ConTeXt\tex\<tt>texmf-local\/omega\/lambda\/misc</tt>
and open
 <tt>omarab.cfg</tt>
you will find a line
04AA N kafswashfin
This means that the 044A is the virtual font position for kafswashfin. Open cuni2oar.otp and add the following at line 263:
%@"E343 => @"04AA;
Following this line you should see
% remaining Arabic glyphs @"E000-@"E3FF => #(\1 - @"DF00);
Basically, in <tt>uni2cuni.otp </tt> final-kaaf gets mapped to E343. In the font, we want it mapped to kafswashfin, so we did that. Now recompile the otp:
otp2ocp cuni2oar
Now you will get kafswashfin for the final kaaf.
2. ===Want new fonts (Arabic or Latin). ? Here are the instructions:===
1. * Read the following two papers carefully again and again; they are your friends:-)** [http://omega.enstb.org/papers/tsukuba-methods97.pdf tsukuba-methods]** [http://omega.enstb.org/papers/ridt-omega98.pdf ridt-omega]* Make a pfb file containing the glyphs you need, or use an existing font* Make a cfg file a la <tt>texmf\omega\lambda\misc\omlgc.cfg</tt>. Make sure you list your glyph positions in hexadecimal notation.* Get <tt>makeovp.pl</tt> from the utilities. I made some small changes, <tt>makeovp2.pl</tt>. Try them both and use what works for you. There is a SH file with a sample of its use using omlgc. * Following are instructions for cooking omarab.ovf.** You want your own ovf, say, omlgcch.ovf.** Generate an afm file for your private glyph pfb/pfa plus the afm files that are listed in the SH file (base files for omlgc found in <tt>\texmf\fonts\afm\public\omega</tt>)** Using the instructions below and the SH file ('''ignore''' the kernings.afm file!) you can figure out how to make your own ovp and ovf.** Before making the ovf file, examine the ovp file created, especially the first few lines, to see how the font-metric info from the afm's are concatenated. Very instructive.* Don't forget the rest of the accounting:** adding lines to a map file and pointing dvips/dvipdfm to it;** create a typescript file;** edit your otp's. If you get stuck be sure to read [http://omega.enstb.org/papers/tsukuba-arabic97.pdf tsukuba-arabic]
http====How to cook omarab.ovf====Ingredients://omegaomarab.enstbcfg, omseco.org/papers/tsukuba-methods97.pdfhttp://omegaafm, omsea1.enstbafm, omsea2.org/papers/ridt-omega98afm, omsea3.pdfafm
2 > perl makeovp. Make a pfb file containing the glyphs you need, or use an existing fontpl omarab.cfg omseco.afm omsea1.afm omsea2.afm omsea3.afm omarab.ovp > pltotf omseco.pl omseco.tfm > pltotf omsea1.pl omsea1.tfm > pltotf omsea2.pl omsea2.tfm > pltotf omsea3.pl omsea3.tfm > ovp2ovf omarab.ovp omarab.ovf omarab.ofm
3.Make a cfg file a la texmf\omega\lambda\misc\omlgc.cfg Make sure u list your glyph positions in hexadecimal notation.If the last line does not work, try
5 > ovp2ovf omarab. Get the following from an old TeXLive distro: \support\makeovpovp omarab.zip, containing makeovp.pl. There is a SH file with a sample of its use using omlgcovf omarab.tfm
4rename omarab. Following are instructions for cooking tfm to omarab.ovf. You want your own ovf, say, omlgcch.ovf (<chofm --> for <cherokee>). Generate an afm file for your private glyph pfb/pfa plus the afm files that are listed in the SH file (base files for omlgc found in \texmf\fonts\afm\public\omega )ofm directory
Using the instructions below and the SH file (IGNORE the kernings====How to distill omarab.afmfile!) you can figure out how to make your own ovp and from omarab.ovf. Before:====making the ovf file, examine Use a different directory or a different name for the output ovp so that omarab.ovp file created, especially thefirst few lines, to see how the font-metric info from the afm's areconcatenated. Very instructiveabove is not overwritten.
6get omarab. Don't forget the rest of the accounting:ofm & rename to omarab.tfm
a) adding lines to a map file and pointing dvips/dvipdfm to it;b) create a typescript file;c) edit your otp's > ovf2ovp omarab. If u get stuck be sure to readovf omarab.tfm omarab.ovp
http====How to cook omarabb.ovf====Ingredients://omegaomarab.cfg, omsecob.afm, omsea1b.enstbafm, omsea2b.org/papers/tsukuba-arabic97afm, omsea3b.pdfafm
<code >[How to cook omarabperl makeovp.ovf:][Ingredients: pl omarab.cfg, omsecoomsecob.afm, omsea1omsea1b.afm, omsea2omsea2b.afm, omsea3omsea3b.afm]omarabb.ovp > pltotf omsecob.pl omsecob.tfm > pltotf omsea1b.pl omsea1b.tfm > pltotf omsea2b.pl omsea2b.tfm > pltotf omsea3b.pl omsea3b.tfm > ovp2ovf omarabb.ovp omarabb.ovf omarabb.ofm
#perl makeovp.pl omarab.cfg omseco.afm omsea1.afm omsea2.afm omsea3.afm omarab.ovp
#pltotf omseco.pl omseco.tfm
#pltotf omsea1.pl omsea1.tfm
#pltotf omsea2.pl omsea2.tfm
#pltotf omsea3.pl omsea3.tfm
#ovp2ovf omarab.ovp omarab.ovf omarab.ofm
[If the last line does not work, try#ovp2ovf omarab.ovp omarab.ovf omarab.tfmrename omarab.tfm to omarab.ofm ===> ofm directory]
-----------------------------[How to distill omarab > ovp2ovf omarabb.ovp from omarabomarabb.ovf:]omarabb.tfm
[Use a different directory or a different name forthe output ovp so that rename omarab.tfm to omarab.ovp created above is not overwritten]ofm --> ofm directory
[get omarab====How to distill omarabb.ofm & rename to omarabovp from omarabb.ovf====Use a different directory or a different name for the output ovp so that omarabb.tfm]ovp created above is not overwritten
#ovf2ovp get omarab.ovf ofm & rename to omarab.tfm omarab.ovp=========================================================[How to cook omarabb.ovf:][Ingredients: omarab.cfg, omsecob.afm, omsea1b.afm, omsea2b.afm, omsea3b.afm]
#perl makeovp > ovf2ovp omarabb.pl omarab.cfg omsecob.afm omsea1b.afm omsea2b.afm omsea3b.afm ovf omarabb.ovp#pltotf omsecob.pl omsecob.tfm#pltotf omsea1b.pl omsea1b.tfm#pltotf omsea2b.pl omsea2b.tfm#pltotf omsea3b.pl omsea3b.tfm#ovp2ovf omarabb.ovp omarabb.ovf omarabb.ofm
[If the last line does not work, try#ovp2ovf omarabb.ovp omarabb.ovf omarabb.tfmrename omarab.tfm to omarab.ofm ===> ofm directory]-----------------------------[How to distill omarabb.ovp from omarabb.ovf:] [Use a different directory or a different name forthe output ovp so that omarabb.ovp created above is not overwritten] [get omarab.ofm & rename to omarab.tfm] #ovf2ovp omarabb.ovf omarabb.tfm omarabb.ovp</code> 3. * For more info, there is also the (mostly cryptic) Omega manual [http://omega.enstb.org/roadmap/doc-1.12.ps in PS-Format]. Don't ask me why it's not in PDF. <tt>:-(</tt> See also [http://omega.enstb.org/papers/tsukuba-arabic97.pdftsukuba-arabic]
==Miscellaneous==
# * Some people have gotten large OpenType fonts to work in Aleph/Omega. Probably they used [http://fontforge.sourceforge.net FontForge ] to convert to CFF-enriched type1. FF can produce ofm files (large tfms) so that's a help too.# * Me, I'm working on an advanced Arabic-script typesetting system that really pushes Aleph to the max. At present I don't actually use [[source:m-gamma.tex|m-gamma]], etc, but my own macros. I really hope to release something this year...#* See also [http://www.dtek.chalmers.se/~d97ost/omega-example.htmlOmega example]
==To the future==
# * The otp mechanism does not seem well suited to support, e.g., opentype OpenType GPOS tables, important for really advanced Arabic (though GDEF and GSUB should work fine with the present mechanism for most purposes). We need a better model for horizontal and vertical glyph substitutions.# * The low-level filtersequence mechanism needs to abstract language processing from font mapping. Right now both are hardwired into a single sequence, so setting up more than one font for a single language is more of a pain than it should be.# * The otp language is a bit cryptic. Hans has suggested switching otp's to a new language (like lua or io) but I don't know how hard that will be...# * One very important feature which may work better at the primitive/engine level by extending the pdfetex pdfeTeX engine:glyph substitution that depends on the paragraph. For example: In traditional Arabic typography, one way to compensate for "underfull" paragraphs is to substitute a "swash" version of a letter. Another way is bystretching the cursive tie between joining characters (which is already implemented in my own Arabicsystem). Combined with HZ we can get some pretty interesting high-level options, effects, etc. that the user can choose etc. {{Installation navbox}}
188

edits

Navigation menu