本文整理匯總了PHP中Nette\PhpGenerator\ClassType類的典型用法代碼示例。如果您正苦於以下問題:PHP ClassType類的具體用法?PHP ClassType怎麽用?PHP ClassType使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了ClassType類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: afterCompile
public function afterCompile(ClassType $class)
{
if (!$this->enabled) {
return;
}
$config = $this->getConfig($this->defaults);
$initialize = $class->getMethod('initialize');
// AppName and license
if (isset($config['appName']) && !is_array($config['appName'])) {
$initialize->addBody('\\VrtakCZ\\NewRelic\\Tracy\\Bootstrap::setup(?, ?);', [$config['appName'], isset($config['license']) ? $config['license'] : NULL]);
} elseif (isset($config['appName']) && is_array($config['appName'])) {
if (!isset($config['appName']['*'])) {
throw new \RuntimeException('Missing default app name as "*"');
}
$initialize->addBody('\\VrtakCZ\\NewRelic\\Tracy\\Bootstrap::setup(?, ?);', [$config['appName']['*'], isset($config['license']) ? $config['license'] : NULL]);
}
// Logger
$initialize->addBody('\\Tracy\\Debugger::setLogger(new \\VrtakCZ\\NewRelic\\Tracy\\Logger(?));', [array_unique($config['logLevel'])]);
$this->setupCustom($initialize);
// Options
if ($config['rum']['enabled'] !== 'auto') {
$initialize->addBody('newrelic_disable_autorum();');
}
$initialize->addBody("ini_set('newrelic.transaction_tracer.enabled', ?);", [(string) $config['transactionTracer']['enabled']]);
$initialize->addBody("ini_set('newrelic.transaction_tracer.detail', ?);", [(string) $config['transactionTracer']['detail']]);
$initialize->addBody("ini_set('newrelic.transaction_tracer.record_sql', ?);", [(string) $config['transactionTracer']['recordSql']]);
$initialize->addBody("ini_set('newrelic.transaction_tracer.slow_sql', ?);", [(string) $config['transactionTracer']['slowSql']]);
$initialize->addBody("ini_set('newrelic.transaction_tracer.threshold', ?);", [(string) $config['transactionTracer']['threshold']]);
$initialize->addBody("ini_set('newrelic.transaction_tracer.stack_trace_thresholdshow', ?);", [(string) $config['transactionTracer']['stackTraceThreshold']]);
$initialize->addBody("ini_set('newrelic.transaction_tracer.explain_threshold', ?);", [(string) $config['transactionTracer']['explainThreshold']]);
$initialize->addBody("ini_set('newrelic.error_collector.enabled', ?);", [(string) $config['errorCollector']['enabled']]);
$initialize->addBody("ini_set('newrelic.error_collector.record_database_errors', ?);", [(string) $config['errorCollector']['recordDatabaseErrors']]);
$initialize->addBody('newrelic_capture_params(?);', [$config['parameters']['capture']]);
$initialize->addBody("ini_set('newrelic.ignored_params', ?);", [implode(',', $config['parameters']['ignored'])]);
}
示例2: afterCompile
public function afterCompile(Code\ClassType $class)
{
$init = $class->getMethod('initialize');
$originalInitialize = $init->getBody();
$init->setBody('Doctrine\\Common\\Annotations\\AnnotationRegistry::registerLoader("class_exists");' . "\n");
$init->addBody($originalInitialize);
}
示例3: afterCompile
public function afterCompile(ClassType $class)
{
if ($this->isCli()) {
return;
}
$class->getMethod('initialize')->addBody('header(?);', ['X-Clacks-Overhead: GNU Terry Pratchett']);
}
示例4: afterCompile
public function afterCompile(Nette\PhpGenerator\ClassType $class)
{
$initialize = $class->getMethod('initialize');
$builder = $this->getContainerBuilder();
$options = $this->config;
unset($options['bar'], $options['blueScreen']);
if (isset($options['logSeverity'])) {
$res = 0;
foreach ((array) $options['logSeverity'] as $level) {
$res |= is_int($level) ? $level : constant($level);
}
$options['logSeverity'] = $res;
}
foreach ($options as $key => $value) {
if ($value !== NULL) {
$key = ($key === 'fromEmail' ? 'getLogger()->' : '$') . $key;
$initialize->addBody($builder->formatPhp('Tracy\\Debugger::' . $key . ' = ?;', Nette\DI\Compiler::filterArguments([$value])));
}
}
$logger = $builder->getDefinition($this->prefix('logger'));
if ($logger->getFactory()->getEntity() !== 'Tracy\\Debugger::getLogger') {
$initialize->addBody($builder->formatPhp('Tracy\\Debugger::setLogger(?);', [$logger]));
}
if ($this->debugMode) {
foreach ((array) $this->config['bar'] as $item) {
$initialize->addBody($builder->formatPhp('$this->getService(?)->addPanel(?);', Nette\DI\Compiler::filterArguments([$this->prefix('bar'), is_string($item) ? new Nette\DI\Statement($item) : $item])));
}
if (!$this->cliMode) {
$initialize->addBody('if ($tmp = $this->getByType("Nette\\Http\\Session", FALSE)) { $tmp->start(); Tracy\\Debugger::dispatch(); };');
}
}
foreach ((array) $this->config['blueScreen'] as $item) {
$initialize->addBody($builder->formatPhp('$this->getService(?)->addPanel(?);', Nette\DI\Compiler::filterArguments([$this->prefix('blueScreen'), $item])));
}
}
示例5: afterCompile
public function afterCompile(Nette\PhpGenerator\ClassType $class)
{
$methods = $class->getMethods();
$init = $methods['initialize'];
$init->addBody('vojtabiberle\\MediaStorage\\Bridges\\Nette\\Forms\\Controls\\SingleSelectFileChoicer::register();');
$init->addBody('vojtabiberle\\MediaStorage\\Bridges\\Nette\\Forms\\Controls\\MultiSelectFileChoicer::register();');
}
示例6: afterCompile
public function afterCompile(ClassType $class)
{
$initialize = $class->getMethod('initialize');
$initialize->addBody('$moduleManager = $this->getService(?);', [$this->getContainerBuilder()->getByType(ModuleManager::class)]);
$initialize->addBody('foreach ($this->findByType(\'' . IModule::class . '\') as $module) {' . "\n" . ' $moduleManager->registerModule($this->getService($module));' . "\n" . '}');
$initialize->addBody('$moduleManager->prepareModules();');
}
示例7: afterCompile
public function afterCompile(ClassType $class)
{
$config = $this->getConfig($this->defaults);
if ($config['enabled']) {
$init = $class->getMethod('initialize');
$init->addBody(Debugger::class . '::setLogger(new ' . SlackLogger::class . '(?, $this->getService(?), ?));', [$config['slackUrl'], $this->prefix('messageFactory'), $config['timeout']]);
}
}
示例8: afterCompile
public function afterCompile(ClassType $class)
{
$builder = $this->getContainerBuilder();
$init = $class->getMethod('initialize');
if ($builder->hasDefinition($this->prefix('bar'))) {
$init->addBody('$this->getByType(?)->addPanel($this->getService(?));', array('Tracy\\Bar', $this->prefix('bar')));
}
}
示例9: afterCompile
public function afterCompile(Nette\PhpGenerator\ClassType $class)
{
$init = $class->getMethods()['initialize'];
$config = $this->validateConfig($this->defaults);
if ($config['paginatorTemplate']) {
$init->addBody('?::$defaultPaginationTemplate = ?;', [Settings::class, $config['paginatorTemplate']]);
}
}
示例10: afterCompile
/**
* Adjusts DI container compiled to PHP class. Intended to be overridden by descendant.
*
* @param Nette\PhpGenerator\ClassType $class
*/
public function afterCompile(Nette\PhpGenerator\ClassType $class)
{
$initialize = $class->getMethod('initialize');
$builder = $this->getContainerBuilder();
if ($builder->parameters['debugMode'] && $builder->hasDefinition(self::TRACY_PANEL)) {
$initialize->addBody($builder->formatPhp('?;', [new Nette\DI\Statement('@Tracy\\Bar::addPanel', ['@' . self::TRACY_PANEL, self::TRACY_PANEL])]));
}
}
示例11: afterCompile
/**
* @param Nette\PhpGenerator\ClassType $class
*/
public function afterCompile(Nette\PhpGenerator\ClassType $class)
{
$methods = $class->getMethods();
$init = $methods['initialize'];
if ($this->getContainerBuilder()->hasDefinition($this->prefix('bar'))) {
$init->addBody('if ($this->parameters["debugMode"]) Tracy\\Debugger::getBar()->addPanel($this->getService(?));', [$this->prefix('bar')]);
}
}
示例12: afterCompile
/**
* @param ClassType $class
*/
public function afterCompile(ClassType $class)
{
$config = $this->validateConfig($this->defaults);
if ($config['auto'] === TRUE) {
$method = $class->getMethod('initialize');
$method->addBody('?::bind($this->getService(?));', [new PhpLiteral(FormBinder::class), $this->prefix('providerFactory')]);
}
}
示例13: afterCompile
public function afterCompile(PhpGenerator\ClassType $class)
{
$config = $this->getConfig(self::$configDefaults);
$initialize = $class->getMethod('initialize');
// response syntax highlighting in debug mode
if ($config['debugMode'] == TRUE) {
$initialize->addBody('$this->getService(?)->onResponse[] = [new Tripomatic\\NetteApi\\Application\\ResponseProcessors\\ResponseDecorator, "process"];', ['application.application']);
}
}
示例14: afterCompile
/**
* Register UUID type into doctrine.
* @param ClassType $container
*/
public function afterCompile(ClassType $container)
{
$initialize = $container->getMethod('initialize');
$builder = $this->getContainerBuilder();
$initialize->addBody('?::addType(?, ?);', [Type::class, 'uuid', UuidType::class]);
foreach ($builder->findByType(Connection::class) as $name => $connection) {
$initialize->addBody('$this->getService(?)->getDatabasePlatform()->registerDoctrineTypeMapping(?, ?);', [$name, 'uuid', 'uuid']);
}
}
示例15: afterCompile
/**
* @param ClassType $class
* @return void
*/
public function afterCompile(ClassType $class)
{
$config = $this->validateConfig($this->defaults);
if ($config['siteKey'] != NULL) {
$method = $class->getMethod('initialize');
$method->addBody(sprintf('%s::bind(?);', ReCaptchaBinding::class), [$config['siteKey']]);
$method->addBody(sprintf('%s::factory(?);', ReCaptchaHolder::class), [$config['siteKey']]);
}
}