mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-28 17:52:43 +01:00
ef85f49adc
Summary: This commit doesn't change license of any file. It just makes the license implicit (inherited from LICENSE file in the root directory). We are removing the headers for these reasons: - It wastes space in editors, less code is visible in editor upon opening a file. - It brings noise to diff of the first change of any file every year. - It confuses Git file copy detection when creating small files. - We don't have an explicit license header in other files (JS, CSS, images, documentation). - Using license header in every file is not obligatory: http://www.apache.org/dev/apply-license.html#new. This change is approved by Alma Chao (Lead Open Source and IP Counsel at Facebook). Test Plan: Verified that the license survived only in LICENSE file and that it didn't modify externals. Reviewers: epriestley, davidrecordon Reviewed By: epriestley CC: aran, Korvin Maniphest Tasks: T2035 Differential Revision: https://secure.phabricator.com/D3886
87 lines
2.2 KiB
PHP
87 lines
2.2 KiB
PHP
<?php
|
|
|
|
final class DifferentialComment extends DifferentialDAO
|
|
implements PhabricatorMarkupInterface {
|
|
|
|
const METADATA_ADDED_REVIEWERS = 'added-reviewers';
|
|
const METADATA_REMOVED_REVIEWERS = 'removed-reviewers';
|
|
const METADATA_ADDED_CCS = 'added-ccs';
|
|
const METADATA_DIFF_ID = 'diff-id';
|
|
|
|
const MARKUP_FIELD_BODY = 'markup:body';
|
|
|
|
protected $authorPHID;
|
|
protected $revisionID;
|
|
protected $action;
|
|
protected $content;
|
|
protected $cache;
|
|
protected $metadata = array();
|
|
protected $contentSource;
|
|
|
|
private $arbitraryDiffForFacebook;
|
|
|
|
public function giveFacebookSomeArbitraryDiff(DifferentialDiff $diff) {
|
|
$this->arbitraryDiffForFacebook = $diff;
|
|
return $this;
|
|
}
|
|
|
|
public function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_SERIALIZATION => array(
|
|
'metadata' => self::SERIALIZATION_JSON,
|
|
),
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public function setContentSource(PhabricatorContentSource $content_source) {
|
|
$this->contentSource = $content_source->serialize();
|
|
return $this;
|
|
}
|
|
|
|
public function getContentSource() {
|
|
return PhabricatorContentSource::newFromSerialized($this->contentSource);
|
|
}
|
|
|
|
|
|
public function getMarkupFieldKey($field) {
|
|
if ($this->getID()) {
|
|
return 'DC:'.$this->getID();
|
|
}
|
|
|
|
// The summary and test plan render as comments, but do not have IDs.
|
|
// They are also mutable. Build keys using content hashes.
|
|
$hash = PhabricatorHash::digest($this->getMarkupText($field));
|
|
return 'DC:'.$hash;
|
|
}
|
|
|
|
public function newMarkupEngine($field) {
|
|
return PhabricatorMarkupEngine::newDifferentialMarkupEngine(
|
|
array(
|
|
'differential.diff' => $this->arbitraryDiffForFacebook,
|
|
));
|
|
}
|
|
|
|
public function getMarkupText($field) {
|
|
return $this->getContent();
|
|
}
|
|
|
|
public function didMarkupText($field, $output, PhutilMarkupEngine $engine) {
|
|
return $output;
|
|
}
|
|
|
|
public function shouldUseMarkupCache($field) {
|
|
if ($this->getID()) {
|
|
return true;
|
|
}
|
|
|
|
$action = $this->getAction();
|
|
switch ($action) {
|
|
case DifferentialAction::ACTION_SUMMARIZE:
|
|
case DifferentialAction::ACTION_TESTPLAN:
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
}
|