2011-12-22 15:19:25 +00:00
|
|
|
/*
|
2020-06-11 12:27:20 +00:00
|
|
|
* \brief Client-side GUI session interface
|
2011-12-22 15:19:25 +00:00
|
|
|
* \author Norman Feske
|
|
|
|
* \date 2006-08-23
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 12:23:52 +00:00
|
|
|
* Copyright (C) 2006-2017 Genode Labs GmbH
|
2011-12-22 15:19:25 +00:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
2017-02-20 12:23:52 +00:00
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
2011-12-22 15:19:25 +00:00
|
|
|
*/
|
|
|
|
|
2020-06-11 12:27:20 +00:00
|
|
|
#ifndef _INCLUDE__GUI_SESSION__CLIENT_H_
|
|
|
|
#define _INCLUDE__GUI_SESSION__CLIENT_H_
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2020-06-11 12:27:20 +00:00
|
|
|
#include <gui_session/capability.h>
|
2011-12-22 15:19:25 +00:00
|
|
|
#include <base/rpc_client.h>
|
2017-01-30 10:35:12 +00:00
|
|
|
#include <base/attached_dataspace.h>
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2020-06-12 09:23:57 +00:00
|
|
|
namespace Gui { struct Session_client; }
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
|
2024-06-10 14:10:45 +00:00
|
|
|
class Gui::Session_client : public Rpc_client<Session>
|
2013-10-14 19:31:14 +00:00
|
|
|
{
|
2014-06-06 15:26:53 +00:00
|
|
|
private:
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2024-06-10 14:10:45 +00:00
|
|
|
Attached_dataspace _command_ds;
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2014-06-06 15:26:53 +00:00
|
|
|
Command_buffer &_command_buffer;
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2014-06-06 15:26:53 +00:00
|
|
|
public:
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2017-01-09 14:18:49 +00:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
2024-06-10 14:10:45 +00:00
|
|
|
Session_client(Region_map &rm, Session_capability session)
|
2014-06-06 15:26:53 +00:00
|
|
|
:
|
|
|
|
Rpc_client<Session>(session),
|
2017-01-09 14:18:49 +00:00
|
|
|
_command_ds(rm, command_dataspace()),
|
|
|
|
_command_buffer(*_command_ds.local_addr<Command_buffer>())
|
|
|
|
{ }
|
|
|
|
|
2014-06-06 15:26:53 +00:00
|
|
|
Framebuffer::Session_capability framebuffer_session() override {
|
|
|
|
return call<Rpc_framebuffer_session>(); }
|
2013-10-14 19:31:14 +00:00
|
|
|
|
2014-06-06 15:26:53 +00:00
|
|
|
Input::Session_capability input_session() override {
|
|
|
|
return call<Rpc_input_session>(); }
|
2013-10-14 19:31:14 +00:00
|
|
|
|
2024-06-10 14:03:40 +00:00
|
|
|
View_handle create_view() override {
|
|
|
|
return call<Rpc_create_view>(); }
|
|
|
|
|
|
|
|
View_handle create_child_view(View_handle parent) override {
|
|
|
|
return call<Rpc_create_child_view>(parent); }
|
2014-06-04 13:58:49 +00:00
|
|
|
|
2014-06-06 15:26:53 +00:00
|
|
|
void destroy_view(View_handle view) override {
|
|
|
|
call<Rpc_destroy_view>(view); }
|
|
|
|
|
|
|
|
View_handle view_handle(View_capability view,
|
|
|
|
View_handle handle = View_handle()) override
|
|
|
|
{
|
|
|
|
return call<Rpc_view_handle>(view, handle);
|
|
|
|
}
|
|
|
|
|
|
|
|
View_capability view_capability(View_handle handle) override {
|
|
|
|
return call<Rpc_view_capability>(handle); }
|
|
|
|
|
|
|
|
void release_view_handle(View_handle handle) override {
|
|
|
|
call<Rpc_release_view_handle>(handle); }
|
|
|
|
|
2024-06-10 14:10:45 +00:00
|
|
|
Dataspace_capability command_dataspace() override {
|
2014-06-06 15:26:53 +00:00
|
|
|
return call<Rpc_command_dataspace>(); }
|
|
|
|
|
|
|
|
void execute() override
|
|
|
|
{
|
|
|
|
call<Rpc_execute>();
|
|
|
|
_command_buffer.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
Framebuffer::Mode mode() override {
|
|
|
|
return call<Rpc_mode>(); }
|
|
|
|
|
2024-06-10 14:10:45 +00:00
|
|
|
void mode_sigh(Signal_context_capability sigh) override {
|
2014-07-09 08:34:02 +00:00
|
|
|
call<Rpc_mode_sigh>(sigh); }
|
|
|
|
|
2014-06-06 15:26:53 +00:00
|
|
|
void buffer(Framebuffer::Mode mode, bool alpha) override {
|
|
|
|
call<Rpc_buffer>(mode, alpha); }
|
|
|
|
|
2020-06-12 09:23:57 +00:00
|
|
|
void focus(Gui::Session_capability session) override {
|
2014-06-06 15:26:53 +00:00
|
|
|
call<Rpc_focus>(session); }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enqueue command to command buffer
|
|
|
|
*
|
|
|
|
* The submitted command is not executed immediately. To execute a
|
2015-03-20 16:50:41 +00:00
|
|
|
* batch of enqueued commands, the 'execute' method must be called.
|
2014-06-06 15:26:53 +00:00
|
|
|
* Only in the corner case when there is not space left in the command
|
|
|
|
* buffer, the 'execute' is called to make room in the buffer.
|
|
|
|
*/
|
2024-05-22 15:22:53 +00:00
|
|
|
template <typename CMD>
|
|
|
|
void enqueue(auto &&... args) { enqueue(Command( CMD { args... } )); }
|
2014-06-06 15:26:53 +00:00
|
|
|
|
|
|
|
void enqueue(Command const &command)
|
|
|
|
{
|
2016-05-11 16:21:47 +00:00
|
|
|
if (_command_buffer.full())
|
2014-06-06 15:26:53 +00:00
|
|
|
execute();
|
|
|
|
|
|
|
|
_command_buffer.enqueue(command);
|
|
|
|
}
|
2013-10-14 19:31:14 +00:00
|
|
|
};
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2020-06-11 12:27:20 +00:00
|
|
|
#endif /* _INCLUDE__GUI_SESSION__CLIENT_H_ */
|