summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xlldb/scripts/Python/finish-swig-Python-LLDB.sh19
-rw-r--r--lldb/scripts/Python/finishSwigPythonLLDB.py60
-rw-r--r--lldb/tools/CMakeLists.txt1
-rw-r--r--lldb/tools/darwin-debug/CMakeLists.txt3
4 files changed, 81 insertions, 2 deletions
diff --git a/lldb/scripts/Python/finish-swig-Python-LLDB.sh b/lldb/scripts/Python/finish-swig-Python-LLDB.sh
index 2e286a632cc..690e88272d3 100755
--- a/lldb/scripts/Python/finish-swig-Python-LLDB.sh
+++ b/lldb/scripts/Python/finish-swig-Python-LLDB.sh
@@ -167,6 +167,25 @@ else
fi
fi
+if [ ${OS_NAME} = "Darwin" ] && [ $MakefileCalled -ne 0 ]
+then
+ # We are being built by CMake on Darwin
+
+ if [ ! -L "${framework_python_dir}/darwin-debug" ]
+ then
+ if [ $Debug -eq 1 ]
+ then
+ echo "Creating symlink for darwin-debug"
+ fi
+ cd "${framework_python_dir}"
+ ln -s "../../../../bin/lldb-launcher" darwin-debug
+ else
+ if [ $Debug -eq 1 ]
+ then
+ echo "${framework_python_dir}/darwin-debug already exists."
+ fi
+ fi
+fi
create_python_package () {
package_dir="${framework_python_dir}$1"
diff --git a/lldb/scripts/Python/finishSwigPythonLLDB.py b/lldb/scripts/Python/finishSwigPythonLLDB.py
index f17b9159681..978b0d67091 100644
--- a/lldb/scripts/Python/finishSwigPythonLLDB.py
+++ b/lldb/scripts/Python/finishSwigPythonLLDB.py
@@ -330,6 +330,53 @@ def make_symlink_other_platforms( vDictArgs, vstrFrameworkPythonDir, vstrSoPath
return (bOk, strMsg);
#++---------------------------------------------------------------------------
+# Details: Make the symbolic link to the darwin-debug. Code for all platforms
+# apart from Windows.
+# Args: vDictArgs - (R) Program input parameters.
+# vstrFrameworkPythonDir - (R) Python framework directory.
+# vstrDarwinDebugFileName - (R) File name for darwin-debug.
+# Returns: Bool - True = function success, False = failure.
+# Str - Error description on task failure.
+# Throws: None.
+#--
+def make_symlink_darwin_debug( vDictArgs, vstrFrameworkPythonDir, vstrDarwinDebugFileName ):
+ dbg = utilsDebug.CDebugFnVerbose( "Python script make_symlink_other_platforms()" );
+ bOk = True;
+ strMsg = "";
+ bDbg = vDictArgs.has_key( "-d" );
+ strTarget = vstrDarwinDebugFileName
+ strDarwinDebugPath = "%s/%s" % (vstrFrameworkPythonDir, strTarget);
+ strTarget = os.path.normcase( strDarwinDebugPath );
+ strSrc = "";
+
+ os.chdir( vstrFrameworkPythonDir );
+ bMakeFileCalled = vDictArgs.has_key( "-m" );
+ if not bMakeFileCalled:
+ return (bOk, strMsg);
+ else:
+ strSrc = os.path.normcase( "../../../../bin/lldb-launcher" );
+
+ if os.path.islink( strTarget ):
+ if bDbg:
+ print strMsglldbsoExists % strTarget;
+ return (bOk, strMsg);
+
+ if bDbg:
+ print strMsglldbsoMk;
+
+ try:
+ os.symlink( strSrc, strTarget );
+ except OSError as e:
+ bOk = False;
+ strMsg = "OSError( %d ): %s %s" % (e.errno, e.strerror, strErrMsgMakeSymlink);
+ strMsg += " Src:'%s' Target:'%s'" % (strSrc, strTarget);
+ except:
+ bOk = False;
+ strMsg = strErrMsgUnexpected % sys.exec_info()[ 0 ];
+
+ return (bOk, strMsg);
+
+#++---------------------------------------------------------------------------
# Details: Make the symlink that the script bridge for Python will need in
# the Python framework directory.
# Args: vDictArgs - (R) Program input parameters.
@@ -343,9 +390,10 @@ def make_symlink( vDictArgs, vstrFrameworkPythonDir ):
bOk = True;
strWkDir = "";
strErrMsg = "";
- strSoFileName = "_lldb";
-
eOSType = utilsOsType.determine_os_type();
+
+ # Make symlink for _lldb
+ strSoFileName = "_lldb";
if eOSType == utilsOsType.EnumOsType.Unknown:
bOk = False;
strErrMsg = strErrMsgOsTypeUnknown;
@@ -357,6 +405,14 @@ def make_symlink( vDictArgs, vstrFrameworkPythonDir ):
bOk, strErrMsg = make_symlink_other_platforms( vDictArgs,
vstrFrameworkPythonDir,
strSoFileName );
+
+ # Make symlink for darwin-debug
+ strDarwinDebugFileName = "darwin-debug"
+ if bOk and eOSType == utilsOsType.EnumOsType.Darwin:
+ bOk, strErrMsg = make_symlink_darwin_debug( vDictArgs,
+ vstrFrameworkPythonDir,
+ strDarwinDebugFileName );
+
return (bOk, strErrMsg);
#++---------------------------------------------------------------------------
diff --git a/lldb/tools/CMakeLists.txt b/lldb/tools/CMakeLists.txt
index 8008b0783fb..bb3ce2d1ab7 100644
--- a/lldb/tools/CMakeLists.txt
+++ b/lldb/tools/CMakeLists.txt
@@ -1,4 +1,5 @@
if (CMAKE_SYSTEM_NAME MATCHES "Darwin")
+ add_subdirectory(darwin-debug)
add_subdirectory(debugserver)
endif()
add_subdirectory(driver)
diff --git a/lldb/tools/darwin-debug/CMakeLists.txt b/lldb/tools/darwin-debug/CMakeLists.txt
new file mode 100644
index 00000000000..0f79772cbbc
--- /dev/null
+++ b/lldb/tools/darwin-debug/CMakeLists.txt
@@ -0,0 +1,3 @@
+add_lldb_executable(lldb-launcher
+ darwin-debug.cpp
+ )
OpenPOWER on IntegriCloud