mirror of
https://github.com/WayfireWM/wf-osk.git
synced 2025-04-05 04:46:45 +02:00
style: fixed style issues
This commit is contained in:
parent
5d26011ccc
commit
4592b3208b
@ -15,8 +15,8 @@ wayland_scanner_client = generator(
|
||||
)
|
||||
|
||||
client_protocols = [
|
||||
[wl_protocol_dir, 'stable/xdg-shell/xdg-shell.xml'],
|
||||
['wayfire-shell.xml'],
|
||||
[wl_protocol_dir, 'stable/xdg-shell/xdg-shell.xml'],
|
||||
['wayfire-shell.xml'],
|
||||
['wlr-layer-shell-unstable-v1.xml'],
|
||||
['virtual-keyboard-unstable-v1.xml']
|
||||
]
|
||||
|
40
src/main.cpp
40
src/main.cpp
@ -21,7 +21,7 @@ namespace wf
|
||||
int default_y = 100;
|
||||
int default_width = 800;
|
||||
int default_height = 400;
|
||||
std::string anchor;
|
||||
std::string anchor;
|
||||
|
||||
KeyButton::KeyButton(Key key, int width, int height)
|
||||
{
|
||||
@ -178,26 +178,30 @@ namespace wf
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
bool show_help = false;
|
||||
bool show_help = false;
|
||||
|
||||
auto cli = clara::detail::Help(show_help) |
|
||||
clara::detail::Opt(wf::osk::default_x, "int")["-x"]("x position (wf-shell only)") |
|
||||
clara::detail::Opt(wf::osk::default_y, "int")["-y"]("y position (wf-shell only)") |
|
||||
clara::detail::Opt(wf::osk::default_width, "int")["-w"]["--width"]("keyboard width") |
|
||||
clara::detail::Opt(wf::osk::default_height, "int")["-h"]["--height"]("keyboard height") |
|
||||
clara::detail::Opt(wf::osk::anchor, "top|left|bottom|right")["-a"]["--anchor"]
|
||||
("where the keyboard should anchor in the screen");
|
||||
auto cli = clara::detail::Help(show_help) |
|
||||
clara::detail::Opt(wf::osk::default_x, "int")["-x"]
|
||||
("x position (wf-shell only)") |
|
||||
clara::detail::Opt(wf::osk::default_y, "int")["-y"]
|
||||
("y position (wf-shell only)") |
|
||||
clara::detail::Opt(wf::osk::default_width, "int")["-w"]["--width"]
|
||||
("keyboard width") |
|
||||
clara::detail::Opt(wf::osk::default_height, "int")["-h"]["--height"]
|
||||
("keyboard height") |
|
||||
clara::detail::Opt(wf::osk::anchor, "top|left|bottom|right")["-a"]
|
||||
["--anchor"]("where the keyboard should anchor in the screen");
|
||||
|
||||
auto res = cli.parse(clara::detail::Args(argc, argv));
|
||||
if (!res) {
|
||||
std::cerr << "Error: " << res.errorMessage() << std::endl;
|
||||
return 1;
|
||||
}
|
||||
auto res = cli.parse(clara::detail::Args(argc, argv));
|
||||
if (!res) {
|
||||
std::cerr << "Error: " << res.errorMessage() << std::endl;
|
||||
return 1;
|
||||
}
|
||||
|
||||
if (show_help) {
|
||||
std::cout << cli << std::endl;
|
||||
return 0;
|
||||
}
|
||||
if (show_help) {
|
||||
std::cout << cli << std::endl;
|
||||
return 0;
|
||||
}
|
||||
|
||||
auto app = Gtk::Application::create();
|
||||
wf::osk::Keyboard::create();
|
||||
|
@ -821,7 +821,7 @@ namespace detail {
|
||||
template<typename T>
|
||||
auto operator|( T const &other ) const -> Parser;
|
||||
|
||||
template<typename T>
|
||||
template<typename T>
|
||||
auto operator+( T const &other ) const -> Parser;
|
||||
};
|
||||
|
||||
|
@ -51,21 +51,23 @@ namespace wf
|
||||
®istry_remove_object
|
||||
};
|
||||
|
||||
static void layer_shell_handle_configure(void *data, struct zwlr_layer_surface_v1 *zwlr_layer_surface,
|
||||
uint32_t serial, uint32_t width, uint32_t height)
|
||||
static void layer_shell_handle_configure(void *data,
|
||||
struct zwlr_layer_surface_v1 *zwlr_layer_surface, uint32_t serial,
|
||||
uint32_t width, uint32_t height)
|
||||
{
|
||||
zwlr_layer_surface_v1_ack_configure(zwlr_layer_surface, serial);
|
||||
zwlr_layer_surface_v1_ack_configure(zwlr_layer_surface, serial);
|
||||
}
|
||||
|
||||
static void layer_shell_handle_close(void *data, struct zwlr_layer_surface_v1 *surface)
|
||||
static void layer_shell_handle_close(void *data,
|
||||
struct zwlr_layer_surface_v1 *surface)
|
||||
{
|
||||
zwlr_layer_surface_v1_destroy(surface);
|
||||
zwlr_layer_surface_v1_destroy(surface);
|
||||
}
|
||||
|
||||
static struct zwlr_layer_surface_v1_listener layer_surface_listener =
|
||||
{
|
||||
&layer_shell_handle_configure,
|
||||
&layer_shell_handle_close
|
||||
&layer_shell_handle_configure,
|
||||
&layer_shell_handle_close
|
||||
};
|
||||
|
||||
WaylandDisplay::WaylandDisplay()
|
||||
@ -99,65 +101,67 @@ namespace wf
|
||||
return instance;
|
||||
}
|
||||
|
||||
uint32_t WaylandWindow::checkAnchorForWayfireShell(int width, int height, std::string anchor)
|
||||
uint32_t WaylandWindow::check_anchor_for_wayfire_shell(int width,
|
||||
int height, std::string anchor)
|
||||
{
|
||||
if (anchor.empty())
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
if (anchor.empty())
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
std::transform(anchor.begin(), anchor.end(), anchor.begin(), ::tolower);
|
||||
std::transform(anchor.begin(), anchor.end(), anchor.begin(), ::tolower);
|
||||
|
||||
uint32_t parsed_anchor = 0;
|
||||
if (anchor.compare("top") == 0)
|
||||
{
|
||||
parsed_anchor = ZWF_WM_SURFACE_V1_ANCHOR_EDGE_TOP;
|
||||
} else if (anchor.compare("bottom") == 0)
|
||||
{
|
||||
parsed_anchor = ZWF_WM_SURFACE_V1_ANCHOR_EDGE_BOTTOM;
|
||||
} else if (anchor.compare("left") == 0)
|
||||
{
|
||||
parsed_anchor = ZWF_WM_SURFACE_V1_ANCHOR_EDGE_LEFT;
|
||||
} else if (anchor.compare("right") == 0)
|
||||
{
|
||||
parsed_anchor = ZWF_WM_SURFACE_V1_ANCHOR_EDGE_RIGHT;
|
||||
}
|
||||
uint32_t parsed_anchor = 0;
|
||||
if (anchor.compare("top") == 0)
|
||||
{
|
||||
parsed_anchor = ZWF_WM_SURFACE_V1_ANCHOR_EDGE_TOP;
|
||||
} else if (anchor.compare("bottom") == 0)
|
||||
{
|
||||
parsed_anchor = ZWF_WM_SURFACE_V1_ANCHOR_EDGE_BOTTOM;
|
||||
} else if (anchor.compare("left") == 0)
|
||||
{
|
||||
parsed_anchor = ZWF_WM_SURFACE_V1_ANCHOR_EDGE_LEFT;
|
||||
} else if (anchor.compare("right") == 0)
|
||||
{
|
||||
parsed_anchor = ZWF_WM_SURFACE_V1_ANCHOR_EDGE_RIGHT;
|
||||
}
|
||||
|
||||
return parsed_anchor;
|
||||
return parsed_anchor;
|
||||
}
|
||||
|
||||
uint32_t WaylandWindow::checkAnchorForLayerShell(int width, int height, std::string anchor)
|
||||
uint32_t WaylandWindow::check_anchor_for_layer_shell(int width, int height,
|
||||
std::string anchor)
|
||||
{
|
||||
if (anchor.empty())
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
if (anchor.empty())
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
std::transform(anchor.begin(), anchor.end(), anchor.begin(), ::tolower);
|
||||
std::transform(anchor.begin(), anchor.end(), anchor.begin(), ::tolower);
|
||||
|
||||
uint32_t parsed_anchor = 0;
|
||||
if (anchor.compare("top") == 0)
|
||||
{
|
||||
parsed_anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP;
|
||||
} else if (anchor.compare("bottom") == 0)
|
||||
{
|
||||
parsed_anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM;
|
||||
} else if (anchor.compare("left") == 0)
|
||||
{
|
||||
parsed_anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_LEFT;
|
||||
} else if (anchor.compare("right") == 0)
|
||||
{
|
||||
parsed_anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_RIGHT;
|
||||
}
|
||||
uint32_t parsed_anchor = 0;
|
||||
if (anchor.compare("top") == 0)
|
||||
{
|
||||
parsed_anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP;
|
||||
} else if (anchor.compare("bottom") == 0)
|
||||
{
|
||||
parsed_anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM;
|
||||
} else if (anchor.compare("left") == 0)
|
||||
{
|
||||
parsed_anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_LEFT;
|
||||
} else if (anchor.compare("right") == 0)
|
||||
{
|
||||
parsed_anchor = ZWLR_LAYER_SURFACE_V1_ANCHOR_RIGHT;
|
||||
}
|
||||
|
||||
return parsed_anchor;
|
||||
return parsed_anchor;
|
||||
}
|
||||
|
||||
void WaylandWindow::initWayfireShell(WaylandDisplay display, int x, int y, int width,
|
||||
int height, std::string anchor)
|
||||
void WaylandWindow::init_wayfire_shell(WaylandDisplay display, int x, int y,
|
||||
int width, int height, std::string anchor)
|
||||
{
|
||||
this->show_all();
|
||||
auto gdk_window = this->get_window()->gobj();
|
||||
this->show_all();
|
||||
auto gdk_window = this->get_window()->gobj();
|
||||
auto surface = gdk_wayland_window_get_wl_surface(gdk_window);
|
||||
|
||||
if (!surface)
|
||||
@ -166,24 +170,27 @@ namespace wf
|
||||
std::exit(-1);
|
||||
}
|
||||
|
||||
wf_surface = zwf_shell_manager_v1_get_wm_surface(display.wf_manager, surface,
|
||||
ZWF_WM_SURFACE_V1_ROLE_DESKTOP_WIDGET, nullptr);
|
||||
zwf_wm_surface_v1_set_keyboard_mode(wf_surface, ZWF_WM_SURFACE_V1_KEYBOARD_FOCUS_MODE_NO_FOCUS);
|
||||
wf_surface = zwf_shell_manager_v1_get_wm_surface(display.wf_manager,
|
||||
surface, ZWF_WM_SURFACE_V1_ROLE_DESKTOP_WIDGET, nullptr);
|
||||
zwf_wm_surface_v1_set_keyboard_mode(wf_surface,
|
||||
ZWF_WM_SURFACE_V1_KEYBOARD_FOCUS_MODE_NO_FOCUS);
|
||||
|
||||
uint32_t parsed_anchor = checkAnchorForWayfireShell(width, height, anchor);
|
||||
zwf_wm_surface_v1_set_anchor(wf_surface, parsed_anchor);
|
||||
zwf_wm_surface_v1_configure(wf_surface, x, y);
|
||||
uint32_t parsed_anchor = check_anchor_for_wayfire_shell(width,
|
||||
height, anchor);
|
||||
zwf_wm_surface_v1_set_anchor(wf_surface, parsed_anchor);
|
||||
zwf_wm_surface_v1_configure(wf_surface, x, y);
|
||||
|
||||
}
|
||||
|
||||
void WaylandWindow::initLayerShell(WaylandDisplay display, int width, int height, std::string anchor)
|
||||
void WaylandWindow::init_layer_shell(WaylandDisplay display, int width,
|
||||
int height, std::string anchor)
|
||||
{
|
||||
auto gtk_window = this->gobj();
|
||||
auto gtk_widget = GTK_WIDGET(gtk_window);
|
||||
gtk_widget_realize(gtk_widget);
|
||||
|
||||
auto gdk_window = this->get_window()->gobj();
|
||||
gdk_wayland_window_set_use_custom_surface(gdk_window);
|
||||
gdk_wayland_window_set_use_custom_surface(gdk_window);
|
||||
auto surface = gdk_wayland_window_get_wl_surface(gdk_window);
|
||||
|
||||
if (!surface)
|
||||
@ -192,31 +199,34 @@ namespace wf
|
||||
std::exit(-1);
|
||||
}
|
||||
|
||||
uint32_t layer = ZWLR_LAYER_SHELL_V1_LAYER_TOP;
|
||||
layer_surface = zwlr_layer_shell_v1_get_layer_surface(display.layer_shell,
|
||||
surface, NULL, layer, "wf-osk");
|
||||
uint32_t layer = ZWLR_LAYER_SHELL_V1_LAYER_TOP;
|
||||
layer_surface = zwlr_layer_shell_v1_get_layer_surface(
|
||||
display.layer_shell, surface, NULL, layer, "wf-osk");
|
||||
if (!layer_surface)
|
||||
{
|
||||
std::cerr << "Error: could not create layer surface" << std::endl;
|
||||
std::exit(-1);
|
||||
std::cerr << "Error: could not create layer surface" << std::endl;
|
||||
std::exit(-1);
|
||||
}
|
||||
|
||||
zwlr_layer_surface_v1_add_listener(layer_surface, &layer_surface_listener, nullptr);
|
||||
zwlr_layer_surface_v1_add_listener(layer_surface,
|
||||
&layer_surface_listener, nullptr);
|
||||
zwlr_layer_surface_v1_set_keyboard_interactivity(layer_surface, 0);
|
||||
zwlr_layer_surface_v1_set_size(layer_surface, width, height);
|
||||
|
||||
uint32_t parsed_anchor = checkAnchorForLayerShell(width, height, anchor);
|
||||
uint32_t parsed_anchor = check_anchor_for_layer_shell(width,
|
||||
height, anchor);
|
||||
zwlr_layer_surface_v1_set_anchor(layer_surface, parsed_anchor);
|
||||
|
||||
wl_surface_commit(surface);
|
||||
auto gdk_display = gdk_display_get_default();
|
||||
auto wl_display = gdk_wayland_display_get_wl_display(gdk_display);
|
||||
wl_display_roundtrip(wl_display);
|
||||
wl_display_roundtrip(wl_display);
|
||||
|
||||
this->show_all();
|
||||
}
|
||||
|
||||
WaylandWindow::WaylandWindow(int x, int y, int width, int height, std::string anchor)
|
||||
WaylandWindow::WaylandWindow(int x, int y, int width, int height,
|
||||
std::string anchor)
|
||||
: Gtk::Window()
|
||||
{
|
||||
auto display = WaylandDisplay::get();
|
||||
@ -228,10 +238,10 @@ namespace wf
|
||||
|
||||
if (display.wf_manager)
|
||||
{
|
||||
initWayfireShell(display, x, y, width, height, anchor);
|
||||
init_wayfire_shell(display, x, y, width, height, anchor);
|
||||
} else if (display.layer_shell)
|
||||
{
|
||||
initLayerShell(display, width, height, anchor);
|
||||
init_layer_shell(display, width, height, anchor);
|
||||
} else {
|
||||
std::cerr << "Error: cannot find any supported shell protocol" << std::endl;
|
||||
std::exit(-1);
|
||||
|
@ -22,14 +22,18 @@ namespace wf
|
||||
|
||||
class WaylandWindow : public Gtk::Window
|
||||
{
|
||||
zwf_wm_surface_v1 *wf_surface;
|
||||
zwf_wm_surface_v1 *wf_surface;
|
||||
zwlr_layer_surface_v1 *layer_surface;
|
||||
|
||||
uint32_t checkAnchorForWayfireShell(int width, int height, std::string anchor);
|
||||
uint32_t checkAnchorForLayerShell(int width, int height, std::string anchor);
|
||||
uint32_t check_anchor_for_wayfire_shell(int width, int height,
|
||||
std::string anchor);
|
||||
uint32_t check_anchor_for_layer_shell(int width, int height,
|
||||
std::string anchor);
|
||||
|
||||
void initWayfireShell(WaylandDisplay display, int x, int y, int width, int height, std::string anchor);
|
||||
void initLayerShell(WaylandDisplay display, int width, int height, std::string anchor);
|
||||
void init_wayfire_shell(WaylandDisplay display, int x, int y,
|
||||
int width, int height, std::string anchor);
|
||||
void init_layer_shell(WaylandDisplay display, int width, int height,
|
||||
std::string anchor);
|
||||
|
||||
public:
|
||||
WaylandWindow(int x, int y, int width, int height, std::string anchor);
|
||||
|
Loading…
x
Reference in New Issue
Block a user