[lldb-dev] LLDB gcc std lib data formatters

Greg Clayton via lldb-dev lldb-dev at lists.llvm.org
Thu Feb 22 09:02:30 PST 2018



> On Feb 19, 2018, at 1:51 AM, Bryan Bennetts via lldb-dev <lldb-dev at lists.llvm.org> wrote:
> 
> Hi,
> 
> Apologies if this is  the wrong forum for this question - redirection to the correct place would be appreciated...
> 
> I am running
> 
> lldb --version
> lldb-900.0.64
>   Swift-4.0
> 
> with binaries compiled using g++
> 
> g++-5 --version
> g++-5 (Homebrew GCC 5.5.0_2) 5.5.0
> Copyright (C) 2015 Free Software Foundation, Inc.
> This is free software; see the source for copying conditions.  There is NO
> warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.(although I have tried a build from repo as well)
> 
> 
> The website <https://lldb.llvm.org/varformats.html> implies that gcc std library formatters should be available:
> 
> By default, several categories are created in LLDB:
> 
> default: this is the category where every formatter ends up, unless another category is specified
> objc: formatters for basic and common Objective-C types that do not specifically depend on Mac OS X
> gnu-libstdc++: formatters for std::string, std::vector, std::list and std::map as implemented by libstdcpp
> However I see:
> 
> (lldb) type category list                                                                                                                                     Category: default (enabled)
> Category: VectorTypes (enabled, applicable for language(s): objective-c++)
> Category: runtime-synthetics (enabled, applicable for language(s): objective-c++, swift)
> Category: system (enabled, applicable for language(s): objective-c++)
> (lldb) type category enable gnu-libstdc++                                                                                                                     warning: empty category enabled (typo?)
> 
> And the std containers do not print nicely:
> 
> containerTest: cat main.cpp
> #include <iostream>
> #include <vector>
> 
> using namespace std;
> 
> int main()
> {
>     auto v = vector< unsigned >{ 0, 1, 2, 3, 4, 5, 6, 7, 9 };
> 
>     for( auto i : v )
>     {
>         cout << i << "\n";
>     }
> 
>     return( 0 );
> }
>  containerTest: g++-5 -g -std=c++11  main.cpp
> /var/folders/2_/07xjgwq904376gst9m3ddb100000gn/T//cctjpiwL.s:157:11: warning: section "__textcoal_nt" is deprecated
>         .section __TEXT,__textcoal_nt,coalesced,pure_instructions
>                  ^      ~~~~~~~~~~~~~
> /var/folders/2_/07xjgwq904376gst9m3ddb100000gn/T//cctjpiwL.s:157:11: note: change section name to "__text"
>         .section __TEXT,__textcoal_nt,coalesced,pure_instructions
>                  ^      ~~~~~~~~~~~~~
> /var/folders/2_/07xjgwq904376gst9m3ddb100000gn/T//cctjpiwL.s:386:11: warning: section "__textcoal_nt" is deprecated
>         .section __TEXT,__textcoal_nt,coalesced,pure_instructions
>                  ^      ~~~~~~~~~~~~~
> /var/folders/2_/07xjgwq904376gst9m3ddb100000gn/T//cctjpiwL.s:386:11: note: change section name to "__text"
>         .section __TEXT,__textcoal_nt,coalesced,pure_instructions
>                  ^      ~~~~~~~~~~~~~
> /var/folders/2_/07xjgwq904376gst9m3ddb100000gn/T//cctjpiwL.s:430:11: warning: section "__textcoal_nt" is deprecated
>         .section __TEXT,__textcoal_nt,coalesced,pure_instructions
>                  ^      ~~~~~~~~~~~~~
> /var/folders/2_/07xjgwq904376gst9m3ddb100000gn/T//cctjpiwL.s:430:11: note: change section name to "__text"
>         .section __TEXT,__textcoal_nt,coalesced,pure_instructions
>                  ^      ~~~~~~~~~~~~~
> /var/folders/2_/07xjgwq904376gst9m3ddb100000gn/T//cctjpiwL.s:683:11: warning: section "__textcoal_nt" is deprecated
>         .section __TEXT,__textcoal_nt,coalesced,pure_instructions
>                  ^      ~~~~~~~~~~~~~
> /var/folders/2_/07xjgwq904376gst9m3ddb100000gn/T//cctjpiwL.s:683:11: note: change section name to "__text"
>         .section __TEXT,__textcoal_nt,coalesced,pure_instructions
>                  ^      ~~~~~~~~~~~~~
>  containerTest: lldb ./a.out
> (lldb) target create "./a.out"
> Current executable set to './a.out' (x86_64).
> (lldb) b main
> Breakpoint 1: where = a.out`main + 13 at main.cpp:8, address = 0x0000000100001673
> (lldb) run
> Process 98294 launched: './a.out' (x86_64)
> Process 98294 stopped
> * thread #1, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1
>     frame #0: 0x0000000100001673 a.out`main at main.cpp:8
>    5
>    6   	int main()
>    7   	{
> -> 8   	    auto v = vector< unsigned >{ 0, 1, 2, 3, 4, 5, 6, 7, 9 };
>    9
>    10  	    for( auto i : v )
>    11  	    {
> Target 0: (a.out) stopped.
> (lldb) n
> Process 98294 stopped
> * thread #1, queue = 'com.apple.main-thread', stop reason = step over
>     frame #0: 0x00000001000016bd a.out`main at main.cpp:10
>    7   	{
>    8   	    auto v = vector< unsigned >{ 0, 1, 2, 3, 4, 5, 6, 7, 9 };
>    9
> -> 10  	    for( auto i : v )
>    11  	    {
>    12  	        cout << i << "\n";
>    13  	    }
> Target 0: (a.out) stopped.
> (lldb) p v
> (vector<unsigned int, allocator<unsigned int> >) $0 = {
>   _Vector_base<unsigned int, allocator<unsigned int> > = {
>     _M_impl = {
>       _M_start = 0x0000000100402050
>       _M_finish = 0x0000000100402074
>       _M_end_of_storage = 0x0000000100402074
>     }
>   }
> }
> (lldb)
> 
> Anyone able to point me at either a python pretty printer or solution to this?
> 

why is the "std::" missing from the typename ("vector<unsigned int, allocator<unsigned int> >") above? That is why the formatters aren't kicking in.


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/lldb-dev/attachments/20180222/4790f0f5/attachment.html>


More information about the lldb-dev mailing list