gimpprocview.c 10.4 KB
Newer Older
1 2
/* LIBGIMP - The GIMP Library
 * Copyright (C) 1995-1997 Peter Mattis and Spencer Kimball
Elliot Lee's avatar
Elliot Lee committed
3
 *
4
 * gimpprocview.c
Elliot Lee's avatar
Elliot Lee committed
5
 *
6
 * This library is free software: you can redistribute it and/or
7 8
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
9
 * version 3 of the License, or (at your option) any later version.
10 11
 *
 * This library is distributed in the hope that it will be useful,
Elliot Lee's avatar
Elliot Lee committed
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 14
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
Elliot Lee's avatar
Elliot Lee committed
15
 *
16
 * You should have received a copy of the GNU Lesser General Public
17 18
 * License along with this library.  If not, see
 * <http://www.gnu.org/licenses/>.
Elliot Lee's avatar
Elliot Lee committed
19 20
 */

21
/*
22 23 24 25 26
 * dbbrowser_utils.c
 * 0.08  26th sept 97  by Thomas NOEL <thomas@minet.net>
 *
 * 98/12/13  Sven Neumann <sven@gimp.org> : added help display
 */
Elliot Lee's avatar
Elliot Lee committed
27

Sven Neumann's avatar
Sven Neumann committed
28
#include "config.h"
29

Daniel Egger's avatar
Daniel Egger committed
30
#include <string.h>
31

32
#include <gegl.h>
33 34
#include <gtk/gtk.h>

35
#include "libgimpwidgets/gimpwidgets.h"
36

37 38 39
#include "gimp.h"

#include "gimpuitypes.h"
40
#include "gimpprocview.h"
41

42
#include "libgimp-intl.h"
Elliot Lee's avatar
Elliot Lee committed
43

44

45 46 47 48 49 50 51 52 53 54
/**
 * SECTION: gimpprocview
 * @title: GimpProcView
 * @short_description: A widget showing information about a PDB procedure.
 *
 * A widget showing information about a PDB procedure, mainly for the
 * procedure and plug-in browsers.
 **/


55
/*  local function prototypes  */
56

57 58 59 60 61
static GtkWidget * gimp_proc_view_create_params (const GimpParamDef *params,
                                                 gint                n_params,
                                                 GtkSizeGroup       *name_group,
                                                 GtkSizeGroup       *type_group,
                                                 GtkSizeGroup       *desc_group);
62

63

64 65
/*  public functions  */

66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85

/**
 * gimp_proc_view_new:
 * @name:
 * @menu_path:
 * @blurb:
 * @help:
 * @author:
 * @copyright:
 * @date:
 * @type:
 * @n_params:
 * @n_return_vals:
 * @params:
 * @return_vals:
 *
 * Return value: a new widget providing a view on a GIMP procedure
 *
 * Since: GIMP 2.4
 **/
86
GtkWidget *
87 88 89 90 91 92 93 94 95 96 97 98
gimp_proc_view_new (const gchar        *name,
                    const gchar        *menu_path,
                    const gchar        *blurb,
                    const gchar        *help,
                    const gchar        *author,
                    const gchar        *copyright,
                    const gchar        *date,
                    GimpPDBProcType     type,
                    gint                n_params,
                    gint                n_return_vals,
                    const GimpParamDef *params,
                    const GimpParamDef *return_vals)
Elliot Lee's avatar
Elliot Lee committed
99
{
100 101 102 103 104 105 106 107
  GtkWidget    *main_vbox;
  GtkWidget    *frame;
  GtkWidget    *vbox;
  GtkWidget    *table;
  GtkWidget    *label;
  GtkSizeGroup *name_group;
  GtkSizeGroup *type_group;
  GtkSizeGroup *desc_group;
108
  const gchar  *type_str;
109 110 111 112 113 114 115 116 117 118
  gint          row;

  if (blurb     && strlen (blurb) < 2)     blurb     = NULL;
  if (help      && strlen (help) < 2)      help      = NULL;
  if (author    && strlen (author) < 2)    author    = NULL;
  if (date      && strlen (date) < 2)      date      = NULL;
  if (copyright && strlen (copyright) < 2) copyright = NULL;

  if (blurb && help && ! strcmp (blurb, help))
    help = NULL;
119

120
  main_vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12);
121

122
  /* show the name */
123

124 125 126 127 128
  frame = gimp_frame_new (name);
  label = gtk_frame_get_label_widget (GTK_FRAME (frame));
  gtk_label_set_selectable (GTK_LABEL (label), TRUE);
  gtk_box_pack_start (GTK_BOX (main_vbox), frame, FALSE, FALSE, 0);
  gtk_widget_show (frame);
129

130
  vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 8);
131
  gtk_container_add (GTK_CONTAINER (frame), vbox);
132 133
  gtk_widget_show (vbox);

134 135 136 137 138
  if (! gimp_enum_get_value (GIMP_TYPE_PDB_PROC_TYPE, type,
                             NULL, NULL, &type_str, NULL))
    type_str = "UNKNOWN";

  label = gtk_label_new (type_str);
139 140 141 142 143
  gimp_label_set_attributes (GTK_LABEL (label),
                             PANGO_ATTR_STYLE, PANGO_STYLE_ITALIC,
                             -1);
  gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
  gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
144
  gtk_widget_show (label);
Elliot Lee's avatar
Elliot Lee committed
145

146
  if (menu_path)
147
    {
148
      label = gtk_label_new_with_mnemonic (menu_path);
Sven Neumann's avatar
Sven Neumann committed
149
      gtk_label_set_selectable (GTK_LABEL (label), TRUE);
150 151 152 153
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
      gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
      gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
      gtk_widget_show (label);
154
    }
Elliot Lee's avatar
Elliot Lee committed
155

156
  if (blurb)
Elliot Lee's avatar
Elliot Lee committed
157
    {
158
      label = gtk_label_new (blurb);
159
      gtk_label_set_selectable (GTK_LABEL (label), TRUE);
160
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
161 162
      gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
      gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
163
      gtk_widget_show (label);
Elliot Lee's avatar
Elliot Lee committed
164
    }
165

166 167 168 169 170 171
  name_group = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);
  type_group = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);
  desc_group = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);

  /* in parameters */
  if (n_params)
172
    {
173 174 175 176 177 178 179 180
      frame = gimp_frame_new (_("Parameters"));
      gtk_box_pack_start (GTK_BOX (main_vbox), frame, FALSE, FALSE, 0);
      gtk_widget_show (frame);

      table = gimp_proc_view_create_params (params, n_params,
                                            name_group, type_group, desc_group);
      gtk_container_add (GTK_CONTAINER (frame), table);
      gtk_widget_show (table);
181
    }
Elliot Lee's avatar
Elliot Lee committed
182 183

  /* out parameters */
184
  if (n_return_vals)
Elliot Lee's avatar
Elliot Lee committed
185
    {
186 187 188 189 190 191 192 193
      frame = gimp_frame_new (_("Return Values"));
      gtk_box_pack_start (GTK_BOX (main_vbox), frame, FALSE, FALSE, 0);
      gtk_widget_show (frame);

      table = gimp_proc_view_create_params (return_vals, n_return_vals,
                                            name_group, type_group, desc_group);
      gtk_container_add (GTK_CONTAINER (frame), table);
      gtk_widget_show (table);
Elliot Lee's avatar
Elliot Lee committed
194 195
    }

196 197 198
  if (! help && ! author && ! date && ! copyright)
    return main_vbox;

199 200 201 202
  frame = gimp_frame_new (_("Additional Information"));
  gtk_box_pack_start (GTK_BOX (main_vbox), frame, FALSE, FALSE, 0);
  gtk_widget_show (frame);

203
  vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 8);
204 205
  gtk_container_add (GTK_CONTAINER (frame), vbox);
  gtk_widget_show (vbox);
Elliot Lee's avatar
Elliot Lee committed
206

Sven Neumann's avatar
Sven Neumann committed
207
  /* show the help */
208
  if (help)
Sven Neumann's avatar
Sven Neumann committed
209
    {
210
      label = gtk_label_new (help);
211
      gtk_label_set_selectable (GTK_LABEL (label), TRUE);
212
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
213
      gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
214 215
      gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
      gtk_widget_show (label);
Sven Neumann's avatar
Sven Neumann committed
216 217 218 219
    }

  /* show the author & the copyright */

220 221 222
  if (! author && ! date && ! copyright)
    return main_vbox;

Sven Neumann's avatar
Sven Neumann committed
223
  table = gtk_table_new (0, 2, FALSE);
224 225 226 227 228
  gtk_table_set_col_spacings (GTK_TABLE (table), 6);
  gtk_table_set_row_spacings (GTK_TABLE (table), 4);
  gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0);
  gtk_widget_show (table);

229
  row = 0;
230

231 232 233
  if (author)
    {
      label = gtk_label_new (author);
234
      gtk_label_set_selectable (GTK_LABEL (label), TRUE);
235 236
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
      gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
Elliot Lee's avatar
Elliot Lee committed
237

238 239 240 241
      gimp_table_attach_aligned (GTK_TABLE (table), 0, row++,
                                 _("Author:"), 0.0, 0.0,
                                 label, 3, FALSE);
    }
Elliot Lee's avatar
Elliot Lee committed
242

243 244 245
  if (date)
    {
      label = gtk_label_new (date);
246
      gtk_label_set_selectable (GTK_LABEL (label), TRUE);
247 248
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
      gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
Elliot Lee's avatar
Elliot Lee committed
249

250 251 252 253
      gimp_table_attach_aligned (GTK_TABLE (table), 0, row++,
                                 _("Date:"), 0.0, 0.0,
                                 label, 3, FALSE);
    }
Elliot Lee's avatar
Elliot Lee committed
254

255 256 257
  if (copyright)
    {
      label = gtk_label_new (copyright);
258
      gtk_label_set_selectable (GTK_LABEL (label), TRUE);
259 260 261 262 263 264 265
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
      gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);

      gimp_table_attach_aligned (GTK_TABLE (table), 0, row++,
                                 _("Copyright:"), 0.0, 0.0,
                                 label, 3, FALSE);
    }
Elliot Lee's avatar
Elliot Lee committed
266

267
  return main_vbox;
268 269
}

Sven Neumann's avatar
Sven Neumann committed
270

271
/*  private functions  */
Elliot Lee's avatar
Elliot Lee committed
272

273
static GtkWidget *
274 275 276 277 278
gimp_proc_view_create_params (const GimpParamDef *params,
                              gint                n_params,
                              GtkSizeGroup       *name_group,
                              GtkSizeGroup       *type_group,
                              GtkSizeGroup       *desc_group)
Elliot Lee's avatar
Elliot Lee committed
279
{
280 281
  GtkWidget *table;
  gint       i;
Elliot Lee's avatar
Elliot Lee committed
282

283 284 285
  table = gtk_table_new (n_params, 3, FALSE);
  gtk_table_set_col_spacings (GTK_TABLE (table), 6);
  gtk_table_set_row_spacings (GTK_TABLE (table), 4);
Elliot Lee's avatar
Elliot Lee committed
286

287
  for (i = 0; i < n_params; i++)
Elliot Lee's avatar
Elliot Lee committed
288
    {
289 290 291 292
      GtkWidget   *label;
      const gchar *type;
      gchar       *upper;

293 294 295 296 297 298 299
      /* name */
      label = gtk_label_new (params[i].name);
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
      gtk_size_group_add_widget (name_group, label);
      gtk_table_attach (GTK_TABLE (table), label,
                        0, 1, i, i + 1, GTK_FILL, GTK_FILL, 0, 0);
      gtk_widget_show (label);
300

301
      /* type */
302 303 304 305 306 307 308 309 310
      if (! gimp_enum_get_value (GIMP_TYPE_PDB_ARG_TYPE, params[i].type,
                                 NULL, &type, NULL, NULL))
        upper = g_strdup ("UNKNOWN");
      else
        upper = g_ascii_strup (type, -1);

      label = gtk_label_new (upper);
      g_free (upper);

311
      gimp_label_set_attributes (GTK_LABEL (label),
312 313
                                 PANGO_ATTR_FAMILY, "monospace",
                                 PANGO_ATTR_STYLE,  PANGO_STYLE_ITALIC,
314 315 316 317 318 319 320 321 322
                                 -1);
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
      gtk_size_group_add_widget (type_group, label);
      gtk_table_attach (GTK_TABLE (table), label,
                        1, 2, i, i + 1, GTK_FILL, GTK_FILL, 0, 0);
      gtk_widget_show (label);

      /* description */
      label = gtk_label_new (params[i].description);
323
      gtk_label_set_selectable (GTK_LABEL (label), TRUE);
324 325 326 327
      gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
      gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
      gtk_size_group_add_widget (desc_group, label);
      gtk_table_attach (GTK_TABLE (table), label,
328
                        2, 3, i, i + 1, GTK_SHRINK | GTK_FILL, GTK_FILL, 0, 0);
329
      gtk_widget_show (label);
Elliot Lee's avatar
Elliot Lee committed
330
    }
331 332

  return table;
Elliot Lee's avatar
Elliot Lee committed
333
}