libos: Remove some shared pointers and change them to owned/live on the stack
All checks were successful
continuous-integration/drone/pr Build is passing
All checks were successful
continuous-integration/drone/pr Build is passing
This commit is contained in:
parent
22d67dca93
commit
9c0fab2e88
@ -1,5 +1,5 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#include <luna/SharedPtr.h>
|
#include <luna/OwnedPtr.h>
|
||||||
#include <luna/StringView.h>
|
#include <luna/StringView.h>
|
||||||
|
|
||||||
namespace os
|
namespace os
|
||||||
@ -7,7 +7,7 @@ namespace os
|
|||||||
/**
|
/**
|
||||||
* @brief A client used to connect to a local server socket.
|
* @brief A client used to connect to a local server socket.
|
||||||
*/
|
*/
|
||||||
class LocalClient : public Shareable
|
class LocalClient
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
@ -15,9 +15,9 @@ namespace os
|
|||||||
*
|
*
|
||||||
* @param path The path of the server socket to connect to.
|
* @param path The path of the server socket to connect to.
|
||||||
* @param blocking Whether the client should block if no data is available and recv() is called.
|
* @param blocking Whether the client should block if no data is available and recv() is called.
|
||||||
* @return Result<SharedPtr<LocalClient>> An error, or a new client object.
|
* @return Result<OwnedPtr<LocalClient>> An error, or a new client object.
|
||||||
*/
|
*/
|
||||||
static Result<SharedPtr<LocalClient>> connect(StringView path, bool blocking);
|
static Result<OwnedPtr<LocalClient>> connect(StringView path, bool blocking);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Return the underlying socket file descriptor used by this object.
|
* @brief Return the underlying socket file descriptor used by this object.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
#include <luna/OwnedPtr.h>
|
||||||
#include <luna/Result.h>
|
#include <luna/Result.h>
|
||||||
#include <luna/SharedPtr.h>
|
|
||||||
#include <luna/StringView.h>
|
#include <luna/StringView.h>
|
||||||
|
|
||||||
namespace os
|
namespace os
|
||||||
@ -8,7 +8,7 @@ namespace os
|
|||||||
/**
|
/**
|
||||||
* @brief A local domain server, used to communicate between processes on the same machine.
|
* @brief A local domain server, used to communicate between processes on the same machine.
|
||||||
*/
|
*/
|
||||||
class LocalServer : public Shareable
|
class LocalServer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
@ -16,9 +16,9 @@ namespace os
|
|||||||
*
|
*
|
||||||
* @param path The path to use for the server socket.
|
* @param path The path to use for the server socket.
|
||||||
* @param blocking Whether the server should block if no connections are available when calling accept().
|
* @param blocking Whether the server should block if no connections are available when calling accept().
|
||||||
* @return Result<SharedPtr<LocalServer>> An error, or a new server object.
|
* @return Result<OwnedPtr<LocalServer>> An error, or a new server object.
|
||||||
*/
|
*/
|
||||||
static Result<SharedPtr<LocalServer>> create(StringView path, bool blocking);
|
static Result<OwnedPtr<LocalServer>> create(StringView path, bool blocking);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Activate the server and start listening for connections.
|
* @brief Activate the server and start listening for connections.
|
||||||
@ -41,7 +41,7 @@ namespace os
|
|||||||
/**
|
/**
|
||||||
* @brief An interface to communicate with clients connected to a local server.
|
* @brief An interface to communicate with clients connected to a local server.
|
||||||
*/
|
*/
|
||||||
class Client : public Shareable
|
class Client
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
@ -107,6 +107,7 @@ namespace os
|
|||||||
return m_fd;
|
return m_fd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Client(Client&& other);
|
||||||
Client(int fd);
|
Client(int fd);
|
||||||
~Client();
|
~Client();
|
||||||
|
|
||||||
@ -119,9 +120,9 @@ namespace os
|
|||||||
* accept() either blocks until there is one (if the object was created with blocking=true), or returns EAGAIN
|
* accept() either blocks until there is one (if the object was created with blocking=true), or returns EAGAIN
|
||||||
* (if the object was created with blocking=false).
|
* (if the object was created with blocking=false).
|
||||||
*
|
*
|
||||||
* @return Result<SharedPtr<Client>> An error, or a handle to the new connection.
|
* @return Result<Client> An error, or a handle to the new connection.
|
||||||
*/
|
*/
|
||||||
Result<SharedPtr<Client>> accept();
|
Result<Client> accept();
|
||||||
|
|
||||||
~LocalServer();
|
~LocalServer();
|
||||||
|
|
||||||
|
@ -7,9 +7,9 @@
|
|||||||
|
|
||||||
namespace os
|
namespace os
|
||||||
{
|
{
|
||||||
Result<SharedPtr<LocalClient>> LocalClient::connect(StringView path, bool blocking)
|
Result<OwnedPtr<LocalClient>> LocalClient::connect(StringView path, bool blocking)
|
||||||
{
|
{
|
||||||
auto client = TRY(make_shared<LocalClient>());
|
auto client = TRY(make_owned<LocalClient>());
|
||||||
|
|
||||||
int sockfd = socket(AF_UNIX, SOCK_STREAM, 0);
|
int sockfd = socket(AF_UNIX, SOCK_STREAM, 0);
|
||||||
if (sockfd < 0) return err(errno);
|
if (sockfd < 0) return err(errno);
|
||||||
|
@ -8,9 +8,9 @@
|
|||||||
|
|
||||||
namespace os
|
namespace os
|
||||||
{
|
{
|
||||||
Result<SharedPtr<LocalServer>> LocalServer::create(StringView path, bool blocking)
|
Result<OwnedPtr<LocalServer>> LocalServer::create(StringView path, bool blocking)
|
||||||
{
|
{
|
||||||
auto server = TRY(make_shared<LocalServer>());
|
auto server = TRY(make_owned<LocalServer>());
|
||||||
|
|
||||||
(void)os::FileSystem::remove(path); // We explicitly ignore any error here, either it doesn't exist (which is
|
(void)os::FileSystem::remove(path); // We explicitly ignore any error here, either it doesn't exist (which is
|
||||||
// fine), or it cannot be removed, which will make bind() fail later.
|
// fine), or it cannot be removed, which will make bind() fail later.
|
||||||
@ -43,12 +43,12 @@ namespace os
|
|||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
Result<SharedPtr<LocalServer::Client>> LocalServer::accept()
|
Result<LocalServer::Client> LocalServer::accept()
|
||||||
{
|
{
|
||||||
int fd = ::accept(m_fd, nullptr, nullptr);
|
int fd = ::accept(m_fd, nullptr, nullptr);
|
||||||
if (fd < 0) return err(errno);
|
if (fd < 0) return err(errno);
|
||||||
if (!m_blocking) fcntl(fd, F_SETFL, O_NONBLOCK);
|
if (!m_blocking) fcntl(fd, F_SETFL, O_NONBLOCK);
|
||||||
return make_shared<Client>(fd);
|
return Client { fd };
|
||||||
}
|
}
|
||||||
|
|
||||||
LocalServer::~LocalServer()
|
LocalServer::~LocalServer()
|
||||||
@ -56,6 +56,11 @@ namespace os
|
|||||||
close(m_fd);
|
close(m_fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LocalServer::Client::Client(Client&& other) : m_fd(other.m_fd)
|
||||||
|
{
|
||||||
|
other.m_fd = -1;
|
||||||
|
}
|
||||||
|
|
||||||
LocalServer::Client::Client(int fd) : m_fd(fd)
|
LocalServer::Client::Client(int fd) : m_fd(fd)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -83,7 +83,7 @@ Result<int> luna_main(int argc, char** argv)
|
|||||||
TRY(make<Window>(ui::Rect { 100, 100, 300, 200 }, ui::RED, "Settings"_sv));
|
TRY(make<Window>(ui::Rect { 100, 100, 300, 200 }, ui::RED, "Settings"_sv));
|
||||||
TRY(make<Window>(ui::Rect { 600, 130, 350, 250 }, ui::CYAN, "File Manager"_sv));
|
TRY(make<Window>(ui::Rect { 600, 130, 350, 250 }, ui::CYAN, "File Manager"_sv));
|
||||||
|
|
||||||
Vector<SharedPtr<os::LocalServer::Client>> clients;
|
Vector<os::LocalServer::Client> clients;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
@ -125,7 +125,7 @@ Result<int> luna_main(int argc, char** argv)
|
|||||||
{
|
{
|
||||||
auto client = TRY(server->accept());
|
auto client = TRY(server->accept());
|
||||||
os::println("wind: New client connected!");
|
os::println("wind: New client connected!");
|
||||||
TRY(clients.try_append(client));
|
TRY(clients.try_append(move(client)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user