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