> On Aug 6, 2015, at 3:33 PM, Siva Chandra <sivachan...@google.com> wrote:
> 
> 
> 
> On Thu, Aug 6, 2015 at 2:43 PM, Enrico Granata <egran...@apple.com 
> <mailto:egran...@apple.com>> wrote:
> To be honest, my favorite approach would be to modify clang’s TypePrinter to 
> do this, and then hooking up GetDisplayTypeName() to use whatever flags would 
> be necessary to invoke that bit of magic
> 
> Do you mean that clang's "pretty printer" should be made extensible by a 
> script?
>  

Nope, what I am imagining is not an extensible system

When LLDB goes to print a type it asks the compiler “what is the name of this 
type that I should display?”
By default, clang prints the fully specialized template, including type 
arguments that have their default value. My theory is that we would want to add 
a mode to the type printer to say “simplify type name”, and that would do 
sensible things to get a display name that is more compact

That seems more interesting than a set of regular expression heuristics on the 
type name, which is probably all you could do without specialized compiler-y 
knowledge of types

> 
>> On Aug 6, 2015, at 2:33 PM, Siva Chandra <sivachan...@google.com 
>> <mailto:sivachan...@google.com>> wrote:
>> 
>> FWIW, GDB has a similar concept called type-printers:
>> https://sourceware.org/gdb/current/onlinedocs/gdb/Type-Printing-API.html 
>> <https://sourceware.org/gdb/current/onlinedocs/gdb/Type-Printing-API.html>
>> 
>> On Thu, Aug 6, 2015 at 2:24 PM, Siva Chandra <sivachan...@google.com 
>> <mailto:sivachan...@google.com>> wrote:
>>> Hi Enrico,
>>> 
>>> I was thinking about the same issue today. Could we add a concept
>>> called "TypeNameModifier" and provide ability to define modifiers in
>>> scripts and command line? With this, a name like
>>> std::__1::basic_string<...> can be modified into a more friendly name
>>> like std::string? We could ofcourse have more complex modifications.
>>> 
>>> I think it is doable, but what is your (and the community's) opinion
>>> about adding such a feature? If you are OK, I would like to take up
>>> adding such a feature.
>>> 
>>> Thanks,
>>> Siva Chandra
>>> 
>>> On Thu, Aug 6, 2015 at 2:15 PM, Enrico Granata via lldb-dev
>>> <lldb-dev@lists.llvm.org <mailto:lldb-dev@lists.llvm.org>> wrote:
>>>> Hi Eugene,
>>>> 
>>>> On Aug 6, 2015, at 2:02 PM, Eugene Birukov via lldb-dev
>>>> <lldb-dev@lists.llvm.org <mailto:lldb-dev@lists.llvm.org>> wrote:
>>>> 
>>>> Hi,
>>>> 
>>>> I am using LLDB C++ API to create custom debugger and trying to dump
>>>> variables with their types. To do that I am using SBValue.GetTypeName() 
>>>> API.
>>>> Some types are OK, but some others - especially ones related to STL - are
>>>> quite unreadable:
>>>> 
>>>> 
>>>> those type names are the actual fully-specialized STL type names. I am not
>>>> sure how to control GDB to stop truncating your string formatting, but 
>>>> after
>>>> the “…” there actually is more text
>>>> It looks like what you have is std::unique_ptr<std::vector<std::string> > >
>>>> and those templates all take more arguments which are defaulted so you 
>>>> don’t
>>>> have to type them in code - but are reflected in the type name
>>>> 
>>>> (gdb) p value.GetTypeName()
>>>> $1 = 0x7fffe419be40
>>>> "std::__1::unique_ptr<std::__1::vector<std::__1::basic_string<char,
>>>> std::__1::char_traits<char>, std::__1::allocator<char> >,
>>>> std::__1::allocator<std::__1::basic_string<char,
>>>> std::__1::char_traits<char"...
>>>> (gdb) p value.GetDisplayTypeName()
>>>> $2 = 0x7fffe419be40
>>>> "std::__1::unique_ptr<std::__1::vector<std::__1::basic_string<char,
>>>> std::__1::char_traits<char>, std::__1::allocator<char> >,
>>>> std::__1::allocator<std::__1::basic_string<char,
>>>> std::__1::char_traits<char"...
>>>> (gdb)
>>>> 
>>>> 
>>>> So, is there any way to convert them into some more human-friendly form?
>>>> 
>>>> 
>>>> Not currently. What one would have to do is hook into the C++ type printing
>>>> logic such that it would know to leave out these extra template arguments
>>>> when they have a default value
>>>> 
>>>> 
>>>> Thanks,
>>>> Eugene
>>>> _______________________________________________
>>>> lldb-dev mailing list
>>>> lldb-dev@lists.llvm.org <mailto:lldb-dev@lists.llvm.org>
>>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-dev 
>>>> <http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-dev>
>>>> 
>>>> 
>>>> 
>>>> Thanks,
>>>> - Enrico
>>>> 📩 egranata@.com ️ 27683
>>>> 
>>>> 
>>>> _______________________________________________
>>>> lldb-dev mailing list
>>>> lldb-dev@lists.llvm.org <mailto:lldb-dev@lists.llvm.org>
>>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-dev 
>>>> <http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-dev>
>>>> 
> 
> 
> Thanks,
> - Enrico
> 📩 egranata@.com ☎️ 27683
> 
> 


Thanks,
- Enrico
📩 egranata@.com ☎️ 27683

_______________________________________________
lldb-dev mailing list
lldb-dev@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-dev

Reply via email to