mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-15 19:32:40 +01:00
0a62f13464
Summary: Ran `arc lint --apply-patches --everything` over rP, mainly to change double quotes to single quotes where appropriate. These changes also validate that the `ArcanistXHPASTLinter::LINT_DOUBLE_QUOTE` rule is working as expected. Test Plan: Eyeballed it. Reviewers: #blessed_reviewers, epriestley Reviewed By: #blessed_reviewers, epriestley Subscribers: epriestley, Korvin, hach-que Differential Revision: https://secure.phabricator.com/D9431
245 lines
4.8 KiB
PHP
245 lines
4.8 KiB
PHP
<?php
|
|
|
|
final class PhabricatorConfigOption
|
|
extends Phobject
|
|
implements PhabricatorMarkupInterface {
|
|
|
|
private $key;
|
|
private $default;
|
|
private $summary;
|
|
private $description;
|
|
private $type;
|
|
private $boolOptions;
|
|
private $enumOptions;
|
|
private $group;
|
|
private $examples;
|
|
private $locked;
|
|
private $hidden;
|
|
private $masked;
|
|
private $baseClass;
|
|
private $customData;
|
|
private $customObject;
|
|
|
|
public function setBaseClass($base_class) {
|
|
$this->baseClass = $base_class;
|
|
return $this;
|
|
}
|
|
|
|
public function getBaseClass() {
|
|
return $this->baseClass;
|
|
}
|
|
|
|
public function setMasked($masked) {
|
|
$this->masked = $masked;
|
|
return $this;
|
|
}
|
|
|
|
public function getMasked() {
|
|
if ($this->masked) {
|
|
return true;
|
|
}
|
|
|
|
if ($this->getHidden()) {
|
|
return true;
|
|
}
|
|
|
|
return idx(
|
|
PhabricatorEnv::getEnvConfig('config.mask'),
|
|
$this->getKey(),
|
|
false);
|
|
}
|
|
|
|
public function setHidden($hidden) {
|
|
$this->hidden = $hidden;
|
|
return $this;
|
|
}
|
|
|
|
public function getHidden() {
|
|
if ($this->hidden) {
|
|
return true;
|
|
}
|
|
|
|
return idx(
|
|
PhabricatorEnv::getEnvConfig('config.hide'),
|
|
$this->getKey(),
|
|
false);
|
|
}
|
|
|
|
public function setLocked($locked) {
|
|
$this->locked = $locked;
|
|
return $this;
|
|
}
|
|
|
|
public function getLocked() {
|
|
if ($this->locked) {
|
|
return true;
|
|
}
|
|
|
|
if ($this->getHidden()) {
|
|
return true;
|
|
}
|
|
|
|
return idx(
|
|
PhabricatorEnv::getEnvConfig('config.lock'),
|
|
$this->getKey(),
|
|
false);
|
|
}
|
|
|
|
public function addExample($value, $description) {
|
|
$this->examples[] = array($value, $description);
|
|
return $this;
|
|
}
|
|
|
|
public function getExamples() {
|
|
return $this->examples;
|
|
}
|
|
|
|
public function setGroup(PhabricatorApplicationConfigOptions $group) {
|
|
$this->group = $group;
|
|
return $this;
|
|
}
|
|
|
|
public function getGroup() {
|
|
return $this->group;
|
|
}
|
|
|
|
public function setBoolOptions(array $options) {
|
|
$this->boolOptions = $options;
|
|
return $this;
|
|
}
|
|
|
|
public function getBoolOptions() {
|
|
if ($this->boolOptions) {
|
|
return $this->boolOptions;
|
|
}
|
|
return array(
|
|
pht('True'),
|
|
pht('False'),
|
|
);
|
|
}
|
|
|
|
public function setEnumOptions(array $options) {
|
|
$this->enumOptions = $options;
|
|
return $this;
|
|
}
|
|
|
|
public function getEnumOptions() {
|
|
if ($this->enumOptions) {
|
|
return $this->enumOptions;
|
|
}
|
|
|
|
throw new Exception(
|
|
'Call setEnumOptions() before trying to access them!');
|
|
}
|
|
|
|
public function setKey($key) {
|
|
$this->key = $key;
|
|
return $this;
|
|
}
|
|
|
|
public function getKey() {
|
|
return $this->key;
|
|
}
|
|
|
|
public function setDefault($default) {
|
|
$this->default = $default;
|
|
return $this;
|
|
}
|
|
|
|
public function getDefault() {
|
|
return $this->default;
|
|
}
|
|
|
|
public function setSummary($summary) {
|
|
$this->summary = $summary;
|
|
return $this;
|
|
}
|
|
|
|
public function getSummary() {
|
|
if (empty($this->summary)) {
|
|
return $this->getDescription();
|
|
}
|
|
return $this->summary;
|
|
}
|
|
|
|
public function setDescription($description) {
|
|
$this->description = $description;
|
|
return $this;
|
|
}
|
|
|
|
public function getDescription() {
|
|
return $this->description;
|
|
}
|
|
|
|
public function setType($type) {
|
|
$this->type = $type;
|
|
return $this;
|
|
}
|
|
|
|
public function getType() {
|
|
return $this->type;
|
|
}
|
|
|
|
public function isCustomType() {
|
|
return !strncmp($this->getType(), 'custom:', 7);
|
|
}
|
|
|
|
public function getCustomObject() {
|
|
if (!$this->customObject) {
|
|
if (!$this->isCustomType()) {
|
|
throw new Exception('This option does not have a custom type!');
|
|
}
|
|
$this->customObject = newv(substr($this->getType(), 7), array());
|
|
}
|
|
return $this->customObject;
|
|
}
|
|
|
|
public function getCustomData() {
|
|
return $this->customData;
|
|
}
|
|
|
|
public function setCustomData($data) {
|
|
$this->customData = $data;
|
|
return $this;
|
|
}
|
|
|
|
/* -( PhabricatorMarkupInterface )----------------------------------------- */
|
|
|
|
public function getMarkupFieldKey($field) {
|
|
return $this->getKey().':'.$field;
|
|
}
|
|
|
|
public function newMarkupEngine($field) {
|
|
return PhabricatorMarkupEngine::newMarkupEngine(array());
|
|
}
|
|
|
|
public function getMarkupText($field) {
|
|
switch ($field) {
|
|
case 'description':
|
|
$text = $this->getDescription();
|
|
break;
|
|
case 'summary':
|
|
$text = $this->getSummary();
|
|
break;
|
|
}
|
|
|
|
// TODO: We should probably implement this as a real Markup rule, but
|
|
// markup rules are a bit of a mess right now and it doesn't hurt us to
|
|
// fake this.
|
|
$text = preg_replace(
|
|
'/{{([^}]+)}}/',
|
|
'[[/config/edit/\\1/ | \\1]]',
|
|
$text);
|
|
|
|
return $text;
|
|
}
|
|
|
|
public function didMarkupText($field, $output, PhutilMarkupEngine $engine) {
|
|
return $output;
|
|
}
|
|
|
|
public function shouldUseMarkupCache($field) {
|
|
return false;
|
|
}
|
|
|
|
}
|