Move PlatformFreeBSD to its own namespace

Based on r233679

llvm-svn: 241287
This commit is contained in:
Ed Maste 2015-07-02 17:35:22 +00:00
parent 03e23121f8
commit ae9f2b9b24
3 changed files with 139 additions and 133 deletions

View File

@ -106,7 +106,7 @@ SystemInitializerCommon::Initialize()
ObjectFileELF::Initialize();
ObjectFilePECOFF::Initialize();
DynamicLoaderPOSIXDYLD::Initialize();
PlatformFreeBSD::Initialize();
platform_freebsd::PlatformFreeBSD::Initialize();
platform_linux::PlatformLinux::Initialize();
PlatformWindows::Initialize();
PlatformKalimba::Initialize();
@ -152,7 +152,7 @@ SystemInitializerCommon::Terminate()
ObjectFileELF::Terminate();
ObjectFilePECOFF::Terminate();
DynamicLoaderPOSIXDYLD::Terminate();
PlatformFreeBSD::Terminate();
platform_freebsd::PlatformFreeBSD::Terminate();
platform_linux::PlatformLinux::Terminate();
PlatformWindows::Terminate();
PlatformKalimba::Terminate();

View File

@ -32,9 +32,10 @@
using namespace lldb;
using namespace lldb_private;
using namespace lldb_private::platform_freebsd;
PlatformSP
PlatformFreeBSD::CreateInstance (bool force, const lldb_private::ArchSpec *arch)
PlatformFreeBSD::CreateInstance(bool force, const ArchSpec *arch)
{
// The only time we create an instance is when we are creating a remote
// freebsd platform
@ -68,8 +69,8 @@ PlatformFreeBSD::CreateInstance (bool force, const lldb_private::ArchSpec *arch)
}
lldb_private::ConstString
PlatformFreeBSD::GetPluginNameStatic (bool is_host)
ConstString
PlatformFreeBSD::GetPluginNameStatic(bool is_host)
{
if (is_host)
{
@ -133,7 +134,7 @@ PlatformFreeBSD::GetModuleSpec (const FileSpec& module_file_spec,
return Platform::GetModuleSpec (module_file_spec, arch, module_spec);
}
lldb_private::Error
Error
PlatformFreeBSD::RunShellCommand(const char *command,
const FileSpec &working_dir,
int *status_ptr,

View File

@ -16,162 +16,167 @@
// Project includes
#include "lldb/Target/Platform.h"
class PlatformFreeBSD : public lldb_private::Platform
{
public:
// Mostly taken from PlatformDarwin and PlatformMacOSX
namespace lldb_private {
namespace platform_freebsd {
//------------------------------------------------------------
// Class functions
//------------------------------------------------------------
static lldb::PlatformSP
CreateInstance (bool force, const lldb_private::ArchSpec *arch);
static void
Initialize ();
static void
Terminate ();
static lldb_private::ConstString
GetPluginNameStatic (bool is_host);
static const char *
GetDescriptionStatic (bool is_host);
//------------------------------------------------------------
// Class Methods
//------------------------------------------------------------
PlatformFreeBSD (bool is_host);
virtual
~PlatformFreeBSD();
//------------------------------------------------------------
// lldb_private::PluginInterface functions
//------------------------------------------------------------
lldb_private::ConstString
GetPluginName() override
class PlatformFreeBSD : public Platform
{
return GetPluginNameStatic (IsHost());
}
public:
uint32_t
GetPluginVersion() override
{
return 1;
}
//------------------------------------------------------------
// Class functions
//------------------------------------------------------------
static lldb::PlatformSP
CreateInstance(bool force, const ArchSpec *arch);
const char *
GetDescription () override
{
return GetDescriptionStatic(IsHost());
}
static void
Initialize ();
//------------------------------------------------------------
// lldb_private::Platform functions
//------------------------------------------------------------
bool
GetModuleSpec (const lldb_private::FileSpec& module_file_spec,
const lldb_private::ArchSpec& arch,
lldb_private::ModuleSpec &module_spec) override;
static void
Terminate ();
lldb_private::Error
RunShellCommand(const char *command,
const lldb_private::FileSpec &working_dir,
int *status_ptr,
int *signo_ptr,
std::string *command_output,
uint32_t timeout_sec) override;
static ConstString
GetPluginNameStatic (bool is_host);
lldb_private::Error
ResolveExecutable (const lldb_private::ModuleSpec &module_spec,
lldb::ModuleSP &module_sp,
const lldb_private::FileSpecList *module_search_paths_ptr) override;
static const char *
GetDescriptionStatic (bool is_host);
size_t
GetSoftwareBreakpointTrapOpcode (lldb_private::Target &target,
lldb_private::BreakpointSite *bp_site) override;
//------------------------------------------------------------
// Class Methods
//------------------------------------------------------------
PlatformFreeBSD (bool is_host);
bool
GetRemoteOSVersion () override;
virtual
~PlatformFreeBSD();
bool
GetRemoteOSBuildString (std::string &s) override;
//------------------------------------------------------------
// lldb_private::PluginInterface functions
//------------------------------------------------------------
ConstString
GetPluginName() override
{
return GetPluginNameStatic (IsHost());
}
bool
GetRemoteOSKernelDescription (std::string &s) override;
uint32_t
GetPluginVersion() override
{
return 1;
}
// Remote Platform subclasses need to override this function
lldb_private::ArchSpec
GetRemoteSystemArchitecture () override;
const char *
GetDescription () override
{
return GetDescriptionStatic(IsHost());
}
bool
IsConnected () const override;
//------------------------------------------------------------
// lldb_private::Platform functions
//------------------------------------------------------------
bool
GetModuleSpec(const FileSpec& module_file_spec,
const ArchSpec& arch,
ModuleSpec &module_spec) override;
lldb_private::Error
ConnectRemote (lldb_private::Args& args) override;
Error
RunShellCommand(const char *command,
const FileSpec &working_dir,
int *status_ptr,
int *signo_ptr,
std::string *command_output,
uint32_t timeout_sec) override;
lldb_private::Error
DisconnectRemote () override;
Error
ResolveExecutable(const ModuleSpec &module_spec,
lldb::ModuleSP &module_sp,
const FileSpecList *module_search_paths_ptr) override;
const char *
GetHostname () override;
size_t
GetSoftwareBreakpointTrapOpcode(Target &target,
BreakpointSite *bp_site) override;
const char *
GetUserName (uint32_t uid) override;
bool
GetRemoteOSVersion () override;
const char *
GetGroupName (uint32_t gid) override;
bool
GetRemoteOSBuildString (std::string &s) override;
bool
GetProcessInfo (lldb::pid_t pid,
lldb_private::ProcessInstanceInfo &proc_info) override;
bool
GetRemoteOSKernelDescription (std::string &s) override;
uint32_t
FindProcesses (const lldb_private::ProcessInstanceInfoMatch &match_info,
lldb_private::ProcessInstanceInfoList &process_infos) override;
// Remote Platform subclasses need to override this function
ArchSpec
GetRemoteSystemArchitecture() override;
lldb_private::Error
LaunchProcess (lldb_private::ProcessLaunchInfo &launch_info) override;
bool
IsConnected () const override;
lldb::ProcessSP
Attach(lldb_private::ProcessAttachInfo &attach_info,
lldb_private::Debugger &debugger,
lldb_private::Target *target,
lldb_private::Error &error) override;
Error
ConnectRemote(Args& args) override;
// FreeBSD processes can not be launched by spawning and attaching.
bool
CanDebugProcess () override { return false; }
Error
DisconnectRemote() override;
// Only on PlatformMacOSX:
lldb_private::Error
GetFileWithUUID (const lldb_private::FileSpec &platform_file,
const lldb_private::UUID* uuid, lldb_private::FileSpec &local_file) override;
const char *
GetHostname () override;
lldb_private::Error
GetSharedModule (const lldb_private::ModuleSpec &module_spec,
lldb_private::Process* process,
lldb::ModuleSP &module_sp,
const lldb_private::FileSpecList *module_search_paths_ptr,
lldb::ModuleSP *old_module_sp_ptr,
bool *did_create_ptr) override;
const char *
GetUserName (uint32_t uid) override;
bool
GetSupportedArchitectureAtIndex (uint32_t idx, lldb_private::ArchSpec &arch) override;
const char *
GetGroupName (uint32_t gid) override;
void
GetStatus (lldb_private::Stream &strm) override;
bool
GetProcessInfo(lldb::pid_t pid,
ProcessInstanceInfo &proc_info) override;
void
CalculateTrapHandlerSymbolNames () override;
uint32_t
FindProcesses(const ProcessInstanceInfoMatch &match_info,
ProcessInstanceInfoList &process_infos) override;
protected:
lldb::PlatformSP m_remote_platform_sp; // Allow multiple ways to connect to a remote freebsd OS
Error
LaunchProcess(ProcessLaunchInfo &launch_info) override;
private:
DISALLOW_COPY_AND_ASSIGN (PlatformFreeBSD);
};
lldb::ProcessSP
Attach(ProcessAttachInfo &attach_info,
Debugger &debugger,
Target *target,
Error &error) override;
// FreeBSD processes can not be launched by spawning and attaching.
bool
CanDebugProcess () override { return false; }
// Only on PlatformMacOSX:
Error
GetFileWithUUID(const FileSpec &platform_file,
const UUID* uuid, FileSpec &local_file) override;
Error
GetSharedModule(const ModuleSpec &module_spec,
Process* process,
lldb::ModuleSP &module_sp,
const FileSpecList *module_search_paths_ptr,
lldb::ModuleSP *old_module_sp_ptr,
bool *did_create_ptr) override;
bool
GetSupportedArchitectureAtIndex(uint32_t idx, ArchSpec &arch) override;
void
GetStatus(Stream &strm) override;
void
CalculateTrapHandlerSymbolNames () override;
protected:
lldb::PlatformSP m_remote_platform_sp; // Allow multiple ways to connect to a remote freebsd OS
private:
DISALLOW_COPY_AND_ASSIGN (PlatformFreeBSD);
};
} // namespace platform_freebsd
} // namespace lldb_private
#endif // liblldb_PlatformFreeBSD_h_