<div dir="ltr">Yea.  It's definitely hard to write a normal test case for this.  It's also a common problem when dealing with remote debugging scenarios.  It's both hard and resource demanding (needing to have just the right Host -> Target configuration available) to test that by going through the full debugging stack.  But it's often easy to write a test for a specific bug by finding the point of failure, and writing a simple unit test that verifies the inputs and outputs of a single method.<div><br></div><div>Many of LLDB's abstractions aren't designed to be able to handle this very well (for example, dependency injection is a common technique, but requires the functionality to be abstracted correctly to be able to inject mock interfaces), but there's no reason they couldn't be changed to be.</div></div><br><div class="gmail_quote"><div dir="ltr">On Wed, Sep 30, 2015 at 11:03 PM Jason Molenda <<a href="mailto:jmolenda@apple.com">jmolenda@apple.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Thanks for the idea Zachary, I haven't been following that.  I'll look at this tomorrow.  I was trying to imagine how to write a normal test case for this and it'd involve running a binary, deleting the binary off disk, then lldb attach to the process, letting it find a dSYM via spotlight which points to a copy of the binary in another location and there's another copy of the dSYM next to that binary. And I'd want to check that lldb stuck with the original dSYM that it found, instead of picking up the second dSYM sitting next to the binary.  It might be possible to replicate the behavior entirely self-hosted.  But it definitely only works on a mac because of the DebugSymbols private framework calls lldb makes while doing all of this.<br>
<br>
<br>
> On Sep 30, 2015, at 10:58 PM, Zachary Turner <<a href="mailto:zturner@google.com" target="_blank">zturner@google.com</a>> wrote:<br>
><br>
> This is a good example of where unit tests are useful.  There's already a small suite of unit tests but I'm going to start being proactive about growing it (in part by evangelizing it in response to people's commits ;-).  It's not integrated into the Xcode build, but it would certainly be easy to do so.  The nice thing about a unit test is that you can set everything up exactly the way you need it and just call the one native code method you want to test, and verify the outputs.  You could make up your own ModuleSpec, you could make a mock implementation of `Symbols` that delegates to the real `Symbols` implementation for everything except the part where it checks if the file exists, and have that method simply return false so it goes to the fallback path, etc.<br>
><br>
> Anyway, just throwing this out there as an option.  This is MacOSX only code so it's not a huge priority for me to push it strongly, but if you think it would be useful I'm happy to help you figure out how to run them and/or write a new one.<br>
><br>
> On Wed, Sep 30, 2015 at 10:39 PM Jason Molenda via lldb-commits <<a href="mailto:lldb-commits@lists.llvm.org" target="_blank">lldb-commits@lists.llvm.org</a>> wrote:<br>
> Author: jmolenda<br>
> Date: Thu Oct  1 00:37:22 2015<br>
> New Revision: 248985<br>
><br>
> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=248985&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project?rev=248985&view=rev</a><br>
> Log:<br>
> Fixing a subtle issue on Mac OS X systems with dSYMs (possibly<br>
> introduced by r235737 but I didn't look into it too closely).<br>
><br>
> A dSYM can have a per-UUID plist in it which tells lldb where<br>
> to find an executable binary for the dSYM (DBGSymbolRichExecutable)<br>
> - other information can be included in this plist, like how to<br>
> remap the source file paths from their build pathnames to their<br>
> long-term storage pathnames.<br>
><br>
> This per-UUID plist is a unusual; it is used probably exclusively<br>
> inside apple with our build system.  It is not created by default<br>
> in normal dSYMs.<br>
><br>
> The problem was like this:<br>
><br>
>   1. lldb wants to find an executable, given only a UUID<br>
>      (this happens when lldb is doing cross-host debugging<br>
>       and doesn't have a copy of the target system's binaries)<br>
><br>
>   2. It eventually calls LocateMacOSXFilesUsingDebugSymbols<br>
>      which does a spotlight search for the dSYM on the local<br>
>      system, and failing that, tries the DBGShellCommands<br>
>      command to find the dSYM.<br>
><br>
>   3. It gets a dSYM.  It reads the per-UUID plist in the dSYM.<br>
>      The dSYM has a DBGSymbolRichExecutable kv pair pointing to<br>
>      the binary on a network filesystem.<br>
><br>
>   4. Using the binary on the network filesystem, lldb now goes<br>
>      to find the dSYM.<br>
><br>
>   5. It starts by looking for a dSYM next to the binary it found.<br>
><br>
>   6. lldb is now reading the dSYM over a network filesystem,<br>
>      ignoring the one it found on its local filesystem earlier.<br>
><br>
> Everything still *works* but it's much slower.<br>
><br>
> This would be a tricky one to write up in a testsuite case;<br>
> you really need the binary to not exist on the local system.<br>
> And LocateMacOSXFilesUsingDebugSymbols will only compile on<br>
> Mac OS X - even if I found a way to write up a test case, it<br>
> would not run anywhere but on a mac.<br>
><br>
> One change Greg wanted while I was touching this code was to<br>
> have LocateMacOSXFilesUsingDebugSymbols (which could be asked<br>
> to find a binary OR find a dSYM) to instead return a ModuleSpec<br>
> with the sum total of everything it could find.  This<br>
> change of passing around a ModuleSpec instead of a FileSpec<br>
> was percolated up into ModuleList::GetSharedModule.<br>
><br>
> The changes to LocateMacOSXFilesUsingDebugSymbols look larger<br>
> than they really are - there's a lot of simple whitespace changes<br>
> in there.<br>
><br>
> I ran the testsuites on mac, no new regressions introduced<br>
><br>
> <rdar://problem/21993813><br>
><br>
> Modified:<br>
>     lldb/trunk/include/lldb/Host/Symbols.h<br>
>     lldb/trunk/source/Core/ModuleList.cpp<br>
>     lldb/trunk/source/Host/common/Symbols.cpp<br>
>     lldb/trunk/source/Host/macosx/Symbols.cpp<br>
>     lldb/trunk/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp<br>
><br>
> Modified: lldb/trunk/include/lldb/Host/Symbols.h<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/Host/Symbols.h?rev=248985&r1=248984&r2=248985&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/Host/Symbols.h?rev=248985&r1=248984&r2=248985&view=diff</a><br>
> ==============================================================================<br>
> --- lldb/trunk/include/lldb/Host/Symbols.h (original)<br>
> +++ lldb/trunk/include/lldb/Host/Symbols.h Thu Oct  1 00:37:22 2015<br>
> @@ -29,7 +29,7 @@ public:<br>
>      // Locating the file should happen only on the local computer or using<br>
>      // the current computers global settings.<br>
>      //----------------------------------------------------------------------<br>
> -    static FileSpec<br>
> +    static ModuleSpec<br>
>      LocateExecutableObjectFile (const ModuleSpec &module_spec);<br>
><br>
>      //----------------------------------------------------------------------<br>
><br>
> Modified: lldb/trunk/source/Core/ModuleList.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Core/ModuleList.cpp?rev=248985&r1=248984&r2=248985&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Core/ModuleList.cpp?rev=248985&r1=248984&r2=248985&view=diff</a><br>
> ==============================================================================<br>
> --- lldb/trunk/source/Core/ModuleList.cpp (original)<br>
> +++ lldb/trunk/source/Core/ModuleList.cpp Thu Oct  1 00:37:22 2015<br>
> @@ -1045,19 +1045,19 @@ ModuleList::GetSharedModule<br>
><br>
>      // Fixup the incoming path in case the path points to a valid file, yet<br>
>      // the arch or UUID (if one was passed in) don't match.<br>
> -    FileSpec file_spec = Symbols::LocateExecutableObjectFile (module_spec);<br>
> +    ModuleSpec located_binary_modulespec = Symbols::LocateExecutableObjectFile (module_spec);<br>
><br>
>      // Don't look for the file if it appears to be the same one we already<br>
>      // checked for above...<br>
> -    if (file_spec != module_file_spec)<br>
> +    if (located_binary_modulespec.GetFileSpec() != module_file_spec)<br>
>      {<br>
> -        if (!file_spec.Exists())<br>
> +        if (!located_binary_modulespec.GetFileSpec().Exists())<br>
>          {<br>
> -            file_spec.GetPath(path, sizeof(path));<br>
> +            located_binary_modulespec.GetFileSpec().GetPath(path, sizeof(path));<br>
>              if (path[0] == '\0')<br>
>                  module_file_spec.GetPath(path, sizeof(path));<br>
>              // How can this check ever be true? This branch it is false, and we haven't modified file_spec.<br>
> -            if (file_spec.Exists())<br>
> +            if (located_binary_modulespec.GetFileSpec().Exists())<br>
>              {<br>
>                  std::string uuid_str;<br>
>                  if (uuid_ptr && uuid_ptr->IsValid())<br>
> @@ -1084,9 +1084,8 @@ ModuleList::GetSharedModule<br>
>          // Make sure no one else can try and get or create a module while this<br>
>          // function is actively working on it by doing an extra lock on the<br>
>          // global mutex list.<br>
> -        ModuleSpec platform_module_spec(module_spec);<br>
> -        platform_module_spec.GetFileSpec() = file_spec;<br>
> -        platform_module_spec.GetPlatformFileSpec() = file_spec;<br>
> +        ModuleSpec platform_module_spec(located_binary_modulespec);<br>
> +        platform_module_spec.GetPlatformFileSpec() = located_binary_modulespec.GetFileSpec();<br>
>          ModuleList matching_module_list;<br>
>          if (shared_module_list.FindModules (platform_module_spec, matching_module_list) > 0)<br>
>          {<br>
> @@ -1096,7 +1095,7 @@ ModuleList::GetSharedModule<br>
>              // then we should make sure the modification time hasn't changed!<br>
>              if (platform_module_spec.GetUUIDPtr() == NULL)<br>
>              {<br>
> -                TimeValue file_spec_mod_time(file_spec.GetModificationTime());<br>
> +                TimeValue file_spec_mod_time(located_binary_modulespec.GetFileSpec().GetModificationTime());<br>
>                  if (file_spec_mod_time.IsValid())<br>
>                  {<br>
>                      if (file_spec_mod_time != module_sp->GetModificationTime())<br>
> @@ -1125,9 +1124,9 @@ ModuleList::GetSharedModule<br>
>              }<br>
>              else<br>
>              {<br>
> -                file_spec.GetPath(path, sizeof(path));<br>
> +                located_binary_modulespec.GetFileSpec().GetPath(path, sizeof(path));<br>
><br>
> -                if (file_spec)<br>
> +                if (located_binary_modulespec.GetFileSpec())<br>
>                  {<br>
>                      if (arch.IsValid())<br>
>                          error.SetErrorStringWithFormat("unable to open %s architecture in '%s'", arch.GetArchitectureName(), path);<br>
><br>
> Modified: lldb/trunk/source/Host/common/Symbols.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/Symbols.cpp?rev=248985&r1=248984&r2=248985&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/common/Symbols.cpp?rev=248985&r1=248984&r2=248985&view=diff</a><br>
> ==============================================================================<br>
> --- lldb/trunk/source/Host/common/Symbols.cpp (original)<br>
> +++ lldb/trunk/source/Host/common/Symbols.cpp Thu Oct  1 00:37:22 2015<br>
> @@ -38,8 +38,7 @@ int<br>
>  LocateMacOSXFilesUsingDebugSymbols<br>
>  (<br>
>      const ModuleSpec &module_spec,<br>
> -    FileSpec *out_exec_fspec,   // If non-NULL, try and find the executable<br>
> -    FileSpec *out_dsym_fspec    // If non-NULL try and find the debug symbol file<br>
> +    ModuleSpec &return_module_spec<br>
>  );<br>
><br>
>  #else<br>
> @@ -48,8 +47,7 @@ int<br>
>  LocateMacOSXFilesUsingDebugSymbols<br>
>  (<br>
>      const ModuleSpec &module_spec,<br>
> -    FileSpec *out_exec_fspec,   // If non-NULL, try and find the executable<br>
> -    FileSpec *out_dsym_fspec    // If non-NULL try and find the debug symbol file<br>
> +    ModuleSpec &return_module_spec<br>
>  ) {<br>
>      // Cannot find MacOSX files using debug symbols on non MacOSX.<br>
>      return 0;<br>
> @@ -178,19 +176,25 @@ LocateExecutableSymbolFileDsym (const Mo<br>
>                          (const void*)uuid);<br>
><br>
>      FileSpec symbol_fspec;<br>
> +    ModuleSpec dsym_module_spec;<br>
>      // First try and find the dSYM in the same directory as the executable or in<br>
>      // an appropriate parent directory<br>
>      if (LocateDSYMInVincinityOfExecutable (module_spec, symbol_fspec) == false)<br>
>      {<br>
>          // We failed to easily find the dSYM above, so use DebugSymbols<br>
> -        LocateMacOSXFilesUsingDebugSymbols (module_spec, NULL, &symbol_fspec);<br>
> +        LocateMacOSXFilesUsingDebugSymbols (module_spec, dsym_module_spec);<br>
>      }<br>
> -    return symbol_fspec;<br>
> +    else<br>
> +    {<br>
> +        dsym_module_spec.GetSymbolFileSpec() = symbol_fspec;<br>
> +    }<br>
> +    return dsym_module_spec.GetSymbolFileSpec();<br>
>  }<br>
><br>
> -FileSpec<br>
> +ModuleSpec<br>
>  Symbols::LocateExecutableObjectFile (const ModuleSpec &module_spec)<br>
>  {<br>
> +    ModuleSpec result = module_spec;<br>
>      const FileSpec *exec_fspec = module_spec.GetFileSpecPtr();<br>
>      const ArchSpec *arch = module_spec.GetArchitecturePtr();<br>
>      const UUID *uuid = module_spec.GetUUIDPtr();<br>
> @@ -200,20 +204,19 @@ Symbols::LocateExecutableObjectFile (con<br>
>                          arch ? arch->GetArchitectureName() : "<NULL>",<br>
>                          (const void*)uuid);<br>
><br>
> -    FileSpec objfile_fspec;<br>
>      ModuleSpecList module_specs;<br>
>      ModuleSpec matched_module_spec;<br>
>      if (exec_fspec &&<br>
>          ObjectFile::GetModuleSpecifications(*exec_fspec, 0, 0, module_specs) &&<br>
>          module_specs.FindMatchingModuleSpec(module_spec, matched_module_spec))<br>
>      {<br>
> -        objfile_fspec = exec_fspec;<br>
> +        result.GetFileSpec() = exec_fspec;<br>
>      }<br>
>      else<br>
>      {<br>
> -        LocateMacOSXFilesUsingDebugSymbols (module_spec, &objfile_fspec, NULL);<br>
> +        LocateMacOSXFilesUsingDebugSymbols (module_spec, result);<br>
>      }<br>
> -    return objfile_fspec;<br>
> +    return result;<br>
>  }<br>
><br>
>  FileSpec<br>
><br>
> Modified: lldb/trunk/source/Host/macosx/Symbols.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/macosx/Symbols.cpp?rev=248985&r1=248984&r2=248985&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Host/macosx/Symbols.cpp?rev=248985&r1=248984&r2=248985&view=diff</a><br>
> ==============================================================================<br>
> --- lldb/trunk/source/Host/macosx/Symbols.cpp (original)<br>
> +++ lldb/trunk/source/Host/macosx/Symbols.cpp Thu Oct  1 00:37:22 2015<br>
> @@ -55,17 +55,14 @@ int<br>
>  LocateMacOSXFilesUsingDebugSymbols<br>
>  (<br>
>      const ModuleSpec &module_spec,<br>
> -    FileSpec *out_exec_fspec,   // If non-NULL, try and find the executable<br>
> -    FileSpec *out_dsym_fspec    // If non-NULL try and find the debug symbol file<br>
> +    ModuleSpec &return_module_spec<br>
>  )<br>
>  {<br>
> -    int items_found = 0;<br>
> -<br>
> -    if (out_exec_fspec)<br>
> -        out_exec_fspec->Clear();<br>
> +    return_module_spec = module_spec;<br>
> +    return_module_spec.GetFileSpec().Clear();<br>
> +    return_module_spec.GetSymbolFileSpec().Clear();<br>
><br>
> -    if (out_dsym_fspec)<br>
> -        out_dsym_fspec->Clear();<br>
> +    int items_found = 0;<br>
><br>
>  #if !defined (__arm__) && !defined (__arm64__) && !defined (__aarch64__) // No DebugSymbols on the iOS devices<br>
><br>
> @@ -110,151 +107,132 @@ LocateMacOSXFilesUsingDebugSymbols<br>
>                                                                                    strlen(exec_cf_path),<br>
>                                                                                    FALSE));<br>
>                  }<br>
> -                if (log)<br>
> -                {<br>
> -                    std::string searching_for;<br>
> -                    if (out_exec_fspec && out_dsym_fspec)<br>
> -                    {<br>
> -                        searching_for = "executable binary and dSYM";<br>
> -                    }<br>
> -                    else if (out_exec_fspec)<br>
> -                    {<br>
> -                        searching_for = "executable binary";<br>
> -                    }<br>
> -                    else<br>
> -                    {<br>
> -                        searching_for = "dSYM bundle";<br>
> -                    }<br>
> -                    log->Printf ("Calling DebugSymbols framework to locate dSYM bundle for UUID %s, searching for %s", uuid->GetAsString().c_str(), searching_for.c_str());<br>
> -                }<br>
><br>
>                  CFCReleaser<CFURLRef> dsym_url (::DBGCopyFullDSYMURLForUUID(module_uuid_ref.get(), exec_url.get()));<br>
>                  char path[PATH_MAX];<br>
><br>
>                  if (dsym_url.get())<br>
>                  {<br>
> -                    if (out_dsym_fspec)<br>
> +                    if (::CFURLGetFileSystemRepresentation (dsym_url.get(), true, (UInt8*)path, sizeof(path)-1))<br>
> +                    {<br>
> +                        if (log)<br>
> +                        {<br>
> +                            log->Printf ("DebugSymbols framework returned dSYM path of %s for UUID %s -- looking for the dSYM", path, uuid->GetAsString().c_str());<br>
> +                        }<br>
> +                        FileSpec dsym_filespec(path, path[0] == '~');<br>
> +<br>
> +                        if (dsym_filespec.GetFileType () == FileSpec::eFileTypeDirectory)<br>
> +                        {<br>
> +                            dsym_filespec = Symbols::FindSymbolFileInBundle (dsym_filespec, uuid, arch);<br>
> +                            ++items_found;<br>
> +                        }<br>
> +                        else<br>
> +                        {<br>
> +                            ++items_found;<br>
> +                        }<br>
> +                        return_module_spec.GetSymbolFileSpec() = dsym_filespec;<br>
> +                    }<br>
> +<br>
> +                    bool success = false;<br>
> +                    if (log)<br>
>                      {<br>
>                          if (::CFURLGetFileSystemRepresentation (dsym_url.get(), true, (UInt8*)path, sizeof(path)-1))<br>
>                          {<br>
> -                            if (log)<br>
> -                            {<br>
> -                                log->Printf ("DebugSymbols framework returned dSYM path of %s for UUID %s -- looking for the dSYM", path, uuid->GetAsString().c_str());<br>
> -                            }<br>
> -                            out_dsym_fspec->SetFile(path, path[0] == '~');<br>
> +                            log->Printf ("DebugSymbols framework returned dSYM path of %s for UUID %s -- looking for an exec file", path, uuid->GetAsString().c_str());<br>
> +                        }<br>
><br>
> -                            if (out_dsym_fspec->GetFileType () == FileSpec::eFileTypeDirectory)<br>
> +                    }<br>
> +<br>
> +                    CFCReleaser<CFDictionaryRef> dict(::DBGCopyDSYMPropertyLists (dsym_url.get()));<br>
> +                    CFDictionaryRef uuid_dict = NULL;<br>
> +                    if (dict.get())<br>
> +                    {<br>
> +                        CFCString uuid_cfstr (uuid->GetAsString().c_str());<br>
> +                        uuid_dict = static_cast<CFDictionaryRef>(::CFDictionaryGetValue (dict.get(), uuid_cfstr.get()));<br>
> +                    }<br>
> +                    if (uuid_dict)<br>
> +                    {<br>
> +                        CFStringRef exec_cf_path = static_cast<CFStringRef>(::CFDictionaryGetValue (uuid_dict, CFSTR("DBGSymbolRichExecutable")));<br>
> +                        if (exec_cf_path && ::CFStringGetFileSystemRepresentation (exec_cf_path, path, sizeof(path)))<br>
> +                        {<br>
> +                            if (log)<br>
>                              {<br>
> -                                *out_dsym_fspec = Symbols::FindSymbolFileInBundle (*out_dsym_fspec, uuid, arch);<br>
> -                                if (*out_dsym_fspec)<br>
> -                                    ++items_found;<br>
> +                                log->Printf ("plist bundle has exec path of %s for UUID %s", path, uuid->GetAsString().c_str());<br>
>                              }<br>
> -                            else<br>
> +                            ++items_found;<br>
> +                            FileSpec exec_filespec (path, path[0] == '~');<br>
> +                            if (exec_filespec.Exists())<br>
>                              {<br>
> -                                ++items_found;<br>
> +                                success = true;<br>
> +                                return_module_spec.GetFileSpec() = exec_filespec;<br>
>                              }<br>
>                          }<br>
>                      }<br>
><br>
> -                    if (out_exec_fspec)<br>
> +                    if (!success)<br>
>                      {<br>
> -                        bool success = false;<br>
> -                        if (log)<br>
> -                        {<br>
> -                            if (::CFURLGetFileSystemRepresentation (dsym_url.get(), true, (UInt8*)path, sizeof(path)-1))<br>
> -                            {<br>
> -                                log->Printf ("DebugSymbols framework returned dSYM path of %s for UUID %s -- looking for an exec file", path, uuid->GetAsString().c_str());<br>
> -                            }<br>
> -<br>
> -                        }<br>
> -                        CFCReleaser<CFDictionaryRef> dict(::DBGCopyDSYMPropertyLists (dsym_url.get()));<br>
> -                        CFDictionaryRef uuid_dict = NULL;<br>
> -                        if (dict.get())<br>
> -                        {<br>
> -                            CFCString uuid_cfstr (uuid->GetAsString().c_str());<br>
> -                            uuid_dict = static_cast<CFDictionaryRef>(::CFDictionaryGetValue (dict.get(), uuid_cfstr.get()));<br>
> -                        }<br>
> -                        if (uuid_dict)<br>
> +                        // No dictionary, check near the dSYM bundle for an executable that matches...<br>
> +                        if (::CFURLGetFileSystemRepresentation (dsym_url.get(), true, (UInt8*)path, sizeof(path)-1))<br>
>                          {<br>
> -                            CFStringRef exec_cf_path = static_cast<CFStringRef>(::CFDictionaryGetValue (uuid_dict, CFSTR("DBGSymbolRichExecutable")));<br>
> -                            if (exec_cf_path && ::CFStringGetFileSystemRepresentation (exec_cf_path, path, sizeof(path)))<br>
> +                            char *dsym_extension_pos = ::strstr (path, ".dSYM");<br>
> +                            if (dsym_extension_pos)<br>
>                              {<br>
> +                                *dsym_extension_pos = '\0';<br>
>                                  if (log)<br>
>                                  {<br>
> -                                    log->Printf ("plist bundle has exec path of %s for UUID %s", path, uuid->GetAsString().c_str());<br>
> +                                    log->Printf ("Looking for executable binary next to dSYM bundle with name with name %s", path);<br>
>                                  }<br>
> -                                ++items_found;<br>
> -                                out_exec_fspec->SetFile(path, path[0] == '~');<br>
> -                                if (out_exec_fspec->Exists())<br>
> -                                    success = true;<br>
> -                            }<br>
> -                        }<br>
> -<br>
> -                        if (!success)<br>
> -                        {<br>
> -                            // No dictionary, check near the dSYM bundle for an executable that matches...<br>
> -                            if (::CFURLGetFileSystemRepresentation (dsym_url.get(), true, (UInt8*)path, sizeof(path)-1))<br>
> -                            {<br>
> -                                char *dsym_extension_pos = ::strstr (path, ".dSYM");<br>
> -                                if (dsym_extension_pos)<br>
> +                                FileSpec file_spec (path, true);<br>
> +                                ModuleSpecList module_specs;<br>
> +                                ModuleSpec matched_module_spec;<br>
> +                                switch (file_spec.GetFileType())<br>
>                                  {<br>
> -                                    *dsym_extension_pos = '\0';<br>
> -                                    if (log)<br>
> -                                    {<br>
> -                                        log->Printf ("Looking for executable binary next to dSYM bundle with name with name %s", path);<br>
> -                                    }<br>
> -                                    FileSpec file_spec (path, true);<br>
> -                                    ModuleSpecList module_specs;<br>
> -                                    ModuleSpec matched_module_spec;<br>
> -                                    switch (file_spec.GetFileType())<br>
> -                                    {<br>
> -                                        case FileSpec::eFileTypeDirectory:  // Bundle directory?<br>
> +                                    case FileSpec::eFileTypeDirectory:  // Bundle directory?<br>
> +                                        {<br>
> +                                            CFCBundle bundle (path);<br>
> +                                            CFCReleaser<CFURLRef> bundle_exe_url (bundle.CopyExecutableURL ());<br>
> +                                            if (bundle_exe_url.get())<br>
>                                              {<br>
> -                                                CFCBundle bundle (path);<br>
> -                                                CFCReleaser<CFURLRef> bundle_exe_url (bundle.CopyExecutableURL ());<br>
> -                                                if (bundle_exe_url.get())<br>
> +                                                if (::CFURLGetFileSystemRepresentation (bundle_exe_url.get(), true, (UInt8*)path, sizeof(path)-1))<br>
>                                                  {<br>
> -                                                    if (::CFURLGetFileSystemRepresentation (bundle_exe_url.get(), true, (UInt8*)path, sizeof(path)-1))<br>
> -                                                    {<br>
> -                                                        FileSpec bundle_exe_file_spec (path, true);<br>
> -                                                        if (ObjectFile::GetModuleSpecifications(bundle_exe_file_spec, 0, 0, module_specs) &&<br>
> -                                                            module_specs.FindMatchingModuleSpec(module_spec, matched_module_spec))<br>
> +                                                    FileSpec bundle_exe_file_spec (path, true);<br>
> +                                                    if (ObjectFile::GetModuleSpecifications(bundle_exe_file_spec, 0, 0, module_specs) &&<br>
> +                                                        module_specs.FindMatchingModuleSpec(module_spec, matched_module_spec))<br>
><br>
> +                                                    {<br>
> +                                                        ++items_found;<br>
> +                                                        return_module_spec.GetFileSpec() = bundle_exe_file_spec;<br>
> +                                                        if (log)<br>
>                                                          {<br>
> -                                                            ++items_found;<br>
> -                                                            *out_exec_fspec = bundle_exe_file_spec;<br>
> -                                                            if (log)<br>
> -                                                            {<br>
> -                                                                log->Printf ("Executable binary %s next to dSYM is compatible; using", path);<br>
> -                                                            }<br>
> +                                                            log->Printf ("Executable binary %s next to dSYM is compatible; using", path);<br>
>                                                          }<br>
>                                                      }<br>
>                                                  }<br>
>                                              }<br>
> -                                            break;<br>
> -<br>
> -                                        case FileSpec::eFileTypePipe:       // Forget pipes<br>
> -                                        case FileSpec::eFileTypeSocket:     // We can't process socket files<br>
> -                                        case FileSpec::eFileTypeInvalid:    // File doesn't exist...<br>
> -                                            break;<br>
> -<br>
> -                                        case FileSpec::eFileTypeUnknown:<br>
> -                                        case FileSpec::eFileTypeRegular:<br>
> -                                        case FileSpec::eFileTypeSymbolicLink:<br>
> -                                        case FileSpec::eFileTypeOther:<br>
> -                                            if (ObjectFile::GetModuleSpecifications(file_spec, 0, 0, module_specs) &&<br>
> -                                                module_specs.FindMatchingModuleSpec(module_spec, matched_module_spec))<br>
> +                                        }<br>
> +                                        break;<br>
><br>
> +                                    case FileSpec::eFileTypePipe:       // Forget pipes<br>
> +                                    case FileSpec::eFileTypeSocket:     // We can't process socket files<br>
> +                                    case FileSpec::eFileTypeInvalid:    // File doesn't exist...<br>
> +                                        break;<br>
> +<br>
> +                                    case FileSpec::eFileTypeUnknown:<br>
> +                                    case FileSpec::eFileTypeRegular:<br>
> +                                    case FileSpec::eFileTypeSymbolicLink:<br>
> +                                    case FileSpec::eFileTypeOther:<br>
> +                                        if (ObjectFile::GetModuleSpecifications(file_spec, 0, 0, module_specs) &&<br>
> +                                            module_specs.FindMatchingModuleSpec(module_spec, matched_module_spec))<br>
> +<br>
> +                                        {<br>
> +                                            ++items_found;<br>
> +                                            return_module_spec.GetFileSpec() = file_spec;<br>
> +                                            if (log)<br>
>                                              {<br>
> -                                                ++items_found;<br>
> -                                                *out_exec_fspec = file_spec;<br>
> -                                                if (log)<br>
> -                                                {<br>
> -                                                    log->Printf ("Executable binary %s next to dSYM is compatible; using", path);<br>
> -                                                }<br>
> +                                                log->Printf ("Executable binary %s next to dSYM is compatible; using", path);<br>
>                                              }<br>
> -                                            break;<br>
> -                                    }<br>
> +                                        }<br>
> +                                        break;<br>
>                                  }<br>
>                              }<br>
>                          }<br>
><br>
> Modified: lldb/trunk/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp?rev=248985&r1=248984&r2=248985&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp?rev=248985&r1=248984&r2=248985&view=diff</a><br>
> ==============================================================================<br>
> --- lldb/trunk/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp (original)<br>
> +++ lldb/trunk/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp Thu Oct  1 00:37:22 2015<br>
> @@ -321,7 +321,13 @@ ProcessKDP::DoConnectRemote (Stream *str<br>
>                              // Lookup UUID locally, before attempting dsymForUUID like action<br>
>                              module_spec.GetSymbolFileSpec() = Symbols::LocateExecutableSymbolFile(module_spec);<br>
>                              if (module_spec.GetSymbolFileSpec())<br>
> -                                 module_spec.GetFileSpec() = Symbols::LocateExecutableObjectFile (module_spec);<br>
> +                            {<br>
> +                                ModuleSpec executable_module_spec = Symbols::LocateExecutableObjectFile (module_spec);<br>
> +                                if (executable_module_spec.GetFileSpec().Exists())<br>
> +                                {<br>
> +                                    module_spec.GetFileSpec() = executable_module_spec.GetFileSpec();<br>
> +                                }<br>
> +                            }<br>
>                              if (!module_spec.GetSymbolFileSpec() || !module_spec.GetSymbolFileSpec())<br>
>                                   Symbols::DownloadObjectAndSymbolFile (module_spec, true);<br>
><br>
><br>
><br>
> _______________________________________________<br>
> lldb-commits mailing list<br>
> <a href="mailto:lldb-commits@lists.llvm.org" target="_blank">lldb-commits@lists.llvm.org</a><br>
> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits</a><br>
<br>
</blockquote></div>