Exemple #1
0
 protected final function addLintMessage(ArcanistLintMessage $message)
 {
     $root = $this->getProjectRoot();
     $path = Filesystem::resolvePath($message->getPath(), $root);
     $message->setPath(Filesystem::readablePath($path, $root));
     $this->messages[] = $message;
     return $message;
 }
 private final function isRelevantMessage(ArcanistLintMessage $message)
 {
     // When a user runs "arc lint", we default to raising only warnings on
     // lines they have changed (errors are still raised anywhere in the
     // file). The list of $changed lines may be null, to indicate that the
     // path is a directory or a binary file so we should not exclude
     // warnings.
     if (!$this->changedLines || $message->isError() || $message->shouldBypassChangedLineFiltering()) {
         return true;
     }
     $locations = $message->getOtherLocations();
     $locations[] = $message->toDictionary();
     foreach ($locations as $location) {
         $path = idx($location, 'path', $message->getPath());
         if (!array_key_exists($path, $this->changedLines)) {
             if (phutil_is_windows()) {
                 // We try checking the UNIX path form as well, on Windows.  Linters
                 // store noramlized paths, which use the Windows-style "\" as a
                 // delimiter; as such, they don't match the UNIX-style paths stored
                 // in changedLines, which come from the VCS.
                 $path = str_replace('\\', '/', $path);
                 if (!array_key_exists($path, $this->changedLines)) {
                     continue;
                 }
             } else {
                 continue;
             }
         }
         $changed = $this->getPathChangedLines($path);
         if ($changed === null || !$location['line']) {
             return true;
         }
         $last_line = $location['line'];
         if (isset($location['original'])) {
             $last_line += substr_count($location['original'], "\n");
         }
         for ($l = $location['line']; $l <= $last_line; $l++) {
             if (!empty($changed[$l])) {
                 return true;
             }
         }
     }
     return false;
 }
 private final function isRelevantMessage(ArcanistLintMessage $message)
 {
     // When a user runs "arc lint", we default to raising only warnings on
     // lines they have changed (errors are still raised anywhere in the
     // file). The list of $changed lines may be null, to indicate that the
     // path is a directory or a binary file so we should not exclude
     // warnings.
     if (!$this->changedLines || $message->isError() || $message->shouldBypassChangedLineFiltering()) {
         return true;
     }
     $locations = $message->getOtherLocations();
     $locations[] = $message->toDictionary();
     foreach ($locations as $location) {
         $path = idx($location, 'path', $message->getPath());
         if (!array_key_exists($path, $this->changedLines)) {
             continue;
         }
         $changed = $this->getPathChangedLines($path);
         if ($changed === null || !$location['line']) {
             return true;
         }
         $last_line = $location['line'];
         if (isset($location['original'])) {
             $last_line += substr_count($location['original'], "\n");
         }
         for ($l = $location['line']; $l <= $last_line; $l++) {
             if (!empty($changed[$l])) {
                 return true;
             }
         }
     }
     return false;
 }
Exemple #4
0
 protected function addLintMessage(ArcanistLintMessage $message)
 {
     if (!$this->getEngine()->getCommitHookMode()) {
         $root = $this->getEngine()->getWorkingCopy()->getProjectRoot();
         $path = Filesystem::resolvePath($message->getPath(), $root);
         $message->setPath(Filesystem::readablePath($path, $root));
     }
     $this->messages[] = $message;
     return $message;
 }