This is an archive of the discontinued LLVM Phabricator instance.

clang-format: add an option -verbose to list the files being processed
ClosedPublic

Authored by sylvestre.ledru on Jun 29 2017, 11:22 AM.

Diff Detail

Event Timeline

djasper edited edge metadata.Jun 30 2017, 7:13 AM

Can you add a test? Tests for this kind of behavior of the clang-format command line go in test/Format/.

tools/clang-format/ClangFormat.cpp
380

As clang-format often returns the result on stdout, maybe it'd be better to use errs() here?

sylvestre.ledru added inline comments.Jul 5 2017, 7:46 AM
tools/clang-format/ClangFormat.cpp
380

Right, otherwise, this:
clang-format -verbose foo.cpp > bar.cpp
won't work

Generally upload diffs with full context to phabricator. That makes reviewing much easier.

test/Format/verbose.cpp
2

This seems like a pretty minimal test to me. Consider adding the filename (with a regex like "Formatting{{.*}}verbose.cpp"). There might be reasons not to do that though.

tools/clang-format/ClangFormat.cpp
377

I think we should restructure the code to not have to duplicate what you are adding here. I think fundamentally, we should be able to change this to:

if (FileNames.empty()) {
  Error = clang::format::format("-");
  return Error ? 1 : 0;
}
if (FileNames.size() == 1 && (!Offsets.empty() || !Lengths.empty() || !LineRanges.empty())) {
  errs() << "error: -offset .... "
  return 1;
}
for (const auto& FileName : FileNames) {
  if (Verbose.getNumOccurences() != 0)
    errs() << "Formatting " << Filename << "\n";
  Error |= clang::format::format(FileName);
}
return Error ? 1 : 0;
388

Feel free to turn this into a range-based for loop while you are here. :)

390

Not sure that just checking the number of occurrences is correct. What happens if I write -verbose=false on the command line?

391

The indentation is off.

tools/clang-format/ClangFormat.cpp
377

This isn't correct.
You can have

bin/clang-format  -lines=1:1 foo-1.cpp foo-2.cpp

we won't enter into the "error: -offset" error

sylvestre.ledru marked 7 inline comments as done.
sylvestre.ledru added inline comments.
test/Format/verbose.cpp
2

I changed the structure and added more checks to it.

djasper added inline comments.Jul 18 2017, 12:08 AM
tools/clang-format/ClangFormat.cpp
377

Right. In my code I had a bug s/== 1/ != 1/. But I don't think you can drop that part entirely. As it is now, you cannot specify any -lines/offsets/lenghts even for a single file?

sylvestre.ledru marked an inline comment as done.

Fixed, thanks for spotting the mistake.
Looks like we could improve the testsuite as my mistake hasn't been catched.

djasper accepted this revision.Jul 18 2017, 7:33 AM

Yeah, improving the testsuite generally seems like a good idea. But unrelated to this patch. This looks good now.

This revision is now accepted and ready to land.Jul 18 2017, 7:33 AM
sylvestre.ledru reopened this revision.Aug 12 2017, 8:13 AM

actually, arc commit never landed this change :(

This revision is now accepted and ready to land.Aug 12 2017, 8:13 AM