123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269 |
- #!/usr/bin/php -q
- <?php
- //============================================================+
- // File name : tcpdf_addfont.php
- // Version : 1.0.002
- // Begin : 2013-05-13
- // Last Update : 2013-08-05
- // Authors : Nicola Asuni - Tecnick.com LTD - www.tecnick.com - info@tecnick.com
- // Remi Collet
- // License : GNU-LGPL v3 (http://www.gnu.org/copyleft/lesser.html)
- // -------------------------------------------------------------------
- // Copyright (C) 2011-2013 Nicola Asuni - Tecnick.com LTD
- //
- // This file is part of TCPDF software library.
- //
- // TCPDF is free software: you can redistribute it and/or modify it
- // under the terms of the GNU Lesser General Public License as
- // published by the Free Software Foundation, either version 3 of the
- // License, or (at your option) any later version.
- //
- // TCPDF is distributed in the hope that it will be useful, but
- // WITHOUT ANY WARRANTY; without even the implied warranty of
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- // See the GNU Lesser General Public License for more details.
- //
- // You should have received a copy of the License
- // along with TCPDF. If not, see
- // <http://www.tecnick.com/pagefiles/tcpdf/LICENSE.TXT>.
- //
- // See LICENSE.TXT file for more information.
- // -------------------------------------------------------------------
- //
- // Description : This is a command line script to generate TCPDF fonts.
- //
- //============================================================+
- /**
- * @file
- * This is a command line script to generate TCPDF fonts.<br>
- * @package com.tecnick.tcpdf
- * @version 1.0.000
- */
- if (php_sapi_name() != 'cli') {
- echo 'You need to run this command from console.';
- exit(1);
- }
- $tcpdf_include_dirs = array(realpath(dirname(__FILE__).'/../tcpdf.php'), '/usr/share/php/tcpdf/tcpdf.php', '/usr/share/tcpdf/tcpdf.php', '/usr/share/php-tcpdf/tcpdf.php', '/var/www/tcpdf/tcpdf.php', '/var/www/html/tcpdf/tcpdf.php', '/usr/local/apache2/htdocs/tcpdf/tcpdf.php');
- foreach ($tcpdf_include_dirs as $tcpdf_include_path) {
- if (@file_exists($tcpdf_include_path)) {
- require_once($tcpdf_include_path);
- break;
- }
- }
- /**
- * Display help guide for this command.
- */
- function showHelp() {
- $help = <<<EOD
- tcpdf_addfont - command line tool to convert fonts for the TCPDF library.
- Usage: tcpdf_addfont.php [ options ] -i fontfile[,fontfile]...
- Options:
- -t
- --type Font type. Leave empty for autodetect mode.
- Valid values are:
- TrueTypeUnicode
- TrueType
- Type1
- CID0JP = CID-0 Japanese
- CID0KR = CID-0 Korean
- CID0CS = CID-0 Chinese Simplified
- CID0CT = CID-0 Chinese Traditional
- -e
- --enc Name of the encoding table to use. Leave empty for
- default mode. Omit this parameter for TrueType Unicode
- and symbolic fonts like Symbol or ZapfDingBats.
- -f
- --flags Unsigned 32-bit integer containing flags specifying
- various characteristics of the font (PDF32000:2008 -
- 9.8.2 Font Descriptor Flags): +1 for fixed font; +4 for
- symbol or +32 for non-symbol; +64 for italic. Fixed and
- Italic mode are generally autodetected so you have to
- set it to 32 = non-symbolic font (default) or 4 =
- symbolic font.
- -o
- --outpath Output path for generated font files (must be writeable
- by the web server). Leave empty for default font folder.
- -p
- --platid Platform ID for CMAP table to extract (when building a
- Unicode font for Windows this value should be 3, for
- Macintosh should be 1).
- -n
- --encid Encoding ID for CMAP table to extract (when building a
- Unicode font for Windows this value should be 1, for
- Macintosh should be 0). When Platform ID is 3, legal
- values for Encoding ID are: 0=Symbol, 1=Unicode,
- 2=ShiftJIS, 3=PRC, 4=Big5, 5=Wansung, 6=Johab,
- 7=Reserved, 8=Reserved, 9=Reserved, 10=UCS-4.
- -b
- --addcbbox Includes the character bounding box information on the
- php font file.
- -l
- --link Link to system font instead of copying the font data #
- (not transportable) - Note: do not work with Type1 fonts.
- -i
- --fonts Comma-separated list of input font files.
- -h
- --help Display this help and exit.
- EOD;
- echo $help."\n\n";
- exit(0);
- }
- // remove the name of the executing script
- array_shift($argv);
- // no options chosen
- if (!is_array($argv)) {
- showHelp();
- }
- // initialize the array of options
- $options = array('type'=>'', 'enc'=>'', 'flags'=>32, 'outpath'=>K_PATH_FONTS, 'platid'=>3, 'encid'=>1, 'addcbbox'=>false, 'link'=>false);
- // short input options
- $sopt = '';
- $sopt .= 't:';
- $sopt .= 'e:';
- $sopt .= 'f:';
- $sopt .= 'o:';
- $sopt .= 'p:';
- $sopt .= 'n:';
- $sopt .= 'b';
- $sopt .= 'l';
- $sopt .= 'i:';
- $sopt .= 'h';
- // long input options
- $lopt = array();
- $lopt[] = 'type:';
- $lopt[] = 'enc:';
- $lopt[] = 'flags:';
- $lopt[] = 'outpath:';
- $lopt[] = 'platid:';
- $lopt[] = 'encid:';
- $lopt[] = 'addcbbox';
- $lopt[] = 'link';
- $lopt[] = 'fonts:';
- $lopt[] = 'help';
- // parse input options
- $inopt = getopt($sopt, $lopt);
- // import options (with some sanitization)
- foreach ($inopt as $opt => $val) {
- switch ($opt) {
- case 't':
- case 'type': {
- if (in_array($val, array('TrueTypeUnicode', 'TrueType', 'Type1', 'CID0JP', 'CID0KR', 'CID0CS', 'CID0CT'))) {
- $options['type'] = $val;
- }
- break;
- }
- case 'e':
- case 'enc': {
- $options['enc'] = $val;
- break;
- }
- case 'f':
- case 'flags': {
- $options['flags'] = intval($val);
- break;
- }
- case 'o':
- case 'outpath': {
- $options['outpath'] = realpath($val);
- if (substr($options['outpath'], -1) != '/') {
- $options['outpath'] .= '/';
- }
- break;
- }
- case 'p':
- case 'platid': {
- $options['platid'] = min(max(1, intval($val)), 3);
- break;
- }
- case 'n':
- case 'encid': {
- $options['encid'] = min(max(0, intval($val)), 10);
- break;
- }
- case 'b':
- case 'addcbbox': {
- $options['addcbbox'] = true;
- break;
- }
- case 'l':
- case 'link': {
- $options['link'] = true;
- break;
- }
- case 'i':
- case 'fonts': {
- $options['fonts'] = explode(',', $val);
- break;
- }
- case 'h':
- case 'help':
- default: {
- showHelp();
- break;
- }
- } // end of switch
- } // end of while loop
- if (empty($options['fonts'])) {
- echo "ERROR: missing input fonts (try --help for usage)\n\n";
- exit(2);
- }
- // check the output path
- if (!is_dir($options['outpath']) OR !is_writable($options['outpath'])) {
- echo "ERROR: Can't write to ".$options['outpath']."\n\n";
- exit(3);
- }
- echo "\n>>> Converting fonts for TCPDF:\n";
- echo '*** Output dir set to '.$options['outpath']."\n";
- // check if there are conversion errors
- $errors = false;
- foreach ($options['fonts'] as $font) {
- $fontfile = realpath($font);
- $fontname = TCPDF_FONTS::addTTFfont($fontfile, $options['type'], $options['enc'], $options['flags'], $options['outpath'], $options['platid'], $options['encid'], $options['addcbbox'], $options['link']);
- if ($fontname === false) {
- $errors = true;
- echo "--- ERROR: can't add ".$font."\n";
- } else {
- echo "+++ OK : ".$fontfile.' added as '.$fontname."\n";
- }
- }
- if ($errors) {
- echo "--- Process completed with ERRORS!\n\n";
- exit(4);
- }
- echo ">>> Process successfully completed!\n\n";
- exit(0);
- //============================================================+
- // END OF FILE
- //============================================================+
|