2013-11-21 05:07:01 +08:00
|
|
|
//===-- SWIG Interface for SBPlatform ---------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2013-11-21 05:07:01 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
namespace lldb {
|
|
|
|
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2021-01-16 02:49:51 +08:00
|
|
|
%feature("docstring",
|
|
|
|
"Describes how :py:class:`SBPlatform.ConnectRemote` connects to a remote platform."
|
|
|
|
) SBPlatformConnectOptions;
|
2013-11-21 05:07:01 +08:00
|
|
|
class SBPlatformConnectOptions
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
SBPlatformConnectOptions (const char *url);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
SBPlatformConnectOptions (const SBPlatformConnectOptions &rhs);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
~SBPlatformConnectOptions ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetURL();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
void
|
|
|
|
SetURL(const char *url);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
bool
|
|
|
|
GetRsyncEnabled();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
void
|
|
|
|
EnableRsync (const char *options,
|
|
|
|
const char *remote_path_prefix,
|
|
|
|
bool omit_remote_hostname);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
void
|
|
|
|
DisableRsync ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetLocalCacheDirectory();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
void
|
|
|
|
SetLocalCacheDirectory(const char *path);
|
|
|
|
};
|
|
|
|
|
2021-01-16 02:49:51 +08:00
|
|
|
%feature("docstring",
|
|
|
|
"Represents a shell command that can be run by :py:class:`SBPlatform.Run`."
|
|
|
|
) SBPlatformShellCommand;
|
2013-11-21 05:07:01 +08:00
|
|
|
class SBPlatformShellCommand
|
|
|
|
{
|
|
|
|
public:
|
2020-08-28 21:38:39 +08:00
|
|
|
SBPlatformShellCommand (const char *shell, const char *shell_command);
|
2013-11-21 05:07:01 +08:00
|
|
|
SBPlatformShellCommand (const char *shell_command);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
SBPlatformShellCommand (const SBPlatformShellCommand &rhs);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
~SBPlatformShellCommand();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
void
|
|
|
|
Clear();
|
|
|
|
|
2020-08-28 21:38:39 +08:00
|
|
|
const char *
|
|
|
|
GetShell();
|
|
|
|
|
|
|
|
void
|
|
|
|
SetShell(const char *shell_interpreter);
|
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetCommand();
|
|
|
|
|
|
|
|
void
|
|
|
|
SetCommand(const char *shell_command);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetWorkingDirectory ();
|
|
|
|
|
|
|
|
void
|
|
|
|
SetWorkingDirectory (const char *path);
|
|
|
|
|
|
|
|
uint32_t
|
|
|
|
GetTimeoutSeconds ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
void
|
|
|
|
SetTimeoutSeconds (uint32_t sec);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
int
|
|
|
|
GetSignal ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
int
|
|
|
|
GetStatus ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetOutput ();
|
|
|
|
};
|
|
|
|
|
|
|
|
%feature("docstring",
|
2015-06-18 13:27:05 +08:00
|
|
|
"A class that represents a platform that can represent the current host or a remote host debug platform.
|
2013-11-21 05:07:01 +08:00
|
|
|
|
|
|
|
The SBPlatform class represents the current host, or a remote host.
|
|
|
|
It can be connected to a remote platform in order to provide ways
|
|
|
|
to remotely launch and attach to processes, upload/download files,
|
|
|
|
create directories, run remote shell commands, find locally cached
|
|
|
|
versions of files from the remote system, and much more.
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
SBPlatform objects can be created and then used to connect to a remote
|
|
|
|
platform which allows the SBPlatform to be used to get a list of the
|
|
|
|
current processes on the remote host, attach to one of those processes,
|
|
|
|
install programs on the remote system, attach and launch processes,
|
|
|
|
and much more.
|
|
|
|
|
2021-01-15 21:43:26 +08:00
|
|
|
Every :py:class:`SBTarget` has a corresponding SBPlatform. The platform can be
|
2013-11-21 05:07:01 +08:00
|
|
|
specified upon target creation, or the currently selected platform
|
|
|
|
will attempt to be used when creating the target automatically as long
|
|
|
|
as the currently selected platform matches the target architecture
|
|
|
|
and executable type. If the architecture or executable type do not match,
|
|
|
|
a suitable platform will be found automatically."
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
) SBPlatform;
|
|
|
|
class SBPlatform
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
SBPlatform ();
|
|
|
|
|
|
|
|
SBPlatform (const char *);
|
|
|
|
|
|
|
|
~SBPlatform();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2020-03-05 15:12:54 +08:00
|
|
|
static SBPlatform GetHostPlatform();
|
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
bool
|
|
|
|
IsValid () const;
|
|
|
|
|
Add "operator bool" to SB APIs
Summary:
Our python version of the SB API has (the python equivalent of)
operator bool, but the C++ version doesn't.
This is because our python operators are added by modify-python-lldb.py,
which performs postprocessing on the swig-generated interface files.
In this patch, I add the "operator bool" to all SB classes which have an
IsValid method (which is the same logic used by modify-python-lldb.py).
This way, we make the two interfaces more constent, and it allows us to
rely on swig's automatic syntesis of python __nonzero__ methods instead
of doing manual fixups.
Reviewers: zturner, jingham, clayborg, jfb, serge-sans-paille
Subscribers: jdoerfert, lldb-commits
Differential Revision: https://reviews.llvm.org/D58792
llvm-svn: 355824
2019-03-11 21:58:46 +08:00
|
|
|
explicit operator bool() const;
|
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
void
|
|
|
|
Clear ();
|
|
|
|
|
|
|
|
const char *
|
|
|
|
GetWorkingDirectory();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
bool
|
|
|
|
SetWorkingDirectory(const char *);
|
|
|
|
|
|
|
|
const char *
|
|
|
|
GetName ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
SBError
|
|
|
|
ConnectRemote (lldb::SBPlatformConnectOptions &connect_options);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
void
|
|
|
|
DisconnectRemote ();
|
|
|
|
|
|
|
|
bool
|
|
|
|
IsConnected();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetTriple();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetHostname ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetOSBuild ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
const char *
|
|
|
|
GetOSDescription ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
uint32_t
|
|
|
|
GetOSMajorVersion ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
uint32_t
|
|
|
|
GetOSMinorVersion ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
uint32_t
|
|
|
|
GetOSUpdateVersion ();
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2022-01-18 18:26:07 +08:00
|
|
|
void
|
|
|
|
SetSDKRoot(const char *sysroot);
|
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
lldb::SBError
|
|
|
|
Get (lldb::SBFileSpec &src, lldb::SBFileSpec &dst);
|
|
|
|
|
|
|
|
lldb::SBError
|
|
|
|
Put (lldb::SBFileSpec &src, lldb::SBFileSpec &dst);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
lldb::SBError
|
|
|
|
Install (lldb::SBFileSpec &src, lldb::SBFileSpec &dst);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
lldb::SBError
|
|
|
|
Run (lldb::SBPlatformShellCommand &shell_command);
|
|
|
|
|
2015-02-05 07:19:15 +08:00
|
|
|
lldb::SBError
|
|
|
|
Launch (lldb::SBLaunchInfo &launch_info);
|
|
|
|
|
|
|
|
lldb::SBError
|
|
|
|
Kill (const lldb::pid_t pid);
|
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
lldb::SBError
|
|
|
|
MakeDirectory (const char *path, uint32_t file_permissions = lldb::eFilePermissionsDirectoryDefault);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
uint32_t
|
|
|
|
GetFilePermissions (const char *path);
|
2019-04-19 00:23:33 +08:00
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
lldb::SBError
|
|
|
|
SetFilePermissions (const char *path, uint32_t file_permissions);
|
|
|
|
|
2015-07-14 09:09:28 +08:00
|
|
|
lldb::SBUnixSignals
|
|
|
|
GetUnixSignals();
|
|
|
|
|
2020-03-21 10:31:33 +08:00
|
|
|
lldb::SBEnvironment
|
|
|
|
GetEnvironment();
|
|
|
|
|
2013-11-21 05:07:01 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace lldb
|