<div dir="ltr">What's the differential revision? At least for me I couldn't find one by searching "llvm-strings" in my inbox.</div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Nov 14, 2016 at 6:03 PM, Saleem Abdulrasool <span dir="ltr"><<a href="mailto:compnerd@compnerd.org" target="_blank">compnerd@compnerd.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="white-space:pre-wrap">It went through Phab. Did it get dropped from the list? :(</div><div class="HOEnZb"><div class="h5"><br><div class="gmail_quote"><div dir="ltr">On Mon, Nov 14, 2016 at 2:57 PM Rui Ueyama <<a href="mailto:ruiu@google.com" target="_blank">ruiu@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class="m_3782289176036219555gmail_msg">I was wondering that, too.</div><div class="gmail_extra m_3782289176036219555gmail_msg"><br class="m_3782289176036219555gmail_msg"><div class="gmail_quote m_3782289176036219555gmail_msg">On Mon, Nov 14, 2016 at 2:48 PM, Michael Spencer via llvm-commits <span dir="ltr" class="m_3782289176036219555gmail_msg"><<a href="mailto:llvm-commits@lists.llvm.org" class="m_3782289176036219555gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a>></span> wrote:<br class="m_3782289176036219555gmail_msg"><blockquote class="gmail_quote m_3782289176036219555gmail_msg" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class="m_3782289176036219555gmail_msg">Was there a review thread for this? I was at the C++ standards meeting all last week so I may have missed it.<br class="m_3782289176036219555gmail_msg"><div class="gmail_extra m_3782289176036219555gmail_msg"><br clear="all" class="m_3782289176036219555gmail_msg"><div class="m_3782289176036219555gmail_msg"><div class="m_3782289176036219555m_1991103296160677412m_5641409663438737564gmail_signature m_3782289176036219555gmail_msg">- Michael Spencer<br class="m_3782289176036219555gmail_msg"></div></div>
<br class="m_3782289176036219555gmail_msg"><div class="gmail_quote m_3782289176036219555gmail_msg"><span class="m_3782289176036219555gmail_msg">On Thu, Nov 10, 2016 at 7:44 PM, Saleem Abdulrasool via llvm-commits <span dir="ltr" class="m_3782289176036219555gmail_msg"><<a href="mailto:llvm-commits@lists.llvm.org" class="m_3782289176036219555gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a>></span> wrote:<br class="m_3782289176036219555gmail_msg"></span><div class="m_3782289176036219555gmail_msg"><div class="m_3782289176036219555m_1991103296160677412h5 m_3782289176036219555gmail_msg"><blockquote class="gmail_quote m_3782289176036219555gmail_msg" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Author: compnerd<br class="m_3782289176036219555gmail_msg">
Date: Thu Nov 10 21:44:12 2016<br class="m_3782289176036219555gmail_msg">
New Revision: 286556<br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=286556&view=rev" rel="noreferrer" class="m_3782289176036219555gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=286556&view=rev</a><br class="m_3782289176036219555gmail_msg">
Log:<br class="m_3782289176036219555gmail_msg">
llvm-strings: introduce basic strings tool<br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg">
This is a replacement to binutils' string tool. It prints strings found in a<br class="m_3782289176036219555gmail_msg">
binary (object file, executable, or archive library). It is rather bare and<br class="m_3782289176036219555gmail_msg">
not functionally equivalent, however, it lays the groundwork necessary for the<br class="m_3782289176036219555gmail_msg">
strings tool, enabling iterative development of features to reach feature<br class="m_3782289176036219555gmail_msg">
parity.<br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg">
Added:<br class="m_3782289176036219555gmail_msg">
llvm/trunk/tools/llvm-strings/<br class="m_3782289176036219555gmail_msg">
llvm/trunk/tools/llvm-strings/<wbr>CMakeLists.txt<br class="m_3782289176036219555gmail_msg">
llvm/trunk/tools/llvm-strings/<wbr>LLVMBuild.txt<br class="m_3782289176036219555gmail_msg">
llvm/trunk/tools/llvm-strings/<wbr>llvm-strings.cpp<br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg">
Added: llvm/trunk/tools/llvm-strings/<wbr>CMakeLists.txt<br class="m_3782289176036219555gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/tools/llvm-strings/CMakeLists.txt?rev=286556&view=auto" rel="noreferrer" class="m_3782289176036219555gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/llvm/trunk/tools/llvm-<wbr>strings/CMakeLists.txt?rev=<wbr>286556&view=auto</a><br class="m_3782289176036219555gmail_msg">
==============================<wbr>==============================<wbr>==================<br class="m_3782289176036219555gmail_msg">
--- llvm/trunk/tools/llvm-strings/<wbr>CMakeLists.txt (added)<br class="m_3782289176036219555gmail_msg">
+++ llvm/trunk/tools/llvm-strings/<wbr>CMakeLists.txt Thu Nov 10 21:44:12 2016<br class="m_3782289176036219555gmail_msg">
@@ -0,0 +1,8 @@<br class="m_3782289176036219555gmail_msg">
+set(LLVM_LINK_COMPONENTS<br class="m_3782289176036219555gmail_msg">
+ Object<br class="m_3782289176036219555gmail_msg">
+ )<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+add_llvm_tool(llvm-strings<br class="m_3782289176036219555gmail_msg">
+ llvm-strings.cpp<br class="m_3782289176036219555gmail_msg">
+ )<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg">
Added: llvm/trunk/tools/llvm-strings/<wbr>LLVMBuild.txt<br class="m_3782289176036219555gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/tools/llvm-strings/LLVMBuild.txt?rev=286556&view=auto" rel="noreferrer" class="m_3782289176036219555gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/llvm/trunk/tools/llvm-<wbr>strings/LLVMBuild.txt?rev=<wbr>286556&view=auto</a><br class="m_3782289176036219555gmail_msg">
==============================<wbr>==============================<wbr>==================<br class="m_3782289176036219555gmail_msg">
--- llvm/trunk/tools/llvm-strings/<wbr>LLVMBuild.txt (added)<br class="m_3782289176036219555gmail_msg">
+++ llvm/trunk/tools/llvm-strings/<wbr>LLVMBuild.txt Thu Nov 10 21:44:12 2016<br class="m_3782289176036219555gmail_msg">
@@ -0,0 +1,22 @@<br class="m_3782289176036219555gmail_msg">
+;===- ./tools/llvm-strings/<wbr>LLVMBuild.txt -----------------------*- Conf -*--===;<br class="m_3782289176036219555gmail_msg">
+;<br class="m_3782289176036219555gmail_msg">
+; The LLVM Compiler Infrastructure<br class="m_3782289176036219555gmail_msg">
+;<br class="m_3782289176036219555gmail_msg">
+; This file is distributed under the University of Illinois Open Source<br class="m_3782289176036219555gmail_msg">
+; License. See LICENSE.TXT for details.<br class="m_3782289176036219555gmail_msg">
+;<br class="m_3782289176036219555gmail_msg">
+;===-------------------------<wbr>------------------------------<wbr>-----------------===;<br class="m_3782289176036219555gmail_msg">
+;<br class="m_3782289176036219555gmail_msg">
+; This is an LLVMBuild description file for the components in this subdirectory.<br class="m_3782289176036219555gmail_msg">
+;<br class="m_3782289176036219555gmail_msg">
+; For more information on the LLVMBuild system, please see:<br class="m_3782289176036219555gmail_msg">
+;<br class="m_3782289176036219555gmail_msg">
+; <a href="http://llvm.org/docs/LLVMBuild.html" rel="noreferrer" class="m_3782289176036219555gmail_msg" target="_blank">http://llvm.org/docs/<wbr>LLVMBuild.html</a><br class="m_3782289176036219555gmail_msg">
+;<br class="m_3782289176036219555gmail_msg">
+;===-------------------------<wbr>------------------------------<wbr>-----------------===;<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+[component_0]<br class="m_3782289176036219555gmail_msg">
+type = Tool<br class="m_3782289176036219555gmail_msg">
+name = llvm-strings<br class="m_3782289176036219555gmail_msg">
+parent = Tools<br class="m_3782289176036219555gmail_msg">
+required_libraries = Archive Object<br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg">
Added: llvm/trunk/tools/llvm-strings/<wbr>llvm-strings.cpp<br class="m_3782289176036219555gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/tools/llvm-strings/llvm-strings.cpp?rev=286556&view=auto" rel="noreferrer" class="m_3782289176036219555gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/llvm/trunk/tools/llvm-<wbr>strings/llvm-strings.cpp?rev=<wbr>286556&view=auto</a><br class="m_3782289176036219555gmail_msg">
==============================<wbr>==============================<wbr>==================<br class="m_3782289176036219555gmail_msg">
--- llvm/trunk/tools/llvm-strings/<wbr>llvm-strings.cpp (added)<br class="m_3782289176036219555gmail_msg">
+++ llvm/trunk/tools/llvm-strings/<wbr>llvm-strings.cpp Thu Nov 10 21:44:12 2016<br class="m_3782289176036219555gmail_msg">
@@ -0,0 +1,120 @@<br class="m_3782289176036219555gmail_msg">
+//===-- llvm-strings.cpp - Printable String dumping utility ---------------===//<br class="m_3782289176036219555gmail_msg">
+//<br class="m_3782289176036219555gmail_msg">
+// The LLVM Compiler Infrastructure<br class="m_3782289176036219555gmail_msg">
+//<br class="m_3782289176036219555gmail_msg">
+// This file is distributed under the University of Illinois Open Source<br class="m_3782289176036219555gmail_msg">
+// License. See LICENSE.TXT for details.<br class="m_3782289176036219555gmail_msg">
+//<br class="m_3782289176036219555gmail_msg">
+//===------------------------<wbr>------------------------------<wbr>----------------===//<br class="m_3782289176036219555gmail_msg">
+//<br class="m_3782289176036219555gmail_msg">
+// This program is a utility that works like binutils "strings", that is, it<br class="m_3782289176036219555gmail_msg">
+// prints out printable strings in a binary, objdump, or archive file.<br class="m_3782289176036219555gmail_msg">
+//<br class="m_3782289176036219555gmail_msg">
+//===------------------------<wbr>------------------------------<wbr>----------------===//<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+#include "llvm/IR/LLVMContext.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Object/Archive.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Object/Binary.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Object/ObjectFile.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Support/CommandLine.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Support/Error.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Support/MemoryBuffer.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Support/<wbr>PrettyStackTrace.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Support/Program.h"<br class="m_3782289176036219555gmail_msg">
+#include "llvm/Support/Signals.h"<br class="m_3782289176036219555gmail_msg">
+#include <string><br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+using namespace llvm;<br class="m_3782289176036219555gmail_msg">
+using namespace llvm::object;<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+static cl::list<std::string> InputFileNames(cl::Positional,<br class="m_3782289176036219555gmail_msg">
+ cl::desc("<input object files>"),<br class="m_3782289176036219555gmail_msg">
+ cl::ZeroOrMore);<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+static void dump(raw_ostream &OS, StringRef Contents) {<br class="m_3782289176036219555gmail_msg">
+ const char *S = nullptr;<br class="m_3782289176036219555gmail_msg">
+ for (const char *P = Contents.begin(), *E = Contents.end(); P < E; ++P) {<br class="m_3782289176036219555gmail_msg">
+ if (std::isgraph(*P) || std::isblank(*P)) {<br class="m_3782289176036219555gmail_msg">
+ if (S == nullptr)<br class="m_3782289176036219555gmail_msg">
+ S = P;<br class="m_3782289176036219555gmail_msg">
+ } else if (S) {<br class="m_3782289176036219555gmail_msg">
+ if (P - S > 3)<br class="m_3782289176036219555gmail_msg">
+ OS << StringRef(S, P - S) << '\n';<br class="m_3782289176036219555gmail_msg">
+ S = nullptr;<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+}<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+namespace {<br class="m_3782289176036219555gmail_msg">
+class Strings {<br class="m_3782289176036219555gmail_msg">
+ LLVMContext Context;<br class="m_3782289176036219555gmail_msg">
+ raw_ostream &OS;<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+ void dump(const ObjectFile *O) {<br class="m_3782289176036219555gmail_msg">
+ for (const auto &S : O->sections()) {<br class="m_3782289176036219555gmail_msg">
+ StringRef Contents;<br class="m_3782289176036219555gmail_msg">
+ if (!S.getContents(Contents))<br class="m_3782289176036219555gmail_msg">
+ ::dump(OS, Contents);<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+ void dump(const Archive *A) {<br class="m_3782289176036219555gmail_msg">
+ Error E;<br class="m_3782289176036219555gmail_msg">
+ for (auto &Element : A->children(E)) {<br class="m_3782289176036219555gmail_msg">
+ if (Expected<std::unique_ptr<<wbr>Binary>> Child =<br class="m_3782289176036219555gmail_msg">
+ Element.getAsBinary(&Context)) {<br class="m_3782289176036219555gmail_msg">
+ dump(dyn_cast<ObjectFile>(&**<wbr>Child));<br class="m_3782289176036219555gmail_msg">
+ } else {<br class="m_3782289176036219555gmail_msg">
+ if (auto E = isNotObjectErrorInvalidFileTyp<wbr>e(Child.takeError())) {<br class="m_3782289176036219555gmail_msg">
+ errs() << A->getFileName();<br class="m_3782289176036219555gmail_msg">
+ if (Expected<StringRef> Name = Element.getName())<br class="m_3782289176036219555gmail_msg">
+ errs() << '(' << *Name << ')';<br class="m_3782289176036219555gmail_msg">
+ logAllUnhandledErrors(std::<wbr>move(E), errs(), "");<br class="m_3782289176036219555gmail_msg">
+ errs() << '\n';<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+ static_cast<bool>(E);<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+public:<br class="m_3782289176036219555gmail_msg">
+ Strings(raw_ostream &S) : OS(S) {}<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+ void scan(StringRef File) {<br class="m_3782289176036219555gmail_msg">
+ ErrorOr<std::unique_ptr<<wbr>MemoryBuffer>> Buffer =<br class="m_3782289176036219555gmail_msg">
+ MemoryBuffer::getFileOrSTDIN(<wbr>File);<br class="m_3782289176036219555gmail_msg">
+ if (std::error_code EC = Buffer.getError()) {<br class="m_3782289176036219555gmail_msg">
+ errs() << File << ": " << EC.message() << '\n';<br class="m_3782289176036219555gmail_msg">
+ return;<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+ if (Expected<std::unique_ptr<<wbr>Binary>> B =<br class="m_3782289176036219555gmail_msg">
+ createBinary(Buffer.get()-><wbr>getMemBufferRef(), &Context)) {<br class="m_3782289176036219555gmail_msg">
+ if (auto *A = dyn_cast<Archive>(&**B))<br class="m_3782289176036219555gmail_msg">
+ return dump(A);<br class="m_3782289176036219555gmail_msg">
+ if (auto *O = dyn_cast<ObjectFile>(&**B))<br class="m_3782289176036219555gmail_msg">
+ return dump(O);<br class="m_3782289176036219555gmail_msg">
+ ::dump(OS, Buffer.get()->getMemBufferRef(<wbr>).getBuffer());<br class="m_3782289176036219555gmail_msg">
+ } else {<br class="m_3782289176036219555gmail_msg">
+ consumeError(B.takeError());<br class="m_3782289176036219555gmail_msg">
+ ::dump(OS, Buffer.get()->getMemBufferRef(<wbr>).getBuffer());<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+ }<br class="m_3782289176036219555gmail_msg">
+};<br class="m_3782289176036219555gmail_msg">
+}<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+int main(int argc, char **argv) {<br class="m_3782289176036219555gmail_msg">
+ sys::<wbr>PrintStackTraceOnErrorSignal(<wbr>argv[0]);<br class="m_3782289176036219555gmail_msg">
+ PrettyStackTraceProgram X(argc, argv);<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+ cl::ParseCommandLineOptions(<wbr>argc, argv, "llvm string dumper\n");<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+ if (InputFileNames.empty())<br class="m_3782289176036219555gmail_msg">
+ InputFileNames.push_back("-");<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
+ Strings S(llvm::outs());<br class="m_3782289176036219555gmail_msg">
+ std::for_each(InputFileNames.<wbr>begin(), InputFileNames.end(),<br class="m_3782289176036219555gmail_msg">
+ [&S](StringRef F) { S.scan(F); });<br class="m_3782289176036219555gmail_msg">
+ return EXIT_SUCCESS;<br class="m_3782289176036219555gmail_msg">
+}<br class="m_3782289176036219555gmail_msg">
+<br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg">
______________________________<wbr>_________________<br class="m_3782289176036219555gmail_msg">
llvm-commits mailing list<br class="m_3782289176036219555gmail_msg">
<a href="mailto:llvm-commits@lists.llvm.org" class="m_3782289176036219555gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a><br class="m_3782289176036219555gmail_msg">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" class="m_3782289176036219555gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-commits</a><br class="m_3782289176036219555gmail_msg">
</blockquote></div></div></div><br class="m_3782289176036219555gmail_msg"></div></div>
<br class="m_3782289176036219555gmail_msg">______________________________<wbr>_________________<br class="m_3782289176036219555gmail_msg">
llvm-commits mailing list<br class="m_3782289176036219555gmail_msg">
<a href="mailto:llvm-commits@lists.llvm.org" class="m_3782289176036219555gmail_msg" target="_blank">llvm-commits@lists.llvm.org</a><br class="m_3782289176036219555gmail_msg">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" class="m_3782289176036219555gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-commits</a><br class="m_3782289176036219555gmail_msg">
<br class="m_3782289176036219555gmail_msg"></blockquote></div><br class="m_3782289176036219555gmail_msg"></div>
</blockquote></div>
</div></div></blockquote></div><br></div>