2016-11-06 08:34:27 -08:00
|
|
|
/*
|
|
|
|
Simple DirectMedia Layer
|
2022-01-03 09:40:00 -08:00
|
|
|
Copyright (C) 1997-2022 Sam Lantinga <slouken@libsdl.org>
|
2016-11-06 08:34:27 -08:00
|
|
|
|
|
|
|
This software is provided 'as-is', without any express or implied
|
|
|
|
warranty. In no event will the authors be held liable for any damages
|
|
|
|
arising from the use of this software.
|
|
|
|
|
|
|
|
Permission is granted to anyone to use this software for any purpose,
|
|
|
|
including commercial applications, and to alter it and redistribute it
|
|
|
|
freely, subject to the following restrictions:
|
|
|
|
|
|
|
|
1. The origin of this software must not be misrepresented; you must not
|
|
|
|
claim that you wrote the original software. If you use this software
|
|
|
|
in a product, an acknowledgment in the product documentation would be
|
|
|
|
appreciated but is not required.
|
|
|
|
2. Altered source versions must be plainly marked as such, and must not be
|
|
|
|
misrepresented as being the original software.
|
|
|
|
3. This notice may not be removed or altered from any source distribution.
|
|
|
|
*/
|
|
|
|
#include "../../SDL_internal.h"
|
|
|
|
|
|
|
|
#if SDL_VIDEO_DRIVER_WAYLAND
|
|
|
|
|
|
|
|
#include "SDL_waylanddatamanager.h"
|
|
|
|
#include "SDL_waylandevents_c.h"
|
2021-11-23 01:33:12 -08:00
|
|
|
#include "SDL_waylandclipboard.h"
|
2016-11-06 08:34:27 -08:00
|
|
|
|
|
|
|
int
|
|
|
|
Wayland_SetClipboardText(_THIS, const char *text)
|
|
|
|
{
|
|
|
|
SDL_VideoData *video_data = NULL;
|
|
|
|
SDL_WaylandDataDevice *data_device = NULL;
|
2021-04-08 11:16:21 -07:00
|
|
|
|
2016-11-06 08:34:27 -08:00
|
|
|
int status = 0;
|
2021-04-08 11:16:21 -07:00
|
|
|
|
2016-11-06 08:34:27 -08:00
|
|
|
if (_this == NULL || _this->driverdata == NULL) {
|
|
|
|
status = SDL_SetError("Video driver uninitialized");
|
|
|
|
} else {
|
|
|
|
video_data = _this->driverdata;
|
2021-04-08 11:14:46 -07:00
|
|
|
if (video_data->input != NULL && video_data->input->data_device != NULL) {
|
|
|
|
data_device = video_data->input->data_device;
|
|
|
|
if (text[0] != '\0') {
|
|
|
|
SDL_WaylandDataSource* source = Wayland_data_source_create(_this);
|
|
|
|
Wayland_data_source_add_data(source, TEXT_MIME, text,
|
2022-08-18 16:24:20 -07:00
|
|
|
SDL_strlen(text));
|
2021-04-08 11:14:46 -07:00
|
|
|
|
|
|
|
status = Wayland_data_device_set_selection(data_device, source);
|
|
|
|
if (status != 0) {
|
|
|
|
Wayland_data_source_destroy(source);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
status = Wayland_data_device_clear_selection(data_device);
|
2016-11-06 08:34:27 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
Add support for X11 primary selection (#6132)
X11 has a so-called primary selection, which you can use by marking text and middle-clicking elsewhere to copy the marked text.
There are 3 new API functions in `SDL_clipboard.h`, which work exactly like their clipboard equivalents.
## Test Instructions
* Run the tests (just a copy of the clipboard tests): `$ ./test/testautomation --filter Clipboard`
* Build and run this small application:
<details>
```C
#include <SDL.h>
#include <unistd.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void print_error(const char *where)
{
const char *errstr = SDL_GetError();
if (errstr == NULL || errstr[0] == '\0')
return;
fprintf(stderr, "SDL Error after '%s': %s\n", where, errstr);
SDL_ClearError();
}
int main()
{
char text_buf[256];
srand(time(NULL));
SDL_Init(SDL_INIT_VIDEO);
print_error("SDL_INIT()");
SDL_Window *window = SDL_CreateWindow("Primary Selection Test", SDL_WINDOWPOS_UNDEFINED,
SDL_WINDOWPOS_UNDEFINED, 400, 400, SDL_WINDOW_SHOWN);
print_error("SDL_CreateWindow()");
SDL_Renderer *renderer = SDL_CreateRenderer(window, -1, SDL_RENDERER_ACCELERATED);
print_error("SDL_CreateRenderer()");
bool quit = false;
unsigned int do_render = 0;
while (!quit) {
SDL_Event event;
while (SDL_PollEvent(&event)) {
print_error("SDL_PollEvent()");
switch (event.type) {
case SDL_QUIT: {
quit = true;
break;
} case SDL_KEYDOWN: {
switch (event.key.keysym.sym) {
case SDLK_ESCAPE:
case SDLK_q:
quit = true;
break;
case SDLK_c:
snprintf(text_buf, sizeof(text_buf), "foo%d", rand());
SDL_SetClipboardText(text_buf);
print_error("SDL_SetClipboardText()");
printf("clipboard: set_to=\"%s\"\n", text_buf);
break;
case SDLK_v: {
printf("clipboard: has=%d, ", SDL_HasClipboardText());
print_error("SDL_HasClipboardText()");
char *text = SDL_GetClipboardText();
print_error("SDL_GetClipboardText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} case SDLK_d:
snprintf(text_buf, sizeof(text_buf), "bar%d", rand());
SDL_SetPrimarySelectionText(text_buf);
print_error("SDL_SetPrimarySelectionText()");
printf("primselec: set_to=\"%s\"\n", text_buf);
break;
case SDLK_f: {
printf("primselec: has=%d, ", SDL_HasPrimarySelectionText());
print_error("SDL_HasPrimarySelectionText()");
char *text = SDL_GetPrimarySelectionText();
print_error("SDL_GetPrimarySelectionText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} default:
break;
}
break;
} default: {
break;
}}
}
// create less noise with WAYLAND_DEBUG=1
if (do_render == 0) {
SDL_RenderPresent(renderer);
print_error("SDL_RenderPresent()");
}
do_render += 1;
usleep(12000);
}
SDL_DestroyRenderer(renderer);
SDL_DestroyWindow(window);
SDL_Quit();
print_error("quit");
return 0;
}
```
</details>
* Use c,v,d,f to get and set the clipboard and primary selection.
* Mark text and middle-click also in other applications.
* For wayland under x:
* `$ mutter --wayland --no-x11 --nested`
* `$ XDG_SESSION_TYPE=wayland SDL_VIDEODRIVER=wayland ./<path_to_test_appl_binary>`
2022-09-14 09:28:35 -07:00
|
|
|
int
|
|
|
|
Wayland_SetPrimarySelectionText(_THIS, const char *text)
|
|
|
|
{
|
|
|
|
SDL_VideoData *video_data = NULL;
|
|
|
|
SDL_WaylandPrimarySelectionDevice *primary_selection_device = NULL;
|
|
|
|
|
|
|
|
int status = 0;
|
|
|
|
|
|
|
|
if (_this == NULL || _this->driverdata == NULL) {
|
|
|
|
status = SDL_SetError("Video driver uninitialized");
|
|
|
|
} else {
|
|
|
|
video_data = _this->driverdata;
|
|
|
|
if (video_data->input != NULL && video_data->input->primary_selection_device != NULL) {
|
|
|
|
primary_selection_device = video_data->input->primary_selection_device;
|
|
|
|
if (text[0] != '\0') {
|
|
|
|
SDL_WaylandPrimarySelectionSource* source = Wayland_primary_selection_source_create(_this);
|
|
|
|
Wayland_primary_selection_source_add_data(source, TEXT_MIME, text,
|
|
|
|
SDL_strlen(text));
|
|
|
|
|
|
|
|
status = Wayland_primary_selection_device_set_selection(primary_selection_device,
|
|
|
|
source);
|
|
|
|
if (status != 0) {
|
|
|
|
Wayland_primary_selection_source_destroy(source);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
status = Wayland_primary_selection_device_clear_selection(primary_selection_device);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
2016-11-06 08:34:27 -08:00
|
|
|
char *
|
|
|
|
Wayland_GetClipboardText(_THIS)
|
|
|
|
{
|
|
|
|
SDL_VideoData *video_data = NULL;
|
|
|
|
SDL_WaylandDataDevice *data_device = NULL;
|
|
|
|
|
|
|
|
char *text = NULL;
|
|
|
|
size_t length = 0;
|
2021-04-08 11:16:21 -07:00
|
|
|
|
2016-11-06 08:34:27 -08:00
|
|
|
if (_this == NULL || _this->driverdata == NULL) {
|
|
|
|
SDL_SetError("Video driver uninitialized");
|
|
|
|
} else {
|
|
|
|
video_data = _this->driverdata;
|
2021-04-08 11:14:46 -07:00
|
|
|
if (video_data->input != NULL && video_data->input->data_device != NULL) {
|
|
|
|
data_device = video_data->input->data_device;
|
Add support for X11 primary selection (#6132)
X11 has a so-called primary selection, which you can use by marking text and middle-clicking elsewhere to copy the marked text.
There are 3 new API functions in `SDL_clipboard.h`, which work exactly like their clipboard equivalents.
## Test Instructions
* Run the tests (just a copy of the clipboard tests): `$ ./test/testautomation --filter Clipboard`
* Build and run this small application:
<details>
```C
#include <SDL.h>
#include <unistd.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void print_error(const char *where)
{
const char *errstr = SDL_GetError();
if (errstr == NULL || errstr[0] == '\0')
return;
fprintf(stderr, "SDL Error after '%s': %s\n", where, errstr);
SDL_ClearError();
}
int main()
{
char text_buf[256];
srand(time(NULL));
SDL_Init(SDL_INIT_VIDEO);
print_error("SDL_INIT()");
SDL_Window *window = SDL_CreateWindow("Primary Selection Test", SDL_WINDOWPOS_UNDEFINED,
SDL_WINDOWPOS_UNDEFINED, 400, 400, SDL_WINDOW_SHOWN);
print_error("SDL_CreateWindow()");
SDL_Renderer *renderer = SDL_CreateRenderer(window, -1, SDL_RENDERER_ACCELERATED);
print_error("SDL_CreateRenderer()");
bool quit = false;
unsigned int do_render = 0;
while (!quit) {
SDL_Event event;
while (SDL_PollEvent(&event)) {
print_error("SDL_PollEvent()");
switch (event.type) {
case SDL_QUIT: {
quit = true;
break;
} case SDL_KEYDOWN: {
switch (event.key.keysym.sym) {
case SDLK_ESCAPE:
case SDLK_q:
quit = true;
break;
case SDLK_c:
snprintf(text_buf, sizeof(text_buf), "foo%d", rand());
SDL_SetClipboardText(text_buf);
print_error("SDL_SetClipboardText()");
printf("clipboard: set_to=\"%s\"\n", text_buf);
break;
case SDLK_v: {
printf("clipboard: has=%d, ", SDL_HasClipboardText());
print_error("SDL_HasClipboardText()");
char *text = SDL_GetClipboardText();
print_error("SDL_GetClipboardText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} case SDLK_d:
snprintf(text_buf, sizeof(text_buf), "bar%d", rand());
SDL_SetPrimarySelectionText(text_buf);
print_error("SDL_SetPrimarySelectionText()");
printf("primselec: set_to=\"%s\"\n", text_buf);
break;
case SDLK_f: {
printf("primselec: has=%d, ", SDL_HasPrimarySelectionText());
print_error("SDL_HasPrimarySelectionText()");
char *text = SDL_GetPrimarySelectionText();
print_error("SDL_GetPrimarySelectionText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} default:
break;
}
break;
} default: {
break;
}}
}
// create less noise with WAYLAND_DEBUG=1
if (do_render == 0) {
SDL_RenderPresent(renderer);
print_error("SDL_RenderPresent()");
}
do_render += 1;
usleep(12000);
}
SDL_DestroyRenderer(renderer);
SDL_DestroyWindow(window);
SDL_Quit();
print_error("quit");
return 0;
}
```
</details>
* Use c,v,d,f to get and set the clipboard and primary selection.
* Mark text and middle-click also in other applications.
* For wayland under x:
* `$ mutter --wayland --no-x11 --nested`
* `$ XDG_SESSION_TYPE=wayland SDL_VIDEODRIVER=wayland ./<path_to_test_appl_binary>`
2022-09-14 09:28:35 -07:00
|
|
|
/* Prefer own selection, if not canceled */
|
|
|
|
if (Wayland_data_source_has_mime(
|
|
|
|
data_device->selection_source, TEXT_MIME)) {
|
|
|
|
text = Wayland_data_source_get_data(data_device->selection_source,
|
2021-04-08 11:14:46 -07:00
|
|
|
&length, TEXT_MIME, SDL_TRUE);
|
Add support for X11 primary selection (#6132)
X11 has a so-called primary selection, which you can use by marking text and middle-clicking elsewhere to copy the marked text.
There are 3 new API functions in `SDL_clipboard.h`, which work exactly like their clipboard equivalents.
## Test Instructions
* Run the tests (just a copy of the clipboard tests): `$ ./test/testautomation --filter Clipboard`
* Build and run this small application:
<details>
```C
#include <SDL.h>
#include <unistd.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void print_error(const char *where)
{
const char *errstr = SDL_GetError();
if (errstr == NULL || errstr[0] == '\0')
return;
fprintf(stderr, "SDL Error after '%s': %s\n", where, errstr);
SDL_ClearError();
}
int main()
{
char text_buf[256];
srand(time(NULL));
SDL_Init(SDL_INIT_VIDEO);
print_error("SDL_INIT()");
SDL_Window *window = SDL_CreateWindow("Primary Selection Test", SDL_WINDOWPOS_UNDEFINED,
SDL_WINDOWPOS_UNDEFINED, 400, 400, SDL_WINDOW_SHOWN);
print_error("SDL_CreateWindow()");
SDL_Renderer *renderer = SDL_CreateRenderer(window, -1, SDL_RENDERER_ACCELERATED);
print_error("SDL_CreateRenderer()");
bool quit = false;
unsigned int do_render = 0;
while (!quit) {
SDL_Event event;
while (SDL_PollEvent(&event)) {
print_error("SDL_PollEvent()");
switch (event.type) {
case SDL_QUIT: {
quit = true;
break;
} case SDL_KEYDOWN: {
switch (event.key.keysym.sym) {
case SDLK_ESCAPE:
case SDLK_q:
quit = true;
break;
case SDLK_c:
snprintf(text_buf, sizeof(text_buf), "foo%d", rand());
SDL_SetClipboardText(text_buf);
print_error("SDL_SetClipboardText()");
printf("clipboard: set_to=\"%s\"\n", text_buf);
break;
case SDLK_v: {
printf("clipboard: has=%d, ", SDL_HasClipboardText());
print_error("SDL_HasClipboardText()");
char *text = SDL_GetClipboardText();
print_error("SDL_GetClipboardText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} case SDLK_d:
snprintf(text_buf, sizeof(text_buf), "bar%d", rand());
SDL_SetPrimarySelectionText(text_buf);
print_error("SDL_SetPrimarySelectionText()");
printf("primselec: set_to=\"%s\"\n", text_buf);
break;
case SDLK_f: {
printf("primselec: has=%d, ", SDL_HasPrimarySelectionText());
print_error("SDL_HasPrimarySelectionText()");
char *text = SDL_GetPrimarySelectionText();
print_error("SDL_GetPrimarySelectionText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} default:
break;
}
break;
} default: {
break;
}}
}
// create less noise with WAYLAND_DEBUG=1
if (do_render == 0) {
SDL_RenderPresent(renderer);
print_error("SDL_RenderPresent()");
}
do_render += 1;
usleep(12000);
}
SDL_DestroyRenderer(renderer);
SDL_DestroyWindow(window);
SDL_Quit();
print_error("quit");
return 0;
}
```
</details>
* Use c,v,d,f to get and set the clipboard and primary selection.
* Mark text and middle-click also in other applications.
* For wayland under x:
* `$ mutter --wayland --no-x11 --nested`
* `$ XDG_SESSION_TYPE=wayland SDL_VIDEODRIVER=wayland ./<path_to_test_appl_binary>`
2022-09-14 09:28:35 -07:00
|
|
|
} else if (Wayland_data_offer_has_mime(
|
|
|
|
data_device->selection_offer, TEXT_MIME)) {
|
|
|
|
text = Wayland_data_offer_receive(data_device->selection_offer,
|
|
|
|
&length, TEXT_MIME, SDL_TRUE);
|
2021-04-08 12:29:54 -07:00
|
|
|
}
|
Add support for X11 primary selection (#6132)
X11 has a so-called primary selection, which you can use by marking text and middle-clicking elsewhere to copy the marked text.
There are 3 new API functions in `SDL_clipboard.h`, which work exactly like their clipboard equivalents.
## Test Instructions
* Run the tests (just a copy of the clipboard tests): `$ ./test/testautomation --filter Clipboard`
* Build and run this small application:
<details>
```C
#include <SDL.h>
#include <unistd.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void print_error(const char *where)
{
const char *errstr = SDL_GetError();
if (errstr == NULL || errstr[0] == '\0')
return;
fprintf(stderr, "SDL Error after '%s': %s\n", where, errstr);
SDL_ClearError();
}
int main()
{
char text_buf[256];
srand(time(NULL));
SDL_Init(SDL_INIT_VIDEO);
print_error("SDL_INIT()");
SDL_Window *window = SDL_CreateWindow("Primary Selection Test", SDL_WINDOWPOS_UNDEFINED,
SDL_WINDOWPOS_UNDEFINED, 400, 400, SDL_WINDOW_SHOWN);
print_error("SDL_CreateWindow()");
SDL_Renderer *renderer = SDL_CreateRenderer(window, -1, SDL_RENDERER_ACCELERATED);
print_error("SDL_CreateRenderer()");
bool quit = false;
unsigned int do_render = 0;
while (!quit) {
SDL_Event event;
while (SDL_PollEvent(&event)) {
print_error("SDL_PollEvent()");
switch (event.type) {
case SDL_QUIT: {
quit = true;
break;
} case SDL_KEYDOWN: {
switch (event.key.keysym.sym) {
case SDLK_ESCAPE:
case SDLK_q:
quit = true;
break;
case SDLK_c:
snprintf(text_buf, sizeof(text_buf), "foo%d", rand());
SDL_SetClipboardText(text_buf);
print_error("SDL_SetClipboardText()");
printf("clipboard: set_to=\"%s\"\n", text_buf);
break;
case SDLK_v: {
printf("clipboard: has=%d, ", SDL_HasClipboardText());
print_error("SDL_HasClipboardText()");
char *text = SDL_GetClipboardText();
print_error("SDL_GetClipboardText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} case SDLK_d:
snprintf(text_buf, sizeof(text_buf), "bar%d", rand());
SDL_SetPrimarySelectionText(text_buf);
print_error("SDL_SetPrimarySelectionText()");
printf("primselec: set_to=\"%s\"\n", text_buf);
break;
case SDLK_f: {
printf("primselec: has=%d, ", SDL_HasPrimarySelectionText());
print_error("SDL_HasPrimarySelectionText()");
char *text = SDL_GetPrimarySelectionText();
print_error("SDL_GetPrimarySelectionText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} default:
break;
}
break;
} default: {
break;
}}
}
// create less noise with WAYLAND_DEBUG=1
if (do_render == 0) {
SDL_RenderPresent(renderer);
print_error("SDL_RenderPresent()");
}
do_render += 1;
usleep(12000);
}
SDL_DestroyRenderer(renderer);
SDL_DestroyWindow(window);
SDL_Quit();
print_error("quit");
return 0;
}
```
</details>
* Use c,v,d,f to get and set the clipboard and primary selection.
* Mark text and middle-click also in other applications.
* For wayland under x:
* `$ mutter --wayland --no-x11 --nested`
* `$ XDG_SESSION_TYPE=wayland SDL_VIDEODRIVER=wayland ./<path_to_test_appl_binary>`
2022-09-14 09:28:35 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (text == NULL) {
|
|
|
|
text = SDL_strdup("");
|
|
|
|
}
|
|
|
|
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
char *
|
|
|
|
Wayland_GetPrimarySelectionText(_THIS)
|
|
|
|
{
|
|
|
|
SDL_VideoData *video_data = NULL;
|
|
|
|
SDL_WaylandPrimarySelectionDevice *primary_selection_device = NULL;
|
|
|
|
|
|
|
|
char *text = NULL;
|
|
|
|
size_t length = 0;
|
|
|
|
|
|
|
|
if (_this == NULL || _this->driverdata == NULL) {
|
|
|
|
SDL_SetError("Video driver uninitialized");
|
|
|
|
} else {
|
|
|
|
video_data = _this->driverdata;
|
|
|
|
if (video_data->input != NULL && video_data->input->primary_selection_device != NULL) {
|
|
|
|
primary_selection_device = video_data->input->primary_selection_device;
|
|
|
|
/* Prefer own selection, if not canceled */
|
|
|
|
if (Wayland_primary_selection_source_has_mime(
|
|
|
|
primary_selection_device->selection_source, TEXT_MIME)) {
|
|
|
|
text = Wayland_primary_selection_source_get_data(primary_selection_device->selection_source,
|
|
|
|
&length, TEXT_MIME, SDL_TRUE);
|
|
|
|
} else if (Wayland_primary_selection_offer_has_mime(
|
|
|
|
primary_selection_device->selection_offer, TEXT_MIME)) {
|
|
|
|
text = Wayland_primary_selection_offer_receive(primary_selection_device->selection_offer,
|
|
|
|
&length, TEXT_MIME, SDL_TRUE);
|
2021-04-08 11:14:46 -07:00
|
|
|
}
|
2016-11-06 08:34:27 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (text == NULL) {
|
|
|
|
text = SDL_strdup("");
|
|
|
|
}
|
|
|
|
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|
|
|
|
SDL_bool
|
|
|
|
Wayland_HasClipboardText(_THIS)
|
|
|
|
{
|
|
|
|
SDL_VideoData *video_data = NULL;
|
|
|
|
SDL_WaylandDataDevice *data_device = NULL;
|
|
|
|
|
2021-04-08 11:16:21 -07:00
|
|
|
SDL_bool result = SDL_FALSE;
|
2016-11-06 08:34:27 -08:00
|
|
|
if (_this == NULL || _this->driverdata == NULL) {
|
|
|
|
SDL_SetError("Video driver uninitialized");
|
|
|
|
} else {
|
|
|
|
video_data = _this->driverdata;
|
2021-04-08 11:14:46 -07:00
|
|
|
if (video_data->input != NULL && video_data->input->data_device != NULL) {
|
|
|
|
data_device = video_data->input->data_device;
|
Add support for X11 primary selection (#6132)
X11 has a so-called primary selection, which you can use by marking text and middle-clicking elsewhere to copy the marked text.
There are 3 new API functions in `SDL_clipboard.h`, which work exactly like their clipboard equivalents.
## Test Instructions
* Run the tests (just a copy of the clipboard tests): `$ ./test/testautomation --filter Clipboard`
* Build and run this small application:
<details>
```C
#include <SDL.h>
#include <unistd.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void print_error(const char *where)
{
const char *errstr = SDL_GetError();
if (errstr == NULL || errstr[0] == '\0')
return;
fprintf(stderr, "SDL Error after '%s': %s\n", where, errstr);
SDL_ClearError();
}
int main()
{
char text_buf[256];
srand(time(NULL));
SDL_Init(SDL_INIT_VIDEO);
print_error("SDL_INIT()");
SDL_Window *window = SDL_CreateWindow("Primary Selection Test", SDL_WINDOWPOS_UNDEFINED,
SDL_WINDOWPOS_UNDEFINED, 400, 400, SDL_WINDOW_SHOWN);
print_error("SDL_CreateWindow()");
SDL_Renderer *renderer = SDL_CreateRenderer(window, -1, SDL_RENDERER_ACCELERATED);
print_error("SDL_CreateRenderer()");
bool quit = false;
unsigned int do_render = 0;
while (!quit) {
SDL_Event event;
while (SDL_PollEvent(&event)) {
print_error("SDL_PollEvent()");
switch (event.type) {
case SDL_QUIT: {
quit = true;
break;
} case SDL_KEYDOWN: {
switch (event.key.keysym.sym) {
case SDLK_ESCAPE:
case SDLK_q:
quit = true;
break;
case SDLK_c:
snprintf(text_buf, sizeof(text_buf), "foo%d", rand());
SDL_SetClipboardText(text_buf);
print_error("SDL_SetClipboardText()");
printf("clipboard: set_to=\"%s\"\n", text_buf);
break;
case SDLK_v: {
printf("clipboard: has=%d, ", SDL_HasClipboardText());
print_error("SDL_HasClipboardText()");
char *text = SDL_GetClipboardText();
print_error("SDL_GetClipboardText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} case SDLK_d:
snprintf(text_buf, sizeof(text_buf), "bar%d", rand());
SDL_SetPrimarySelectionText(text_buf);
print_error("SDL_SetPrimarySelectionText()");
printf("primselec: set_to=\"%s\"\n", text_buf);
break;
case SDLK_f: {
printf("primselec: has=%d, ", SDL_HasPrimarySelectionText());
print_error("SDL_HasPrimarySelectionText()");
char *text = SDL_GetPrimarySelectionText();
print_error("SDL_GetPrimarySelectionText()");
printf("text=\"%s\"\n", text);
SDL_free(text);
break;
} default:
break;
}
break;
} default: {
break;
}}
}
// create less noise with WAYLAND_DEBUG=1
if (do_render == 0) {
SDL_RenderPresent(renderer);
print_error("SDL_RenderPresent()");
}
do_render += 1;
usleep(12000);
}
SDL_DestroyRenderer(renderer);
SDL_DestroyWindow(window);
SDL_Quit();
print_error("quit");
return 0;
}
```
</details>
* Use c,v,d,f to get and set the clipboard and primary selection.
* Mark text and middle-click also in other applications.
* For wayland under x:
* `$ mutter --wayland --no-x11 --nested`
* `$ XDG_SESSION_TYPE=wayland SDL_VIDEODRIVER=wayland ./<path_to_test_appl_binary>`
2022-09-14 09:28:35 -07:00
|
|
|
result = result ||
|
|
|
|
Wayland_data_source_has_mime(data_device->selection_source, TEXT_MIME) ||
|
|
|
|
Wayland_data_offer_has_mime(data_device->selection_offer, TEXT_MIME);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
SDL_bool
|
|
|
|
Wayland_HasPrimarySelectionText(_THIS)
|
|
|
|
{
|
|
|
|
SDL_VideoData *video_data = NULL;
|
|
|
|
SDL_WaylandPrimarySelectionDevice *primary_selection_device = NULL;
|
|
|
|
|
|
|
|
SDL_bool result = SDL_FALSE;
|
|
|
|
if (_this == NULL || _this->driverdata == NULL) {
|
|
|
|
SDL_SetError("Video driver uninitialized");
|
|
|
|
} else {
|
|
|
|
video_data = _this->driverdata;
|
|
|
|
if (video_data->input != NULL && video_data->input->primary_selection_device != NULL) {
|
|
|
|
primary_selection_device = video_data->input->primary_selection_device;
|
|
|
|
result = result ||
|
|
|
|
Wayland_primary_selection_source_has_mime(
|
|
|
|
primary_selection_device->selection_source, TEXT_MIME) ||
|
|
|
|
Wayland_primary_selection_offer_has_mime(
|
|
|
|
primary_selection_device->selection_offer, TEXT_MIME);
|
2016-11-06 08:34:27 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* SDL_VIDEO_DRIVER_WAYLAND */
|
|
|
|
|
|
|
|
/* vi: set ts=4 sw=4 expandtab: */
|