256 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			256 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			C++
		
	
	
	
| //===-- SBCommunication.cpp -------------------------------------*- C++ -*-===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is distributed under the University of Illinois Open Source
 | |
| // License. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| #include "lldb/API/SBCommunication.h"
 | |
| #include "lldb/API/SBBroadcaster.h"
 | |
| #include "lldb/Core/Communication.h"
 | |
| #include "lldb/Host/ConnectionFileDescriptor.h"
 | |
| #include "lldb/Host/Host.h"
 | |
| #include "lldb/Utility/Log.h"
 | |
| 
 | |
| using namespace lldb;
 | |
| using namespace lldb_private;
 | |
| 
 | |
| SBCommunication::SBCommunication() : m_opaque(NULL), m_opaque_owned(false) {}
 | |
| 
 | |
| SBCommunication::SBCommunication(const char *broadcaster_name)
 | |
|     : m_opaque(new Communication(broadcaster_name)), m_opaque_owned(true) {
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication::SBCommunication (broadcaster_name=\"%s\") => "
 | |
|                 "SBCommunication(%p)",
 | |
|                 broadcaster_name, static_cast<void *>(m_opaque));
 | |
| }
 | |
| 
 | |
| SBCommunication::~SBCommunication() {
 | |
|   if (m_opaque && m_opaque_owned)
 | |
|     delete m_opaque;
 | |
|   m_opaque = NULL;
 | |
|   m_opaque_owned = false;
 | |
| }
 | |
| 
 | |
| bool SBCommunication::IsValid() const { return m_opaque != NULL; }
 | |
| 
 | |
| bool SBCommunication::GetCloseOnEOF() {
 | |
|   if (m_opaque)
 | |
|     return m_opaque->GetCloseOnEOF();
 | |
|   return false;
 | |
| }
 | |
| 
 | |
| void SBCommunication::SetCloseOnEOF(bool b) {
 | |
|   if (m_opaque)
 | |
|     m_opaque->SetCloseOnEOF(b);
 | |
| }
 | |
| 
 | |
| ConnectionStatus SBCommunication::Connect(const char *url) {
 | |
|   if (m_opaque) {
 | |
|     if (!m_opaque->HasConnection())
 | |
|       m_opaque->SetConnection(Host::CreateDefaultConnection(url).release());
 | |
|     return m_opaque->Connect(url, NULL);
 | |
|   }
 | |
|   return eConnectionStatusNoConnection;
 | |
| }
 | |
| 
 | |
| ConnectionStatus SBCommunication::AdoptFileDesriptor(int fd, bool owns_fd) {
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
| 
 | |
|   ConnectionStatus status = eConnectionStatusNoConnection;
 | |
|   if (m_opaque) {
 | |
|     if (m_opaque->HasConnection()) {
 | |
|       if (m_opaque->IsConnected())
 | |
|         m_opaque->Disconnect();
 | |
|     }
 | |
|     m_opaque->SetConnection(new ConnectionFileDescriptor(fd, owns_fd));
 | |
|     if (m_opaque->IsConnected())
 | |
|       status = eConnectionStatusSuccess;
 | |
|     else
 | |
|       status = eConnectionStatusLostConnection;
 | |
|   }
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf(
 | |
|         "SBCommunication(%p)::AdoptFileDescriptor (fd=%d, ownd_fd=%i) => %s",
 | |
|         static_cast<void *>(m_opaque), fd, owns_fd,
 | |
|         Communication::ConnectionStatusAsCString(status));
 | |
| 
 | |
|   return status;
 | |
| }
 | |
| 
 | |
| ConnectionStatus SBCommunication::Disconnect() {
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
| 
 | |
|   ConnectionStatus status = eConnectionStatusNoConnection;
 | |
|   if (m_opaque)
 | |
|     status = m_opaque->Disconnect();
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::Disconnect () => %s",
 | |
|                 static_cast<void *>(m_opaque),
 | |
|                 Communication::ConnectionStatusAsCString(status));
 | |
| 
 | |
|   return status;
 | |
| }
 | |
| 
 | |
| bool SBCommunication::IsConnected() const {
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
|   bool result = false;
 | |
|   if (m_opaque)
 | |
|     result = m_opaque->IsConnected();
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::IsConnected () => %i",
 | |
|                 static_cast<void *>(m_opaque), result);
 | |
| 
 | |
|   return false;
 | |
| }
 | |
| 
 | |
| size_t SBCommunication::Read(void *dst, size_t dst_len, uint32_t timeout_usec,
 | |
|                              ConnectionStatus &status) {
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::Read (dst=%p, dst_len=%" PRIu64
 | |
|                 ", timeout_usec=%u, &status)...",
 | |
|                 static_cast<void *>(m_opaque), static_cast<void *>(dst),
 | |
|                 static_cast<uint64_t>(dst_len), timeout_usec);
 | |
|   size_t bytes_read = 0;
 | |
|   Timeout<std::micro> timeout = timeout_usec == UINT32_MAX
 | |
|                                     ? Timeout<std::micro>(llvm::None)
 | |
|                                     : std::chrono::microseconds(timeout_usec);
 | |
|   if (m_opaque)
 | |
|     bytes_read = m_opaque->Read(dst, dst_len, timeout, status, NULL);
 | |
|   else
 | |
|     status = eConnectionStatusNoConnection;
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::Read (dst=%p, dst_len=%" PRIu64
 | |
|                 ", timeout_usec=%u, &status=%s) => %" PRIu64,
 | |
|                 static_cast<void *>(m_opaque), static_cast<void *>(dst),
 | |
|                 static_cast<uint64_t>(dst_len), timeout_usec,
 | |
|                 Communication::ConnectionStatusAsCString(status),
 | |
|                 static_cast<uint64_t>(bytes_read));
 | |
|   return bytes_read;
 | |
| }
 | |
| 
 | |
| size_t SBCommunication::Write(const void *src, size_t src_len,
 | |
|                               ConnectionStatus &status) {
 | |
|   size_t bytes_written = 0;
 | |
|   if (m_opaque)
 | |
|     bytes_written = m_opaque->Write(src, src_len, status, NULL);
 | |
|   else
 | |
|     status = eConnectionStatusNoConnection;
 | |
| 
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::Write (src=%p, src_len=%" PRIu64
 | |
|                 ", &status=%s) => %" PRIu64,
 | |
|                 static_cast<void *>(m_opaque), static_cast<const void *>(src),
 | |
|                 static_cast<uint64_t>(src_len),
 | |
|                 Communication::ConnectionStatusAsCString(status),
 | |
|                 static_cast<uint64_t>(bytes_written));
 | |
| 
 | |
|   return 0;
 | |
| }
 | |
| 
 | |
| bool SBCommunication::ReadThreadStart() {
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
| 
 | |
|   bool success = false;
 | |
|   if (m_opaque)
 | |
|     success = m_opaque->StartReadThread();
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::ReadThreadStart () => %i",
 | |
|                 static_cast<void *>(m_opaque), success);
 | |
| 
 | |
|   return success;
 | |
| }
 | |
| 
 | |
| bool SBCommunication::ReadThreadStop() {
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::ReadThreadStop ()...",
 | |
|                 static_cast<void *>(m_opaque));
 | |
| 
 | |
|   bool success = false;
 | |
|   if (m_opaque)
 | |
|     success = m_opaque->StopReadThread();
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::ReadThreadStop () => %i",
 | |
|                 static_cast<void *>(m_opaque), success);
 | |
| 
 | |
|   return success;
 | |
| }
 | |
| 
 | |
| bool SBCommunication::ReadThreadIsRunning() {
 | |
|   bool result = false;
 | |
|   if (m_opaque)
 | |
|     result = m_opaque->ReadThreadIsRunning();
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::ReadThreadIsRunning () => %i",
 | |
|                 static_cast<void *>(m_opaque), result);
 | |
|   return result;
 | |
| }
 | |
| 
 | |
| bool SBCommunication::SetReadThreadBytesReceivedCallback(
 | |
|     ReadThreadBytesReceived callback, void *callback_baton) {
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
| 
 | |
|   bool result = false;
 | |
|   if (m_opaque) {
 | |
|     m_opaque->SetReadThreadBytesReceivedCallback(callback, callback_baton);
 | |
|     result = true;
 | |
|   }
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::SetReadThreadBytesReceivedCallback "
 | |
|                 "(callback=%p, baton=%p) => %i",
 | |
|                 static_cast<void *>(m_opaque),
 | |
|                 reinterpret_cast<void *>(reinterpret_cast<intptr_t>(callback)),
 | |
|                 static_cast<void *>(callback_baton), result);
 | |
| 
 | |
|   return result;
 | |
| }
 | |
| 
 | |
| SBBroadcaster SBCommunication::GetBroadcaster() {
 | |
|   SBBroadcaster broadcaster(m_opaque, false);
 | |
| 
 | |
|   Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_API));
 | |
| 
 | |
|   if (log)
 | |
|     log->Printf("SBCommunication(%p)::GetBroadcaster () => SBBroadcaster (%p)",
 | |
|                 static_cast<void *>(m_opaque),
 | |
|                 static_cast<void *>(broadcaster.get()));
 | |
| 
 | |
|   return broadcaster;
 | |
| }
 | |
| 
 | |
| const char *SBCommunication::GetBroadcasterClass() {
 | |
|   return Communication::GetStaticBroadcasterClass().AsCString();
 | |
| }
 | |
| 
 | |
| //
 | |
| // void
 | |
| // SBCommunication::CreateIfNeeded ()
 | |
| //{
 | |
| //    if (m_opaque == NULL)
 | |
| //    {
 | |
| //        static uint32_t g_broadcaster_num;
 | |
| //        char broadcaster_name[256];
 | |
| //        ::snprintf (name, broadcaster_name, "%p SBCommunication", this);
 | |
| //        m_opaque = new Communication (broadcaster_name);
 | |
| //        m_opaque_owned = true;
 | |
| //    }
 | |
| //    assert (m_opaque);
 | |
| //}
 | |
| //
 | |
| //
 |