4
* A group of @{class:ArcanistLintMessage}s that apply to a file.
6
final class ArcanistLintResult {
10
protected $filePathOnDisk;
11
protected $cacheVersion;
12
protected $messages = array();
13
protected $effectiveMessages = array();
16
public function setPath($path) {
21
public function getPath() {
25
public function addMessage(ArcanistLintMessage $message) {
26
$this->messages[] = $message;
27
$this->needsSort = true;
31
public function getMessages() {
32
if ($this->needsSort) {
33
$this->sortAndFilterMessages();
35
return $this->effectiveMessages;
38
public function setData($data) {
43
public function getData() {
47
public function setFilePathOnDisk($file_path_on_disk) {
48
$this->filePathOnDisk = $file_path_on_disk;
52
public function getFilePathOnDisk() {
53
return $this->filePathOnDisk;
56
public function setCacheVersion($version) {
57
$this->cacheVersion = $version;
61
public function getCacheVersion() {
62
return $this->cacheVersion;
65
public function isPatchable() {
66
foreach ($this->messages as $message) {
67
if ($message->isPatchable()) {
74
public function isAllAutofix() {
75
foreach ($this->messages as $message) {
76
if (!$message->isAutofix()) {
83
public function sortAndFilterMessages() {
84
$messages = $this->messages;
86
foreach ($messages as $key => $message) {
87
if ($message->getObsolete()) {
88
unset($messages[$key]);
94
foreach ($messages as $key => $message) {
95
$map[$key] = ($message->getLine() * (2 << 12)) + $message->getChar();
98
$messages = array_select_keys($messages, array_keys($map));
100
$this->effectiveMessages = $messages;
101
$this->needsSort = false;