clang-format: [JS] do not format MPEG transport streams.

Summary:
The MPEG transport stream file format also uses ".ts" as its file extension.
This change detects its specific framing format (0x47 every 189 bytes) and
simply ignores MPEG TS files.

Reviewers: djasper, sammccall

Subscribers: klimek, cfe-commits

Differential Revision: https://reviews.llvm.org/D29186

llvm-svn: 293270
This commit is contained in:
Martin Probst 2017-01-27 09:09:11 +00:00
parent 67346ca9ef
commit fa37b18f94
3 changed files with 22 additions and 1 deletions

View File

@ -1462,12 +1462,22 @@ tooling::Replacements sortCppIncludes(const FormatStyle &Style, StringRef Code,
return Replaces; return Replaces;
} }
bool isMpegTS(StringRef Code) {
// MPEG transport streams use the ".ts" file extension. clang-format should
// not attempt to format those. MPEG TS' frame format starts with 0x47 every
// 189 bytes - detect that and return.
return Code.size() > 188 && Code[0] == 0x47 && Code[188] == 0x47;
}
tooling::Replacements sortIncludes(const FormatStyle &Style, StringRef Code, tooling::Replacements sortIncludes(const FormatStyle &Style, StringRef Code,
ArrayRef<tooling::Range> Ranges, ArrayRef<tooling::Range> Ranges,
StringRef FileName, unsigned *Cursor) { StringRef FileName, unsigned *Cursor) {
tooling::Replacements Replaces; tooling::Replacements Replaces;
if (!Style.SortIncludes) if (!Style.SortIncludes)
return Replaces; return Replaces;
if (Style.Language == FormatStyle::LanguageKind::LK_JavaScript &&
isMpegTS(Code))
return Replaces;
if (Style.Language == FormatStyle::LanguageKind::LK_JavaScript) if (Style.Language == FormatStyle::LanguageKind::LK_JavaScript)
return sortJavaScriptImports(Style, Code, Ranges, FileName); return sortJavaScriptImports(Style, Code, Ranges, FileName);
sortCppIncludes(Style, Code, Ranges, FileName, Replaces, Cursor); sortCppIncludes(Style, Code, Ranges, FileName, Replaces, Cursor);
@ -1813,7 +1823,8 @@ tooling::Replacements reformat(const FormatStyle &Style, StringRef Code,
FormatStyle Expanded = expandPresets(Style); FormatStyle Expanded = expandPresets(Style);
if (Expanded.DisableFormat) if (Expanded.DisableFormat)
return tooling::Replacements(); return tooling::Replacements();
if (Expanded.Language == FormatStyle::LK_JavaScript && isMpegTS(Code))
return tooling::Replacements();
auto Env = Environment::CreateVirtualEnvironment(Code, FileName, Ranges); auto Env = Environment::CreateVirtualEnvironment(Code, FileName, Ranges);
if (Style.Language == FormatStyle::LK_JavaScript && if (Style.Language == FormatStyle::LK_JavaScript &&

View File

@ -256,6 +256,7 @@ static bool format(StringRef FileName) {
llvm::errs() << llvm::toString(FormatStyle.takeError()) << "\n"; llvm::errs() << llvm::toString(FormatStyle.takeError()) << "\n";
return true; return true;
} }
if (SortIncludes.getNumOccurrences() != 0) if (SortIncludes.getNumOccurrences() != 0)
FormatStyle->SortIncludes = SortIncludes; FormatStyle->SortIncludes = SortIncludes;
unsigned CursorPosition = Cursor; unsigned CursorPosition = Cursor;

View File

@ -1036,6 +1036,15 @@ TEST_F(FormatTestJS, RegexLiteralExamples) {
verifyFormat("var regex = search.match(/(?:\?|&)times=([^?&]+)/i);"); verifyFormat("var regex = search.match(/(?:\?|&)times=([^?&]+)/i);");
} }
TEST_F(FormatTestJS, IgnoresMpegTS) {
std::string MpegTS(200, ' ');
MpegTS.replace(0, strlen("nearlyLooks + like + ts + code; "),
"nearlyLooks + like + ts + code; ");
MpegTS[0] = 0x47;
MpegTS[188] = 0x47;
verifyFormat(MpegTS, MpegTS);
}
TEST_F(FormatTestJS, TypeAnnotations) { TEST_F(FormatTestJS, TypeAnnotations) {
verifyFormat("var x: string;"); verifyFormat("var x: string;");
verifyFormat("var x: {a: string; b: number;} = {};"); verifyFormat("var x: {a: string; b: number;} = {};");