composer v1
This commit is contained in:
10
composer.json
Normal file
10
composer.json
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"name": "franzz/objects",
|
||||||
|
"description": "Objects",
|
||||||
|
"type": "library",
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Franzz\\Objects\\": "inc"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
55
inc/db.php
55
inc/db.php
@@ -1,5 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
namespace Franzz\Objects;
|
||||||
|
use \Settings;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* MySql query manager and generator
|
* MySql query manager and generator
|
||||||
* @author franzz
|
* @author franzz
|
||||||
@@ -23,10 +26,10 @@ class Db extends PhpObject
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* SQL connection Handle
|
* SQL connection Handle
|
||||||
* @var mysqli
|
* @var \mysqli
|
||||||
*/
|
*/
|
||||||
private $oConnection;
|
private $oConnection;
|
||||||
private $sDatabase;
|
private $asConf;
|
||||||
private $asOptions;
|
private $asOptions;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -37,20 +40,14 @@ class Db extends PhpObject
|
|||||||
* 'cascading_delete'=>array('table_name1'=>array('linked_table1', 'linked_table2', ...), 'table_name2'=>...))
|
* 'cascading_delete'=>array('table_name1'=>array('linked_table1', 'linked_table2', ...), 'table_name2'=>...))
|
||||||
* @var Array
|
* @var Array
|
||||||
*/
|
*/
|
||||||
public function __construct($sDbServer, $sLogin, $sPass, $sDatabase, $asOptions, $sEncoding='utf8mb4')
|
public function __construct($asConf, $asOptions)
|
||||||
{
|
{
|
||||||
parent::__construct(__FILE__, Settings::DEBUG);
|
$this->asConf = $asConf;
|
||||||
$this->sDatabase = $sDatabase;
|
|
||||||
$this->asOptions = $asOptions;
|
$this->asOptions = $asOptions;
|
||||||
//$this->oConnection = mysql_connect(self::DB_SERVER, self::DB_LOGIN, self::DB_PASS);
|
|
||||||
$this->oConnection = new mysqli($sDbServer, $sLogin, $sPass);
|
|
||||||
$this->syncPhpParams($sEncoding);
|
|
||||||
|
|
||||||
/*
|
parent::__construct(__FILE__, Settings::DEBUG);
|
||||||
$dsn = 'mysql:dbname='.$this->sDatabase.';host='.self::DB_SERVER;
|
$this->oConnection = new \mysqli($this->getConf('server'), $this->getConf('user'), $this->getConf('pass'));
|
||||||
try {$dbh = new PDO($dsn, self::DB_LOGIN, self::DB_PASS);}
|
$this->syncPhpParams($this->getConf('encoding'));
|
||||||
catch (PDOException $e) {$this->addError('Connexion échouée : ' . $e->getMessage());}
|
|
||||||
*/
|
|
||||||
|
|
||||||
$this->setTrace(false);
|
$this->setTrace(false);
|
||||||
if($this->oConnection->connect_error)
|
if($this->oConnection->connect_error)
|
||||||
@@ -60,7 +57,7 @@ class Db extends PhpObject
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(!$this->oConnection->select_db($this->sDatabase))
|
if(!$this->oConnection->select_db($this->getConf('database')))
|
||||||
{
|
{
|
||||||
$this->addError('Could not find database "'.$this->sDatabase.'"');
|
$this->addError('Could not find database "'.$this->sDatabase.'"');
|
||||||
$this->sDbState = self::DB_NO_DATA;
|
$this->sDbState = self::DB_NO_DATA;
|
||||||
@@ -73,6 +70,10 @@ class Db extends PhpObject
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function getConf($sConf) {
|
||||||
|
return $this->asConf[$sConf] ?? null;
|
||||||
|
}
|
||||||
|
|
||||||
private function syncPhpParams($sEncoding)
|
private function syncPhpParams($sEncoding)
|
||||||
{
|
{
|
||||||
//Characters encoding
|
//Characters encoding
|
||||||
@@ -91,7 +92,6 @@ class Db extends PhpObject
|
|||||||
public function setTrace($bTrace=true)
|
public function setTrace($bTrace=true)
|
||||||
{
|
{
|
||||||
$this->bTrace = $bTrace;
|
$this->bTrace = $bTrace;
|
||||||
//if($bTrace) $this->setDebug(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getTrace()
|
public function getTrace()
|
||||||
@@ -108,7 +108,7 @@ class Db extends PhpObject
|
|||||||
{
|
{
|
||||||
//Create Database
|
//Create Database
|
||||||
$this->setQuery("DROP DATABASE IF EXISTS ".$this->sDatabase);
|
$this->setQuery("DROP DATABASE IF EXISTS ".$this->sDatabase);
|
||||||
$this->setQuery("CREATE DATABASE ".$this->sDatabase." DEFAULT CHARACTER SET ".Settings::DB_ENC." DEFAULT COLLATE ".Settings::DB_ENC."_general_ci");
|
$this->setQuery("CREATE DATABASE ".$this->sDatabase." DEFAULT CHARACTER SET ".$this->getConf('encoding')." DEFAULT COLLATE ".$this->getConf('encoding')."_general_ci");
|
||||||
$this->oConnection->select_db($this->sDatabase);
|
$this->oConnection->select_db($this->sDatabase);
|
||||||
|
|
||||||
//Create tables
|
//Create tables
|
||||||
@@ -120,7 +120,7 @@ class Db extends PhpObject
|
|||||||
|
|
||||||
$sAppPath = '';
|
$sAppPath = '';
|
||||||
if(strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') $sAppPath = 'C:\ProgramData\xampp\mysql\bin\\';
|
if(strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') $sAppPath = 'C:\ProgramData\xampp\mysql\bin\\';
|
||||||
exec($sAppPath.'mysqldump --user='.Settings::DB_LOGIN.' --password='.Settings::DB_PASS.' '.Settings::DB_NAME.' --add-drop-table --result-file='.$sBackupFile);
|
exec($sAppPath.'mysqldump --user='.$this->getConf('user').' --password='.$this->getConf('pass').' '.$this->getConf('database').' --add-drop-table --result-file='.$sBackupFile);
|
||||||
if(file_exists($sBackupFile)) {
|
if(file_exists($sBackupFile)) {
|
||||||
$sBackup = file_get_contents($sBackupFile);
|
$sBackup = file_get_contents($sBackupFile);
|
||||||
unlink($sBackupFile);
|
unlink($sBackupFile);
|
||||||
@@ -133,7 +133,7 @@ class Db extends PhpObject
|
|||||||
$sAppPath = '';
|
$sAppPath = '';
|
||||||
if(file_exists($sBackupFile)) {
|
if(file_exists($sBackupFile)) {
|
||||||
if(strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') $sAppPath = 'C:\ProgramData\xampp\mysql\bin\\';
|
if(strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') $sAppPath = 'C:\ProgramData\xampp\mysql\bin\\';
|
||||||
return exec($sAppPath.'mysql --user='.Settings::DB_LOGIN.' --password='.Settings::DB_PASS.' '.Settings::DB_NAME.' < '.$sBackupFile);
|
return exec($sAppPath.'mysql --user='.$this->getConf('user').' --password='.$this->getConf('pass').' '.$this->getConf('database').' < '.$sBackupFile);
|
||||||
}
|
}
|
||||||
else return false;
|
else return false;
|
||||||
}
|
}
|
||||||
@@ -750,23 +750,4 @@ class Db extends PhpObject
|
|||||||
return array_combine($asKeys, $asValues);
|
return array_combine($asKeys, $asValues);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
public function select($asFields='*')
|
|
||||||
{
|
|
||||||
$oSql = new Sql($this, array('select'=>$asFields));
|
|
||||||
return $oSql;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function from($sTable)
|
|
||||||
{
|
|
||||||
$oSql = new Sql($this, array('from'=>$sTable));
|
|
||||||
return $oSql;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getConnection()
|
|
||||||
{
|
|
||||||
return $this->oConnection;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|||||||
28
inc/main.php
28
inc/main.php
@@ -1,5 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
namespace Franzz\Objects;
|
||||||
|
use \Settings;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Main Class
|
* Main Class
|
||||||
* @author franzz
|
* @author franzz
|
||||||
@@ -20,12 +23,6 @@ abstract class Main extends PhpObject
|
|||||||
//Folders
|
//Folders
|
||||||
const MASKS_FOLDER = 'masks/';
|
const MASKS_FOLDER = 'masks/';
|
||||||
|
|
||||||
/**
|
|
||||||
* Class Management
|
|
||||||
* @var ClassManagement
|
|
||||||
*/
|
|
||||||
protected $oClassManagement;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* DB Handle
|
* DB Handle
|
||||||
* @var Db
|
* @var Db
|
||||||
@@ -50,24 +47,23 @@ abstract class Main extends PhpObject
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Main constructor
|
* Main constructor
|
||||||
* @param ClassManagement $oClassManagement
|
|
||||||
* @param string $sLang
|
|
||||||
*/
|
*/
|
||||||
public function __construct($oClassManagement, $sProcessPage, $asMandatoryClasses=array(), $bDb=true, $sFile=__FILE__, $sTimeZone='')
|
public function __construct($sProcessPage, $bDb=true, $sFile=__FILE__, $sTimeZone='')
|
||||||
{
|
{
|
||||||
parent::__construct($sFile, Settings::DEBUG);
|
parent::__construct($sFile, Settings::DEBUG);
|
||||||
$this->oClassManagement = $oClassManagement;
|
|
||||||
|
|
||||||
//Load classes
|
|
||||||
$asMandatoryClasses[] = array('name'=>'mask', 'project'=>false);
|
|
||||||
if($bDb) $asMandatoryClasses[] = array('name'=>'db', 'project'=>false);
|
|
||||||
foreach($asMandatoryClasses as $asClass) $this->oClassManagement->incClass($asClass['name'], $asClass['project']);
|
|
||||||
|
|
||||||
$this->setContext($sProcessPage, $sTimeZone);
|
$this->setContext($sProcessPage, $sTimeZone);
|
||||||
|
|
||||||
//Init objects
|
//Init objects
|
||||||
if($bDb) {
|
if($bDb) {
|
||||||
$this->oDb = new Db(Settings::DB_SERVER, Settings::DB_LOGIN, Settings::DB_PASS, Settings::DB_NAME, $this->getSqlOptions() , Settings::DB_ENC);
|
$asConf = array(
|
||||||
|
'server' => Settings::DB_SERVER,
|
||||||
|
'database' => Settings::DB_NAME,
|
||||||
|
'user' => Settings::DB_LOGIN,
|
||||||
|
'pass' => Settings::DB_PASS,
|
||||||
|
'encoding' => Settings::DB_ENC
|
||||||
|
);
|
||||||
|
$this->oDb = new Db($asConf, $this->getSqlOptions());
|
||||||
if(in_array($this->oDb->sDbState, array(Db::DB_NO_DATA, Db::DB_NO_TABLE))) $this->install();
|
if(in_array($this->oDb->sDbState, array(Db::DB_NO_DATA, Db::DB_NO_TABLE))) $this->install();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
namespace Franzz\Objects;
|
||||||
|
use \Settings;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Mask Reader
|
* Mask Reader
|
||||||
* @author franzz
|
* @author franzz
|
||||||
@@ -293,7 +296,7 @@ class Mask extends PhpObject
|
|||||||
if(!is_null($this->oLang) && self::isLangTag($sTagValue)) $sTagValue = $this->oLang->getTranslation($sTagActValue, $this->asTagsParams[$sTagName]);
|
if(!is_null($this->oLang) && self::isLangTag($sTagValue)) $sTagValue = $this->oLang->getTranslation($sTagActValue, $this->asTagsParams[$sTagName]);
|
||||||
|
|
||||||
//Convert Value to Mask Time Zone
|
//Convert Value to Mask Time Zone
|
||||||
if(self::isTimeTag($sTagValue)) $sTagValue = (new DateTime('@'.$sTagActValue))->setTimeZone(new DateTimeZone($this->sTimezone))->format($this->asTagsParams[$sTagName]);;
|
if(self::isTimeTag($sTagValue)) $sTagValue = (new \DateTime('@'.$sTagActValue))->setTimeZone(new \DateTimeZone($this->sTimezone))->format($this->asTagsParams[$sTagName]);;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Replace Tags
|
//Replace Tags
|
||||||
|
|||||||
69
class_management.php → inc/phpobject.php
Executable file → Normal file
69
class_management.php → inc/phpobject.php
Executable file → Normal file
@@ -1,72 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
/**
|
namespace Franzz\Objects;
|
||||||
* Manage includes
|
use \Settings;
|
||||||
* @author franzz
|
|
||||||
* @version 1.2
|
|
||||||
*/
|
|
||||||
class ClassManagement extends PhpObject
|
|
||||||
{
|
|
||||||
const OBJECT_FOLDER = '../objects/';
|
|
||||||
const INC_FOLDER = 'inc/';
|
|
||||||
const INC_EXT = '.php';
|
|
||||||
const SETTINGS_FILE = 'settings.php';
|
|
||||||
const GLOBAL_SETTINGS_FILE = 'globalsettings.php';
|
|
||||||
const TOOLBOX_CLASS = 'toolbox';
|
|
||||||
const MAIN_CLASS_ABS = 'main';
|
|
||||||
|
|
||||||
private $asIncFiles;
|
|
||||||
|
|
||||||
function __construct($sMainClass)
|
|
||||||
{
|
|
||||||
parent::__construct(__FILE__, true);
|
|
||||||
$this->asIncFiles = array();
|
|
||||||
|
|
||||||
//try to include default files
|
|
||||||
$this->incFile(self::OBJECT_FOLDER.self::GLOBAL_SETTINGS_FILE);
|
|
||||||
$this->incFile(self::SETTINGS_FILE);
|
|
||||||
$this->incClass(self::TOOLBOX_CLASS);
|
|
||||||
|
|
||||||
//Include main class
|
|
||||||
$this->incClass(self::MAIN_CLASS_ABS);
|
|
||||||
$this->incClass($sMainClass, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
function __destruct()
|
|
||||||
{
|
|
||||||
parent::__destruct();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function incClass($sClassName, $bProjectClass=false)
|
|
||||||
{
|
|
||||||
$sProject = $bProjectClass?'':self::OBJECT_FOLDER;
|
|
||||||
$sFile = $sProject.self::INC_FOLDER.$sClassName.self::INC_EXT;
|
|
||||||
return $this->incFile($sFile);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function incFile($sFilePath, $bMandatory=true)
|
|
||||||
{
|
|
||||||
$bIncluded = false;
|
|
||||||
if(!in_array($sFilePath, $this->asIncFiles))
|
|
||||||
{
|
|
||||||
$sMissingFile = 'File "'.$sFilePath.'" missing.';
|
|
||||||
if(file_exists($sFilePath))
|
|
||||||
{
|
|
||||||
$bIncluded = require_once($sFilePath);
|
|
||||||
$this->asIncFiles[] = $sFilePath;
|
|
||||||
}
|
|
||||||
elseif($bMandatory)
|
|
||||||
{
|
|
||||||
die($sMissingFile.' Stopping process.');
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$this->addError($sMissingFile);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return $bIncluded;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* PHP Object
|
* PHP Object
|
||||||
@@ -1,5 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
namespace Franzz\Objects;
|
||||||
|
use \Settings;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* RSS Feed Class
|
* RSS Feed Class
|
||||||
* @author franzz
|
* @author franzz
|
||||||
|
|||||||
456
inc/toolbox.php
456
inc/toolbox.php
@@ -1,5 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
namespace Franzz\Objects;
|
||||||
|
use \Settings;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ToolBox - Only static functions missing from php library
|
* ToolBox - Only static functions missing from php library
|
||||||
* @author franzz
|
* @author franzz
|
||||||
@@ -81,39 +84,6 @@ class ToolBox
|
|||||||
return $acText;
|
return $acText;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param String $sFromName
|
|
||||||
* @param String $sSubject
|
|
||||||
* @param String $sMessage
|
|
||||||
* @param String $sTo
|
|
||||||
* @param Array $asCc array(name => email)
|
|
||||||
* @param Boolean $bSelfMail
|
|
||||||
* @return mixed
|
|
||||||
*/
|
|
||||||
public function sendMail($sFromName, $sSubject, $sMessage, $sTo, $asCc=array(), $bSelfMail=true)
|
|
||||||
{
|
|
||||||
$asForm = array('api_key'=>Settings::MAIL_API_KEY,
|
|
||||||
'app'=>'Wedding',
|
|
||||||
'from_name'=>$sFromName,
|
|
||||||
'subject'=>$sSubject,
|
|
||||||
'msg'=>$sMessage,
|
|
||||||
'to_email'=>$sTo,
|
|
||||||
'cc_email'=>self::jsonConvert($asCc),
|
|
||||||
'self'=>$bSelfMail);
|
|
||||||
|
|
||||||
$oCurl = curl_init();
|
|
||||||
curl_setopt($oCurl, CURLOPT_URL, Settings::MAIL_SCRIPT);
|
|
||||||
curl_setopt($oCurl, CURLOPT_POST, true);
|
|
||||||
curl_setopt($oCurl, CURLOPT_HEADER, false);
|
|
||||||
curl_setopt($oCurl, CURLOPT_RETURNTRANSFER, true);
|
|
||||||
curl_setopt($oCurl, CURLOPT_POSTFIELDS, $asForm);
|
|
||||||
$iResult = curl_exec($oCurl);
|
|
||||||
curl_close($oCurl);
|
|
||||||
|
|
||||||
return $iResult;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function jsonExport($asData)
|
public static function jsonExport($asData)
|
||||||
{
|
{
|
||||||
header('Content-type: application/json');
|
header('Content-type: application/json');
|
||||||
@@ -170,7 +140,7 @@ class ToolBox
|
|||||||
//Retrieving file Content Type
|
//Retrieving file Content Type
|
||||||
if(file_exists($sPath)) //Local
|
if(file_exists($sPath)) //Local
|
||||||
{
|
{
|
||||||
$oFileInfo = new finfo(FILEINFO_MIME);
|
$oFileInfo = new \finfo(FILEINFO_MIME);
|
||||||
$sMimetype = $oFileInfo->file($sPath);
|
$sMimetype = $oFileInfo->file($sPath);
|
||||||
}
|
}
|
||||||
else //Remote
|
else //Remote
|
||||||
@@ -346,7 +316,7 @@ class ToolBox
|
|||||||
return $asResult;
|
return $asResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function copyExif($srcfile, $destfile) {
|
public static function copyExif($srcfile, $destfile) {
|
||||||
// Function transfers EXIF (APP1) and IPTC (APP13) from $srcfile and adds it to $destfile
|
// Function transfers EXIF (APP1) and IPTC (APP13) from $srcfile and adds it to $destfile
|
||||||
// JPEG file has format 0xFFD8 + [APP0] + [APP1] + ... [APP15] + <image data> where [APPi] are optional
|
// JPEG file has format 0xFFD8 + [APP0] + [APP1] + ... [APP15] + <image data> where [APPi] are optional
|
||||||
// Segment APPi (where i=0x0 to 0xF) has format 0xFFEi + 0xMM + 0xLL + <data> (where 0xMM is
|
// Segment APPi (where i=0x0 to 0xF) has format 0xFFEi + 0xMM + 0xLL + <data> (where 0xMM is
|
||||||
@@ -591,227 +561,205 @@ class ToolBox
|
|||||||
{
|
{
|
||||||
if(!preg_match('/[\x80-\xff]/', $string)) return $string;
|
if(!preg_match('/[\x80-\xff]/', $string)) return $string;
|
||||||
|
|
||||||
if (true || seems_utf8($string)) {
|
$chars = array(
|
||||||
$chars = array(
|
// Decompositions for Latin-1 Supplement
|
||||||
// Decompositions for Latin-1 Supplement
|
chr(194).chr(170) => 'a', chr(194).chr(186) => 'o',
|
||||||
chr(194).chr(170) => 'a', chr(194).chr(186) => 'o',
|
chr(195).chr(128) => 'A', chr(195).chr(129) => 'A',
|
||||||
chr(195).chr(128) => 'A', chr(195).chr(129) => 'A',
|
chr(195).chr(130) => 'A', chr(195).chr(131) => 'A',
|
||||||
chr(195).chr(130) => 'A', chr(195).chr(131) => 'A',
|
chr(195).chr(132) => 'A', chr(195).chr(133) => 'A',
|
||||||
chr(195).chr(132) => 'A', chr(195).chr(133) => 'A',
|
chr(195).chr(134) => 'AE',chr(195).chr(135) => 'C',
|
||||||
chr(195).chr(134) => 'AE',chr(195).chr(135) => 'C',
|
chr(195).chr(136) => 'E', chr(195).chr(137) => 'E',
|
||||||
chr(195).chr(136) => 'E', chr(195).chr(137) => 'E',
|
chr(195).chr(138) => 'E', chr(195).chr(139) => 'E',
|
||||||
chr(195).chr(138) => 'E', chr(195).chr(139) => 'E',
|
chr(195).chr(140) => 'I', chr(195).chr(141) => 'I',
|
||||||
chr(195).chr(140) => 'I', chr(195).chr(141) => 'I',
|
chr(195).chr(142) => 'I', chr(195).chr(143) => 'I',
|
||||||
chr(195).chr(142) => 'I', chr(195).chr(143) => 'I',
|
chr(195).chr(144) => 'D', chr(195).chr(145) => 'N',
|
||||||
chr(195).chr(144) => 'D', chr(195).chr(145) => 'N',
|
chr(195).chr(146) => 'O', chr(195).chr(147) => 'O',
|
||||||
chr(195).chr(146) => 'O', chr(195).chr(147) => 'O',
|
chr(195).chr(148) => 'O', chr(195).chr(149) => 'O',
|
||||||
chr(195).chr(148) => 'O', chr(195).chr(149) => 'O',
|
chr(195).chr(150) => 'O', chr(195).chr(153) => 'U',
|
||||||
chr(195).chr(150) => 'O', chr(195).chr(153) => 'U',
|
chr(195).chr(154) => 'U', chr(195).chr(155) => 'U',
|
||||||
chr(195).chr(154) => 'U', chr(195).chr(155) => 'U',
|
chr(195).chr(156) => 'U', chr(195).chr(157) => 'Y',
|
||||||
chr(195).chr(156) => 'U', chr(195).chr(157) => 'Y',
|
chr(195).chr(158) => 'TH',chr(195).chr(159) => 's',
|
||||||
chr(195).chr(158) => 'TH',chr(195).chr(159) => 's',
|
chr(195).chr(160) => 'a', chr(195).chr(161) => 'a',
|
||||||
chr(195).chr(160) => 'a', chr(195).chr(161) => 'a',
|
chr(195).chr(162) => 'a', chr(195).chr(163) => 'a',
|
||||||
chr(195).chr(162) => 'a', chr(195).chr(163) => 'a',
|
chr(195).chr(164) => 'a', chr(195).chr(165) => 'a',
|
||||||
chr(195).chr(164) => 'a', chr(195).chr(165) => 'a',
|
chr(195).chr(166) => 'ae',chr(195).chr(167) => 'c',
|
||||||
chr(195).chr(166) => 'ae',chr(195).chr(167) => 'c',
|
chr(195).chr(168) => 'e', chr(195).chr(169) => 'e',
|
||||||
chr(195).chr(168) => 'e', chr(195).chr(169) => 'e',
|
chr(195).chr(170) => 'e', chr(195).chr(171) => 'e',
|
||||||
chr(195).chr(170) => 'e', chr(195).chr(171) => 'e',
|
chr(195).chr(172) => 'i', chr(195).chr(173) => 'i',
|
||||||
chr(195).chr(172) => 'i', chr(195).chr(173) => 'i',
|
chr(195).chr(174) => 'i', chr(195).chr(175) => 'i',
|
||||||
chr(195).chr(174) => 'i', chr(195).chr(175) => 'i',
|
chr(195).chr(176) => 'd', chr(195).chr(177) => 'n',
|
||||||
chr(195).chr(176) => 'd', chr(195).chr(177) => 'n',
|
chr(195).chr(178) => 'o', chr(195).chr(179) => 'o',
|
||||||
chr(195).chr(178) => 'o', chr(195).chr(179) => 'o',
|
chr(195).chr(180) => 'o', chr(195).chr(181) => 'o',
|
||||||
chr(195).chr(180) => 'o', chr(195).chr(181) => 'o',
|
chr(195).chr(182) => 'o', chr(195).chr(184) => 'o',
|
||||||
chr(195).chr(182) => 'o', chr(195).chr(184) => 'o',
|
chr(195).chr(185) => 'u', chr(195).chr(186) => 'u',
|
||||||
chr(195).chr(185) => 'u', chr(195).chr(186) => 'u',
|
chr(195).chr(187) => 'u', chr(195).chr(188) => 'u',
|
||||||
chr(195).chr(187) => 'u', chr(195).chr(188) => 'u',
|
chr(195).chr(189) => 'y', chr(195).chr(190) => 'th',
|
||||||
chr(195).chr(189) => 'y', chr(195).chr(190) => 'th',
|
chr(195).chr(191) => 'y', chr(195).chr(152) => 'O',
|
||||||
chr(195).chr(191) => 'y', chr(195).chr(152) => 'O',
|
// Decompositions for Latin Extended-A
|
||||||
// Decompositions for Latin Extended-A
|
chr(196).chr(128) => 'A', chr(196).chr(129) => 'a',
|
||||||
chr(196).chr(128) => 'A', chr(196).chr(129) => 'a',
|
chr(196).chr(130) => 'A', chr(196).chr(131) => 'a',
|
||||||
chr(196).chr(130) => 'A', chr(196).chr(131) => 'a',
|
chr(196).chr(132) => 'A', chr(196).chr(133) => 'a',
|
||||||
chr(196).chr(132) => 'A', chr(196).chr(133) => 'a',
|
chr(196).chr(134) => 'C', chr(196).chr(135) => 'c',
|
||||||
chr(196).chr(134) => 'C', chr(196).chr(135) => 'c',
|
chr(196).chr(136) => 'C', chr(196).chr(137) => 'c',
|
||||||
chr(196).chr(136) => 'C', chr(196).chr(137) => 'c',
|
chr(196).chr(138) => 'C', chr(196).chr(139) => 'c',
|
||||||
chr(196).chr(138) => 'C', chr(196).chr(139) => 'c',
|
chr(196).chr(140) => 'C', chr(196).chr(141) => 'c',
|
||||||
chr(196).chr(140) => 'C', chr(196).chr(141) => 'c',
|
chr(196).chr(142) => 'D', chr(196).chr(143) => 'd',
|
||||||
chr(196).chr(142) => 'D', chr(196).chr(143) => 'd',
|
chr(196).chr(144) => 'D', chr(196).chr(145) => 'd',
|
||||||
chr(196).chr(144) => 'D', chr(196).chr(145) => 'd',
|
chr(196).chr(146) => 'E', chr(196).chr(147) => 'e',
|
||||||
chr(196).chr(146) => 'E', chr(196).chr(147) => 'e',
|
chr(196).chr(148) => 'E', chr(196).chr(149) => 'e',
|
||||||
chr(196).chr(148) => 'E', chr(196).chr(149) => 'e',
|
chr(196).chr(150) => 'E', chr(196).chr(151) => 'e',
|
||||||
chr(196).chr(150) => 'E', chr(196).chr(151) => 'e',
|
chr(196).chr(152) => 'E', chr(196).chr(153) => 'e',
|
||||||
chr(196).chr(152) => 'E', chr(196).chr(153) => 'e',
|
chr(196).chr(154) => 'E', chr(196).chr(155) => 'e',
|
||||||
chr(196).chr(154) => 'E', chr(196).chr(155) => 'e',
|
chr(196).chr(156) => 'G', chr(196).chr(157) => 'g',
|
||||||
chr(196).chr(156) => 'G', chr(196).chr(157) => 'g',
|
chr(196).chr(158) => 'G', chr(196).chr(159) => 'g',
|
||||||
chr(196).chr(158) => 'G', chr(196).chr(159) => 'g',
|
chr(196).chr(160) => 'G', chr(196).chr(161) => 'g',
|
||||||
chr(196).chr(160) => 'G', chr(196).chr(161) => 'g',
|
chr(196).chr(162) => 'G', chr(196).chr(163) => 'g',
|
||||||
chr(196).chr(162) => 'G', chr(196).chr(163) => 'g',
|
chr(196).chr(164) => 'H', chr(196).chr(165) => 'h',
|
||||||
chr(196).chr(164) => 'H', chr(196).chr(165) => 'h',
|
chr(196).chr(166) => 'H', chr(196).chr(167) => 'h',
|
||||||
chr(196).chr(166) => 'H', chr(196).chr(167) => 'h',
|
chr(196).chr(168) => 'I', chr(196).chr(169) => 'i',
|
||||||
chr(196).chr(168) => 'I', chr(196).chr(169) => 'i',
|
chr(196).chr(170) => 'I', chr(196).chr(171) => 'i',
|
||||||
chr(196).chr(170) => 'I', chr(196).chr(171) => 'i',
|
chr(196).chr(172) => 'I', chr(196).chr(173) => 'i',
|
||||||
chr(196).chr(172) => 'I', chr(196).chr(173) => 'i',
|
chr(196).chr(174) => 'I', chr(196).chr(175) => 'i',
|
||||||
chr(196).chr(174) => 'I', chr(196).chr(175) => 'i',
|
chr(196).chr(176) => 'I', chr(196).chr(177) => 'i',
|
||||||
chr(196).chr(176) => 'I', chr(196).chr(177) => 'i',
|
chr(196).chr(178) => 'IJ',chr(196).chr(179) => 'ij',
|
||||||
chr(196).chr(178) => 'IJ',chr(196).chr(179) => 'ij',
|
chr(196).chr(180) => 'J', chr(196).chr(181) => 'j',
|
||||||
chr(196).chr(180) => 'J', chr(196).chr(181) => 'j',
|
chr(196).chr(182) => 'K', chr(196).chr(183) => 'k',
|
||||||
chr(196).chr(182) => 'K', chr(196).chr(183) => 'k',
|
chr(196).chr(184) => 'k', chr(196).chr(185) => 'L',
|
||||||
chr(196).chr(184) => 'k', chr(196).chr(185) => 'L',
|
chr(196).chr(186) => 'l', chr(196).chr(187) => 'L',
|
||||||
chr(196).chr(186) => 'l', chr(196).chr(187) => 'L',
|
chr(196).chr(188) => 'l', chr(196).chr(189) => 'L',
|
||||||
chr(196).chr(188) => 'l', chr(196).chr(189) => 'L',
|
chr(196).chr(190) => 'l', chr(196).chr(191) => 'L',
|
||||||
chr(196).chr(190) => 'l', chr(196).chr(191) => 'L',
|
chr(197).chr(128) => 'l', chr(197).chr(129) => 'L',
|
||||||
chr(197).chr(128) => 'l', chr(197).chr(129) => 'L',
|
chr(197).chr(130) => 'l', chr(197).chr(131) => 'N',
|
||||||
chr(197).chr(130) => 'l', chr(197).chr(131) => 'N',
|
chr(197).chr(132) => 'n', chr(197).chr(133) => 'N',
|
||||||
chr(197).chr(132) => 'n', chr(197).chr(133) => 'N',
|
chr(197).chr(134) => 'n', chr(197).chr(135) => 'N',
|
||||||
chr(197).chr(134) => 'n', chr(197).chr(135) => 'N',
|
chr(197).chr(136) => 'n', chr(197).chr(137) => 'N',
|
||||||
chr(197).chr(136) => 'n', chr(197).chr(137) => 'N',
|
chr(197).chr(138) => 'n', chr(197).chr(139) => 'N',
|
||||||
chr(197).chr(138) => 'n', chr(197).chr(139) => 'N',
|
chr(197).chr(140) => 'O', chr(197).chr(141) => 'o',
|
||||||
chr(197).chr(140) => 'O', chr(197).chr(141) => 'o',
|
chr(197).chr(142) => 'O', chr(197).chr(143) => 'o',
|
||||||
chr(197).chr(142) => 'O', chr(197).chr(143) => 'o',
|
chr(197).chr(144) => 'O', chr(197).chr(145) => 'o',
|
||||||
chr(197).chr(144) => 'O', chr(197).chr(145) => 'o',
|
chr(197).chr(146) => 'OE',chr(197).chr(147) => 'oe',
|
||||||
chr(197).chr(146) => 'OE',chr(197).chr(147) => 'oe',
|
chr(197).chr(148) => 'R',chr(197).chr(149) => 'r',
|
||||||
chr(197).chr(148) => 'R',chr(197).chr(149) => 'r',
|
chr(197).chr(150) => 'R',chr(197).chr(151) => 'r',
|
||||||
chr(197).chr(150) => 'R',chr(197).chr(151) => 'r',
|
chr(197).chr(152) => 'R',chr(197).chr(153) => 'r',
|
||||||
chr(197).chr(152) => 'R',chr(197).chr(153) => 'r',
|
chr(197).chr(154) => 'S',chr(197).chr(155) => 's',
|
||||||
chr(197).chr(154) => 'S',chr(197).chr(155) => 's',
|
chr(197).chr(156) => 'S',chr(197).chr(157) => 's',
|
||||||
chr(197).chr(156) => 'S',chr(197).chr(157) => 's',
|
chr(197).chr(158) => 'S',chr(197).chr(159) => 's',
|
||||||
chr(197).chr(158) => 'S',chr(197).chr(159) => 's',
|
chr(197).chr(160) => 'S', chr(197).chr(161) => 's',
|
||||||
chr(197).chr(160) => 'S', chr(197).chr(161) => 's',
|
chr(197).chr(162) => 'T', chr(197).chr(163) => 't',
|
||||||
chr(197).chr(162) => 'T', chr(197).chr(163) => 't',
|
chr(197).chr(164) => 'T', chr(197).chr(165) => 't',
|
||||||
chr(197).chr(164) => 'T', chr(197).chr(165) => 't',
|
chr(197).chr(166) => 'T', chr(197).chr(167) => 't',
|
||||||
chr(197).chr(166) => 'T', chr(197).chr(167) => 't',
|
chr(197).chr(168) => 'U', chr(197).chr(169) => 'u',
|
||||||
chr(197).chr(168) => 'U', chr(197).chr(169) => 'u',
|
chr(197).chr(170) => 'U', chr(197).chr(171) => 'u',
|
||||||
chr(197).chr(170) => 'U', chr(197).chr(171) => 'u',
|
chr(197).chr(172) => 'U', chr(197).chr(173) => 'u',
|
||||||
chr(197).chr(172) => 'U', chr(197).chr(173) => 'u',
|
chr(197).chr(174) => 'U', chr(197).chr(175) => 'u',
|
||||||
chr(197).chr(174) => 'U', chr(197).chr(175) => 'u',
|
chr(197).chr(176) => 'U', chr(197).chr(177) => 'u',
|
||||||
chr(197).chr(176) => 'U', chr(197).chr(177) => 'u',
|
chr(197).chr(178) => 'U', chr(197).chr(179) => 'u',
|
||||||
chr(197).chr(178) => 'U', chr(197).chr(179) => 'u',
|
chr(197).chr(180) => 'W', chr(197).chr(181) => 'w',
|
||||||
chr(197).chr(180) => 'W', chr(197).chr(181) => 'w',
|
chr(197).chr(182) => 'Y', chr(197).chr(183) => 'y',
|
||||||
chr(197).chr(182) => 'Y', chr(197).chr(183) => 'y',
|
chr(197).chr(184) => 'Y', chr(197).chr(185) => 'Z',
|
||||||
chr(197).chr(184) => 'Y', chr(197).chr(185) => 'Z',
|
chr(197).chr(186) => 'z', chr(197).chr(187) => 'Z',
|
||||||
chr(197).chr(186) => 'z', chr(197).chr(187) => 'Z',
|
chr(197).chr(188) => 'z', chr(197).chr(189) => 'Z',
|
||||||
chr(197).chr(188) => 'z', chr(197).chr(189) => 'Z',
|
chr(197).chr(190) => 'z', chr(197).chr(191) => 's',
|
||||||
chr(197).chr(190) => 'z', chr(197).chr(191) => 's',
|
// Decompositions for Latin Extended-B
|
||||||
// Decompositions for Latin Extended-B
|
chr(200).chr(152) => 'S', chr(200).chr(153) => 's',
|
||||||
chr(200).chr(152) => 'S', chr(200).chr(153) => 's',
|
chr(200).chr(154) => 'T', chr(200).chr(155) => 't',
|
||||||
chr(200).chr(154) => 'T', chr(200).chr(155) => 't',
|
// Euro Sign
|
||||||
// Euro Sign
|
chr(226).chr(130).chr(172) => 'E',
|
||||||
chr(226).chr(130).chr(172) => 'E',
|
// GBP (Pound) Sign
|
||||||
// GBP (Pound) Sign
|
chr(194).chr(163) => '',
|
||||||
chr(194).chr(163) => '',
|
// Vowels with diacritic (Vietnamese)
|
||||||
// Vowels with diacritic (Vietnamese)
|
// unmarked
|
||||||
// unmarked
|
chr(198).chr(160) => 'O', chr(198).chr(161) => 'o',
|
||||||
chr(198).chr(160) => 'O', chr(198).chr(161) => 'o',
|
chr(198).chr(175) => 'U', chr(198).chr(176) => 'u',
|
||||||
chr(198).chr(175) => 'U', chr(198).chr(176) => 'u',
|
// grave accent
|
||||||
// grave accent
|
chr(225).chr(186).chr(166) => 'A', chr(225).chr(186).chr(167) => 'a',
|
||||||
chr(225).chr(186).chr(166) => 'A', chr(225).chr(186).chr(167) => 'a',
|
chr(225).chr(186).chr(176) => 'A', chr(225).chr(186).chr(177) => 'a',
|
||||||
chr(225).chr(186).chr(176) => 'A', chr(225).chr(186).chr(177) => 'a',
|
chr(225).chr(187).chr(128) => 'E', chr(225).chr(187).chr(129) => 'e',
|
||||||
chr(225).chr(187).chr(128) => 'E', chr(225).chr(187).chr(129) => 'e',
|
chr(225).chr(187).chr(146) => 'O', chr(225).chr(187).chr(147) => 'o',
|
||||||
chr(225).chr(187).chr(146) => 'O', chr(225).chr(187).chr(147) => 'o',
|
chr(225).chr(187).chr(156) => 'O', chr(225).chr(187).chr(157) => 'o',
|
||||||
chr(225).chr(187).chr(156) => 'O', chr(225).chr(187).chr(157) => 'o',
|
chr(225).chr(187).chr(170) => 'U', chr(225).chr(187).chr(171) => 'u',
|
||||||
chr(225).chr(187).chr(170) => 'U', chr(225).chr(187).chr(171) => 'u',
|
chr(225).chr(187).chr(178) => 'Y', chr(225).chr(187).chr(179) => 'y',
|
||||||
chr(225).chr(187).chr(178) => 'Y', chr(225).chr(187).chr(179) => 'y',
|
// hook
|
||||||
// hook
|
chr(225).chr(186).chr(162) => 'A', chr(225).chr(186).chr(163) => 'a',
|
||||||
chr(225).chr(186).chr(162) => 'A', chr(225).chr(186).chr(163) => 'a',
|
chr(225).chr(186).chr(168) => 'A', chr(225).chr(186).chr(169) => 'a',
|
||||||
chr(225).chr(186).chr(168) => 'A', chr(225).chr(186).chr(169) => 'a',
|
chr(225).chr(186).chr(178) => 'A', chr(225).chr(186).chr(179) => 'a',
|
||||||
chr(225).chr(186).chr(178) => 'A', chr(225).chr(186).chr(179) => 'a',
|
chr(225).chr(186).chr(186) => 'E', chr(225).chr(186).chr(187) => 'e',
|
||||||
chr(225).chr(186).chr(186) => 'E', chr(225).chr(186).chr(187) => 'e',
|
chr(225).chr(187).chr(130) => 'E', chr(225).chr(187).chr(131) => 'e',
|
||||||
chr(225).chr(187).chr(130) => 'E', chr(225).chr(187).chr(131) => 'e',
|
chr(225).chr(187).chr(136) => 'I', chr(225).chr(187).chr(137) => 'i',
|
||||||
chr(225).chr(187).chr(136) => 'I', chr(225).chr(187).chr(137) => 'i',
|
chr(225).chr(187).chr(142) => 'O', chr(225).chr(187).chr(143) => 'o',
|
||||||
chr(225).chr(187).chr(142) => 'O', chr(225).chr(187).chr(143) => 'o',
|
chr(225).chr(187).chr(148) => 'O', chr(225).chr(187).chr(149) => 'o',
|
||||||
chr(225).chr(187).chr(148) => 'O', chr(225).chr(187).chr(149) => 'o',
|
chr(225).chr(187).chr(158) => 'O', chr(225).chr(187).chr(159) => 'o',
|
||||||
chr(225).chr(187).chr(158) => 'O', chr(225).chr(187).chr(159) => 'o',
|
chr(225).chr(187).chr(166) => 'U', chr(225).chr(187).chr(167) => 'u',
|
||||||
chr(225).chr(187).chr(166) => 'U', chr(225).chr(187).chr(167) => 'u',
|
chr(225).chr(187).chr(172) => 'U', chr(225).chr(187).chr(173) => 'u',
|
||||||
chr(225).chr(187).chr(172) => 'U', chr(225).chr(187).chr(173) => 'u',
|
chr(225).chr(187).chr(182) => 'Y', chr(225).chr(187).chr(183) => 'y',
|
||||||
chr(225).chr(187).chr(182) => 'Y', chr(225).chr(187).chr(183) => 'y',
|
// tilde
|
||||||
// tilde
|
chr(225).chr(186).chr(170) => 'A', chr(225).chr(186).chr(171) => 'a',
|
||||||
chr(225).chr(186).chr(170) => 'A', chr(225).chr(186).chr(171) => 'a',
|
chr(225).chr(186).chr(180) => 'A', chr(225).chr(186).chr(181) => 'a',
|
||||||
chr(225).chr(186).chr(180) => 'A', chr(225).chr(186).chr(181) => 'a',
|
chr(225).chr(186).chr(188) => 'E', chr(225).chr(186).chr(189) => 'e',
|
||||||
chr(225).chr(186).chr(188) => 'E', chr(225).chr(186).chr(189) => 'e',
|
chr(225).chr(187).chr(132) => 'E', chr(225).chr(187).chr(133) => 'e',
|
||||||
chr(225).chr(187).chr(132) => 'E', chr(225).chr(187).chr(133) => 'e',
|
chr(225).chr(187).chr(150) => 'O', chr(225).chr(187).chr(151) => 'o',
|
||||||
chr(225).chr(187).chr(150) => 'O', chr(225).chr(187).chr(151) => 'o',
|
chr(225).chr(187).chr(160) => 'O', chr(225).chr(187).chr(161) => 'o',
|
||||||
chr(225).chr(187).chr(160) => 'O', chr(225).chr(187).chr(161) => 'o',
|
chr(225).chr(187).chr(174) => 'U', chr(225).chr(187).chr(175) => 'u',
|
||||||
chr(225).chr(187).chr(174) => 'U', chr(225).chr(187).chr(175) => 'u',
|
chr(225).chr(187).chr(184) => 'Y', chr(225).chr(187).chr(185) => 'y',
|
||||||
chr(225).chr(187).chr(184) => 'Y', chr(225).chr(187).chr(185) => 'y',
|
// acute accent
|
||||||
// acute accent
|
chr(225).chr(186).chr(164) => 'A', chr(225).chr(186).chr(165) => 'a',
|
||||||
chr(225).chr(186).chr(164) => 'A', chr(225).chr(186).chr(165) => 'a',
|
chr(225).chr(186).chr(174) => 'A', chr(225).chr(186).chr(175) => 'a',
|
||||||
chr(225).chr(186).chr(174) => 'A', chr(225).chr(186).chr(175) => 'a',
|
chr(225).chr(186).chr(190) => 'E', chr(225).chr(186).chr(191) => 'e',
|
||||||
chr(225).chr(186).chr(190) => 'E', chr(225).chr(186).chr(191) => 'e',
|
chr(225).chr(187).chr(144) => 'O', chr(225).chr(187).chr(145) => 'o',
|
||||||
chr(225).chr(187).chr(144) => 'O', chr(225).chr(187).chr(145) => 'o',
|
chr(225).chr(187).chr(154) => 'O', chr(225).chr(187).chr(155) => 'o',
|
||||||
chr(225).chr(187).chr(154) => 'O', chr(225).chr(187).chr(155) => 'o',
|
chr(225).chr(187).chr(168) => 'U', chr(225).chr(187).chr(169) => 'u',
|
||||||
chr(225).chr(187).chr(168) => 'U', chr(225).chr(187).chr(169) => 'u',
|
// dot below
|
||||||
// dot below
|
chr(225).chr(186).chr(160) => 'A', chr(225).chr(186).chr(161) => 'a',
|
||||||
chr(225).chr(186).chr(160) => 'A', chr(225).chr(186).chr(161) => 'a',
|
chr(225).chr(186).chr(172) => 'A', chr(225).chr(186).chr(173) => 'a',
|
||||||
chr(225).chr(186).chr(172) => 'A', chr(225).chr(186).chr(173) => 'a',
|
chr(225).chr(186).chr(182) => 'A', chr(225).chr(186).chr(183) => 'a',
|
||||||
chr(225).chr(186).chr(182) => 'A', chr(225).chr(186).chr(183) => 'a',
|
chr(225).chr(186).chr(184) => 'E', chr(225).chr(186).chr(185) => 'e',
|
||||||
chr(225).chr(186).chr(184) => 'E', chr(225).chr(186).chr(185) => 'e',
|
chr(225).chr(187).chr(134) => 'E', chr(225).chr(187).chr(135) => 'e',
|
||||||
chr(225).chr(187).chr(134) => 'E', chr(225).chr(187).chr(135) => 'e',
|
chr(225).chr(187).chr(138) => 'I', chr(225).chr(187).chr(139) => 'i',
|
||||||
chr(225).chr(187).chr(138) => 'I', chr(225).chr(187).chr(139) => 'i',
|
chr(225).chr(187).chr(140) => 'O', chr(225).chr(187).chr(141) => 'o',
|
||||||
chr(225).chr(187).chr(140) => 'O', chr(225).chr(187).chr(141) => 'o',
|
chr(225).chr(187).chr(152) => 'O', chr(225).chr(187).chr(153) => 'o',
|
||||||
chr(225).chr(187).chr(152) => 'O', chr(225).chr(187).chr(153) => 'o',
|
chr(225).chr(187).chr(162) => 'O', chr(225).chr(187).chr(163) => 'o',
|
||||||
chr(225).chr(187).chr(162) => 'O', chr(225).chr(187).chr(163) => 'o',
|
chr(225).chr(187).chr(164) => 'U', chr(225).chr(187).chr(165) => 'u',
|
||||||
chr(225).chr(187).chr(164) => 'U', chr(225).chr(187).chr(165) => 'u',
|
chr(225).chr(187).chr(176) => 'U', chr(225).chr(187).chr(177) => 'u',
|
||||||
chr(225).chr(187).chr(176) => 'U', chr(225).chr(187).chr(177) => 'u',
|
chr(225).chr(187).chr(180) => 'Y', chr(225).chr(187).chr(181) => 'y',
|
||||||
chr(225).chr(187).chr(180) => 'Y', chr(225).chr(187).chr(181) => 'y',
|
// Vowels with diacritic (Chinese, Hanyu Pinyin)
|
||||||
// Vowels with diacritic (Chinese, Hanyu Pinyin)
|
chr(201).chr(145) => 'a',
|
||||||
chr(201).chr(145) => 'a',
|
// macron
|
||||||
// macron
|
chr(199).chr(149) => 'U', chr(199).chr(150) => 'u',
|
||||||
chr(199).chr(149) => 'U', chr(199).chr(150) => 'u',
|
// acute accent
|
||||||
// acute accent
|
chr(199).chr(151) => 'U', chr(199).chr(152) => 'u',
|
||||||
chr(199).chr(151) => 'U', chr(199).chr(152) => 'u',
|
// caron
|
||||||
// caron
|
chr(199).chr(141) => 'A', chr(199).chr(142) => 'a',
|
||||||
chr(199).chr(141) => 'A', chr(199).chr(142) => 'a',
|
chr(199).chr(143) => 'I', chr(199).chr(144) => 'i',
|
||||||
chr(199).chr(143) => 'I', chr(199).chr(144) => 'i',
|
chr(199).chr(145) => 'O', chr(199).chr(146) => 'o',
|
||||||
chr(199).chr(145) => 'O', chr(199).chr(146) => 'o',
|
chr(199).chr(147) => 'U', chr(199).chr(148) => 'u',
|
||||||
chr(199).chr(147) => 'U', chr(199).chr(148) => 'u',
|
chr(199).chr(153) => 'U', chr(199).chr(154) => 'u',
|
||||||
chr(199).chr(153) => 'U', chr(199).chr(154) => 'u',
|
// grave accent
|
||||||
// grave accent
|
chr(199).chr(155) => 'U', chr(199).chr(156) => 'u',
|
||||||
chr(199).chr(155) => 'U', chr(199).chr(156) => 'u',
|
);
|
||||||
);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
// Used for locale-specific rules
|
// Used for locale-specific rules
|
||||||
$locale = get_locale();
|
$locale = get_locale();
|
||||||
|
|
||||||
if ( 'de_DE' == $locale ) {
|
if ( 'de_DE' == $locale ) {
|
||||||
$chars[ chr(195).chr(132) ] = 'Ae';
|
$chars[ chr(195).chr(132) ] = 'Ae';
|
||||||
$chars[ chr(195).chr(164) ] = 'ae';
|
$chars[ chr(195).chr(164) ] = 'ae';
|
||||||
$chars[ chr(195).chr(150) ] = 'Oe';
|
$chars[ chr(195).chr(150) ] = 'Oe';
|
||||||
$chars[ chr(195).chr(182) ] = 'oe';
|
$chars[ chr(195).chr(182) ] = 'oe';
|
||||||
$chars[ chr(195).chr(156) ] = 'Ue';
|
$chars[ chr(195).chr(156) ] = 'Ue';
|
||||||
$chars[ chr(195).chr(188) ] = 'ue';
|
$chars[ chr(195).chr(188) ] = 'ue';
|
||||||
$chars[ chr(195).chr(159) ] = 'ss';
|
$chars[ chr(195).chr(159) ] = 'ss';
|
||||||
} elseif ( 'da_DK' === $locale ) {
|
} elseif ( 'da_DK' === $locale ) {
|
||||||
$chars[ chr(195).chr(134) ] = 'Ae';
|
$chars[ chr(195).chr(134) ] = 'Ae';
|
||||||
$chars[ chr(195).chr(166) ] = 'ae';
|
$chars[ chr(195).chr(166) ] = 'ae';
|
||||||
$chars[ chr(195).chr(152) ] = 'Oe';
|
$chars[ chr(195).chr(152) ] = 'Oe';
|
||||||
$chars[ chr(195).chr(184) ] = 'oe';
|
$chars[ chr(195).chr(184) ] = 'oe';
|
||||||
$chars[ chr(195).chr(133) ] = 'Aa';
|
$chars[ chr(195).chr(133) ] = 'Aa';
|
||||||
$chars[ chr(195).chr(165) ] = 'aa';
|
$chars[ chr(195).chr(165) ] = 'aa';
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
$string = strtr($string, $chars);
|
$string = strtr($string, $chars);
|
||||||
} else {
|
|
||||||
$chars = array();
|
|
||||||
// Assume ISO-8859-1 if not UTF-8
|
|
||||||
$chars['in'] = chr(128).chr(131).chr(138).chr(142).chr(154).chr(158)
|
|
||||||
.chr(159).chr(162).chr(165).chr(181).chr(192).chr(193).chr(194)
|
|
||||||
.chr(195).chr(196).chr(197).chr(199).chr(200).chr(201).chr(202)
|
|
||||||
.chr(203).chr(204).chr(205).chr(206).chr(207).chr(209).chr(210)
|
|
||||||
.chr(211).chr(212).chr(213).chr(214).chr(216).chr(217).chr(218)
|
|
||||||
.chr(219).chr(220).chr(221).chr(224).chr(225).chr(226).chr(227)
|
|
||||||
.chr(228).chr(229).chr(231).chr(232).chr(233).chr(234).chr(235)
|
|
||||||
.chr(236).chr(237).chr(238).chr(239).chr(241).chr(242).chr(243)
|
|
||||||
.chr(244).chr(245).chr(246).chr(248).chr(249).chr(250).chr(251)
|
|
||||||
.chr(252).chr(253).chr(255);
|
|
||||||
|
|
||||||
$chars['out'] = "EfSZszYcYuAAAAAACEEEEIIIINOOOOOOUUUUYaaaaaaceeeeiiiinoooooouuuuyy";
|
|
||||||
|
|
||||||
$string = strtr($string, $chars['in'], $chars['out']);
|
|
||||||
$double_chars = array();
|
|
||||||
$double_chars['in'] = array(chr(140), chr(156), chr(198), chr(208), chr(222), chr(223), chr(230), chr(240), chr(254));
|
|
||||||
$double_chars['out'] = array('OE', 'oe', 'AE', 'DH', 'TH', 'ss', 'ae', 'dh', 'th');
|
|
||||||
$string = str_replace($double_chars['in'], $double_chars['out'], $string);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $string;
|
return $string;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
namespace Franzz\Objects;
|
||||||
|
use \Settings;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Translator Class
|
* Translator Class
|
||||||
* @author franzz
|
* @author franzz
|
||||||
|
|||||||
1483
inc/uploadhandler.php
Normal file
1483
inc/uploadhandler.php
Normal file
File diff suppressed because it is too large
Load Diff
80
index.php
80
index.php
@@ -1,80 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/*
|
|
||||||
Main Project
|
|
||||||
http://git.lutran.fr/main.git
|
|
||||||
Copyright (C) 2015 François Lutran
|
|
||||||
|
|
||||||
This program is free software: you can redistribute it and/or modify
|
|
||||||
it under the terms of the GNU General Public License as published by
|
|
||||||
the Free Software Foundation, either version 3 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
This program 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 General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License
|
|
||||||
along with this program. If not, see http://www.gnu.org/licenses
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Requests Handler */
|
|
||||||
|
|
||||||
//Start buffering
|
|
||||||
ob_start();
|
|
||||||
require_once '../objects/class_management.php';
|
|
||||||
$oClassManagement = new ClassManagement('main');
|
|
||||||
ToolBox::cleanPost($_POST);
|
|
||||||
ToolBox::cleanPost($_GET);
|
|
||||||
ToolBox::cleanPost($_REQUEST);
|
|
||||||
ToolBox::fixGlobalVars(isset($argv)?$argv:array());
|
|
||||||
|
|
||||||
//Available variables
|
|
||||||
$sToken = isset($_GET['token'])?$_GET['token']:'';
|
|
||||||
$sAction = isset($_GET['a'])?$_GET['a']:'';
|
|
||||||
$sPage = isset($_GET['p'])?$_GET['p']:'index';
|
|
||||||
$sLang = isset($_GET['l'])?$_GET['l']:(isset($_COOKIE['l'])?$_COOKIE['l']:'');
|
|
||||||
//...
|
|
||||||
|
|
||||||
//Initiate class
|
|
||||||
$oMain = new Main($oClassManagement, __FILE__, $sLang);
|
|
||||||
$bLoggedIn = $oMain->isLoggedIn();
|
|
||||||
|
|
||||||
$sResult = '';
|
|
||||||
if($sAction=='logmein') $sResult = $oMain->logMeIn($sToken);
|
|
||||||
elseif($sAction!='' && $bLoggedIn)
|
|
||||||
{
|
|
||||||
switch ($sAction)
|
|
||||||
{
|
|
||||||
case '':
|
|
||||||
$sResult = $oCvTheque->function();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
$sResult = Main::getJsonResult(false, Main::NOT_FOUND);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
elseif($sAction!='' && !$bLoggedIn)
|
|
||||||
{
|
|
||||||
if($oCvTheque->checkApiKey($iApiKey))
|
|
||||||
{
|
|
||||||
switch ($sAction)
|
|
||||||
{
|
|
||||||
case '':
|
|
||||||
$sResult = $oCvTheque->apifunction();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
$sResult = Main::getJsonResult(false, Main::NOT_FOUND);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else $sResult = Main::getJsonResult(false, Main::UNAUTHORIZED);
|
|
||||||
}
|
|
||||||
elseif($bLoggedIn) $sResult = $oMain->getMainPage();
|
|
||||||
else $sResult = $oMain->getLogonPage();
|
|
||||||
|
|
||||||
$sDebug = ob_get_clean();
|
|
||||||
if(Settings::DEBUG && $sDebug!='') $oMain->addUncaughtError($sDebug);
|
|
||||||
|
|
||||||
echo $sResult;
|
|
||||||
|
|
||||||
?>
|
|
||||||
Reference in New Issue
Block a user