3951ccbef7
The realtime clock is not reliable when calculating elapsed time.
80 lines
1.9 KiB
PHP
80 lines
1.9 KiB
PHP
<?php
|
|
|
|
if (isset($_SERVER) && array_key_exists('REQUEST_METHOD', $_SERVER)) {
|
|
print "This script must be run from the command line\n";
|
|
exit();
|
|
}
|
|
|
|
define('INSTALLDIR', realpath(dirname(__FILE__) . '/../../..'));
|
|
define('GNUSOCIAL', true);
|
|
define('STATUSNET', true); // compatibility
|
|
|
|
require_once INSTALLDIR . '/scripts/commandline.inc';
|
|
require_once INSTALLDIR . '/extlib/php-gettext/gettext.inc';
|
|
|
|
common_init_locale("en_US");
|
|
common_init_locale('fr');
|
|
|
|
|
|
putenv("LANG=fr");
|
|
putenv("LANGUAGE=fr");
|
|
setlocale('fr.utf8');
|
|
_setlocale('fr.utf8');
|
|
|
|
_bindtextdomain("statusnet", INSTALLDIR . '/locale');
|
|
_bindtextdomain("FeedSub", INSTALLDIR . '/plugins/FeedSub/locale');
|
|
|
|
$times = 10000;
|
|
$delta = [];
|
|
|
|
$start = hrtime(true);
|
|
for ($i = 0; $i < $times; ++$i) {
|
|
$result = _('Send');
|
|
}
|
|
$delta['_'] = [(hrtime(true) - $start) / $times, $result];
|
|
|
|
$start = hrtime(true);
|
|
for ($i = 0; $i < $times; ++$i) {
|
|
$result = __('Send');
|
|
}
|
|
$delta['__'] = [(hrtime(true) - $start) / $times, $result];
|
|
|
|
$start = hrtime(true);
|
|
for ($i = 0; $i < $times; ++$i) {
|
|
$result = dgettext('FeedSub', 'Feeds');
|
|
}
|
|
$delta['dgettext'] = [(hrtime(true) - $start) / $times, $result];
|
|
|
|
$start = hrtime(true);
|
|
for ($i = 0; $i < $times; ++$i) {
|
|
$result = _dgettext('FeedSub', 'Feeds');
|
|
}
|
|
$delta['_dgettext'] = [(hrtime(true) - $start) / $times, $result];
|
|
|
|
|
|
$start = hrtime(true);
|
|
for ($i = 0; $i < $times; ++$i) {
|
|
// TRANS: String in the gettext speed test script. Unimportant.
|
|
$result = _m('Feeds');
|
|
}
|
|
$delta['_m'] = [(hrtime(true) - $start) / $times, $result];
|
|
|
|
|
|
$start = hrtime(true);
|
|
for ($i = 0; $i < $times; ++$i) {
|
|
$result = fake('Feeds');
|
|
}
|
|
$delta['fake'] = [(hrtime(true) - $start) / $times, $result];
|
|
|
|
foreach ($delta as $func => $bits) {
|
|
[$time, $result] = $bits;
|
|
$ms = $time / 1000000;
|
|
printf("%10s %2.4fms %s\n", $func, $ms, $result);
|
|
}
|
|
|
|
|
|
function fake(string $str)
|
|
{
|
|
return $str;
|
|
}
|