all repos — openbox @ 9676757a08b3e2e508c47f7795326bda8e54dc53

openbox fork - make it a bit more like ryudo

openbox/prompt.h (raw)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*-

   prompt.h for the Openbox window manager
   Copyright (c) 2008        Dana Jansens

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2 of the License, or
   (at your option) any later version.

   This program 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 General Public License for more details.

   See the COPYING file for a copy of the GNU General Public License.
*/

#ifndef ob__prompt_h
#define ob__prompt_h

#include "window.h"
#include "geom.h"
#include "render/render.h"
#include <glib.h>
#include <X11/Xlib.h>

typedef struct _ObPrompt       ObPrompt;
typedef struct _ObPromptElement ObPromptElement;
typedef struct _ObPromptAnswer ObPromptAnswer;

typedef void (*ObPromptCallback)(ObPrompt *p, gint result, gpointer data);

struct _ObPromptElement {
    gchar *text;
    Window window;

    gint x, y, width, height;
    gboolean pressed;
    gint result;
};

struct _ObPrompt
{
    ObInternalWindow super;
    gint ref;

    guint event_mask;

    /* keep a copy of this because we re-render things that may need it
       (i.e. the buttons) */
    RrAppearance *a_bg;

    gboolean mapped;
    gint width, height;
    gint msg_wbound;

    ObPromptElement msg;

    /* one for each answer */
    ObPromptElement *button;
    gint n_buttons;

    /* points to the button with the focus */
    ObPromptElement *focus;
    /* the default button to have selected */
    gint default_result;
    /* the cancel result if the dialog is closed */
    gint cancel_result;

    ObPromptCallback func;
    gpointer data;
};

struct _ObPromptAnswer {
    const gchar *text;
    gint result;
};

void prompt_startup(gboolean reconfig);
void prompt_shutdown(gboolean reconfig);

/*! Create a new prompt
  @param answers A number of ObPromptAnswers which define the buttons which
                 will appear in the dialog from left to right, and the result
                 returned when they are selected.
  @param n_answers The number of answers
  @param default_result The result for the answer button selected by default
  @param cancel_result The result that is given if the dialog is closed instead
         of having a button presssed
  @param func The callback function which is called when the dialog is closed
         or a button is pressed
  @param data User defined data which will be passed to the callback
*/
ObPrompt* prompt_new(const gchar *msg,
                     const ObPromptAnswer *answers, gint n_answers,
                     gint default_result, gint cancel_result,
                     ObPromptCallback func, gpointer data);
void prompt_ref(ObPrompt *self);
void prompt_unref(ObPrompt *self);

/*! Show the prompt.  It will be centered within the given area rectangle */
void prompt_show(ObPrompt *self, struct _ObClient *parent, gboolean modal);
void prompt_hide(ObPrompt *self);

gboolean prompt_key_event(ObPrompt *self, XEvent *e);
gboolean prompt_mouse_event(ObPrompt *self, XEvent *e);
void prompt_cancel(ObPrompt *self);

#endif