<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Oct 25, 2017, at 6:05 PM, Zachary Turner <<a href="mailto:zturner@google.com" class="">zturner@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div class=""><div dir="auto" class=""><br class=""></div><br class=""><div class="gmail_quote"><div dir="auto" class="">On Wed, Oct 25, 2017 at 4:59 PM Jim Ingham via Phabricator <<a href="mailto:reviews@reviews.llvm.org" class="">reviews@reviews.llvm.org</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">jingham added a comment.<br class="">
<br class="">
Note, BTW, we absolutely need some way to say "this symbol from this library". But first of all, if we're going to do this you need to be able to mix & match within an expression which you can't do with a flag to expr. Instead you need something like:<br class="">
<br class="">
(lldb) expr $$MyDylib$my_symbol + $$MyOtherDylib$my_other_symbol<br class="">
<br class="">
That syntax is ugly, we should try to think of something better. But the main point is this should only be necessary when lldb can't find a unique symbol. When we can no intervention should be required.<br class="">
</blockquote><div dir="auto" class=""><br class=""></div><div dir="auto" class=""><div dir="auto" class="">+1, this is very useful. The Microsoft syntax for this is here:</div><div dir="auto" class=""><br class=""></div><div dir="auto" class=""><a href="https://docs.microsoft.com/en-us/visualstudio/debugger/context-operator-cpp" class="">https://docs.microsoft.com/en-us/visualstudio/debugger/context-operator-cpp</a></div></div><div dir="auto" class=""><br class=""></div><div dir="auto" class="">Which is pretty nice imo</div></div></div>
</div></blockquote></div><br class=""><div class="">The main reason for using $ decorated names is because clang will accept them as identifiers and ask us about them. So "$$MyOtherDylib$my_other_symbol" is just a valid identifier and would result in a find external lexical decl call that we can fill in with whatever we want. </div><div class=""><br class=""></div><div class="">We don't really want to muck with clang by overloading stuff with symbols that would hose up clang (like the MSVC examples "{,,EXAMPLE.dll}SomeFunction", "EXAMPLE.dll!SomeFunction", and "{,,"a long, long, library name.dll"}g_Var". The { } and , characters would hose up the expression parser. So I would vote to use the $ decoration as Jim suggested.</div><div class=""><br class=""></div><div class="">Greg</div></body></html>