function test2() { $tests[] = array('совместимая', '%td%ta%sy%t8%t1%td%te%t4%t8%sw%tr'); foreach ($tests as $test) { list($utf8, $safe) = $test; $this->assertEquals(SafeFN::decode($safe), $utf8); } }
function document_start() { global $ID; $filename = SafeFN::encode(strtr($ID, '/:', '--')) . '.ics'; $headers = array('Content-Type:' => 'text/calendar', 'Content-Disposition:' => 'attachment; filename=' . $filename); p_set_metadata($ID, array('format' => array('icalevents' => $headers))); $this->doc = "BEGIN:VCALENDAR\r\n"; $this->doc .= "PRODID: -//DokuWiki//NONSGML Plugin iCalEvents//EN" . "\r\n"; $this->doc .= "VERSION:2.0\r\n"; }
function test1() { // we test multiple cases here - format: string, repl, additional, test $tests = array(); $tests[] = array('asciistring', 'asciistring'); $tests[] = array('ascii-_/.string', 'ascii-_/.string'); $tests[] = array('AName', '%x%1a.ame'); $tests[] = array('A Name', '%x%0%1a.ame'); $tests[] = array('Another...Name', '%x.nother...%1a.ame'); $tests[] = array('Aß∂ƒName', '%x%5b%6oy%aa%1a.ame'); $tests[] = array('A%ß-∂_.ƒName', '%x%%5b.-%6oy._.%aa%1a.ame'); $tests[] = array('A%%ß-∂_.ƒName', '%x%%%5b.-%6oy._.%aa%1a.ame'); $tests[] = array('데이터도 함께 복원됩니다. 강력한', '%zf4%13dg%15ao%zhg%0%164o%yig%0%11at%138w%zk9%zag%zb8..%0%xyt%10cl%164c'); $tests[] = array('совместимая', '%td%ta%sy%t8%t1%td%te%t4%t8%sw%tr'); $tests[] = array('нехватка_файлового_пространства_на_сервере_p0-squid.some.domain.1270211897.txt.gz', '%t9%t1%th%sy%sw%te%t6%sw._%tg%sw%t5%t7%ta%sy%ta%sz%ta._%tb%tc%ta%td%te%tc%sw%t9%td%te%sy%sw._%t9%sw._%td%t1%tc%sy%t1%tc%t1._p0-squid.some.domain.1270211897.txt.gz'); foreach ($tests as $test) { list($utf8, $safe) = $test; $this->assertEqual(SafeFN::encode($utf8), $safe); $this->assertEqual(SafeFN::decode($safe), $utf8); } }
/** * Decode a filename back to UTF-8 * * Uses the 'fnencode' option to determine encoding * * @author Andreas Gohr <*****@*****.**> * @see urldecode * * @param string $file file name * @return string */ function utf8_decodeFN($file) { global $conf; if ($conf['fnencode'] == 'utf-8') { return $file; } if ($conf['fnencode'] == 'safe') { return SafeFN::decode($file); } return urldecode($file); }
/** * Decode a filename back to UTF-8 * * Uses the 'fnencode' option to determine encoding * * @author Andreas Gohr <*****@*****.**> * @see urldecode */ function dwiki_decodeFN($file) { global $Dwfck_conf_values; if ($Dwfck_conf_values['fnencode'] == 'utf-8') { return $file; } if ($Dwfck_conf_values['fnencode'] == 'safe') { return SafeFN::decode($file); } return urldecode($file); }