mirror of
https://github.com/mpv-player/mpv
synced 2025-01-15 03:23:23 +00:00
a8a314b829
This commit adds a DND_INSERT_NEXT action option for drag-and-drop, allows for selecting it through the --drag-and-drop=insert-next option, and adds the necessary plumbing to make that happen when something is dragged onto the player.
45 lines
1.6 KiB
C
45 lines
1.6 KiB
C
/*
|
|
* This file is part of mpv.
|
|
*
|
|
* mpv is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* mpv is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with mpv. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#ifndef MP_INPUT_EVENT_H_
|
|
#define MP_INPUT_EVENT_H_
|
|
|
|
#include "misc/bstr.h"
|
|
|
|
struct input_ctx;
|
|
|
|
enum mp_dnd_action {
|
|
DND_REPLACE,
|
|
DND_APPEND,
|
|
DND_INSERT_NEXT,
|
|
};
|
|
|
|
// Enqueue files for playback after drag and drop
|
|
void mp_event_drop_files(struct input_ctx *ictx, int num_files, char **files,
|
|
enum mp_dnd_action action);
|
|
|
|
// Drop data in a specific format (identified by the mimetype).
|
|
// Returns <0 on error, ==0 if data was ok but empty, >0 on success.
|
|
int mp_event_drop_mime_data(struct input_ctx *ictx, const char *mime_type,
|
|
bstr data, enum mp_dnd_action action);
|
|
|
|
// Many drag & drop APIs support multiple mime types, and this function returns
|
|
// whether a type is preferred (higher integer score), or supported (scores
|
|
// below 0 indicate unsupported types).
|
|
int mp_event_get_mime_type_score(struct input_ctx *ictx, const char *mime_type);
|
|
|
|
#endif
|