summaryrefslogtreecommitdiffstats
path: root/pdb/groups/brush.pdb
diff options
context:
space:
mode:
Diffstat (limited to 'pdb/groups/brush.pdb')
-rw-r--r--pdb/groups/brush.pdb907
1 files changed, 907 insertions, 0 deletions
diff --git a/pdb/groups/brush.pdb b/pdb/groups/brush.pdb
new file mode 100644
index 0000000..b01cebd
--- /dev/null
+++ b/pdb/groups/brush.pdb
@@ -0,0 +1,907 @@
+# GIMP - The GNU Image Manipulation Program
+# Copyright (C) 1995 Spencer Kimball and Peter Mattis
+
+# 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 3 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.
+
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
+
+# "Perlized" from C source by Manish Singh <yosh@gimp.org>
+
+sub brush_new {
+ $blurb = "Creates a new brush.";
+ $help = "This procedure creates a new, uninitialized brush.";
+
+ &mitch_pdb_misc('2004', '2.2');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The requested name of the new brush' }
+ );
+
+ @outargs = (
+ { name => 'actual_name', type => 'string',
+ desc => 'The actual new brush name. The returned value must be freed with g_free()' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpData *data = gimp_data_factory_data_new (gimp->brush_factory,
+ context, name);
+
+ if (data)
+ actual_name = g_strdup (gimp_object_get_name (data));
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_duplicate {
+ $blurb = "Duplicates a brush.";
+ $help = "This procedure creates an identical brush by a different name.";
+
+ &mitch_pdb_misc('2004', '2.2');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'copy_name', type => 'string',
+ desc => "The name of the brush's copy. The returned value must be freed with g_free()" }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ {
+ GimpBrush *brush_copy = (GimpBrush *)
+ gimp_data_factory_data_duplicate (gimp->brush_factory,
+ GIMP_DATA (brush));
+
+ if (brush_copy)
+ copy_name = g_strdup (gimp_object_get_name (brush_copy));
+ else
+ success = FALSE;
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_is_generated {
+ $blurb = "Tests if brush is generated.";
+ $help = "Returns TRUE if this brush is parametric, FALSE for other types.";
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'generated', type => 'boolean',
+ desc => 'TRUE if the brush is generated' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ generated = GIMP_IS_BRUSH_GENERATED (brush);
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_is_editable {
+ $blurb = "Tests if brush can be edited.";
+ $help = "Returns TRUE if you have permission to change the brush.";
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'editable', type => 'boolean',
+ desc => 'TRUE if the brush can be edited' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ editable = gimp_data_is_writable (GIMP_DATA (brush));
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_rename {
+ $blurb = "Renames a brush.";
+ $help = "This procedure renames a brush.";
+
+ &mitch_pdb_misc('2004', '2.2');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' },
+ { name => 'new_name', type => 'string', non_empty => 1,
+ desc => 'The new name of the brush' }
+ );
+
+ @outargs = (
+ { name => 'actual_name', type => 'string',
+ desc => 'The actual new name of the brush. The returned value must be freed with g_free()' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_RENAME, error);
+
+ if (brush)
+ {
+ gimp_object_set_name (GIMP_OBJECT (brush), new_name);
+ actual_name = g_strdup (gimp_object_get_name (brush));
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_delete {
+ $blurb = "Deletes a brush.";
+ $help = "This procedure deletes a brush.";
+
+ &mitch_pdb_misc('2004', '2.2');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush && gimp_data_is_deletable (GIMP_DATA (brush)))
+ success = gimp_data_factory_data_delete (gimp->brush_factory,
+ GIMP_DATA (brush),
+ TRUE, error);
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_info {
+ $blurb = "Retrieves information about the specified brush.";
+
+ $help = <<'HELP';
+This procedure retrieves information about the specified brush:
+brush extents (width and height), color depth and mask depth.
+HELP
+
+ &mitch_pdb_misc('2004', '2.2');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'width', type => 'int32', void_ret => 1,
+ desc => 'The brush width' },
+ { name => 'height', type => 'int32',
+ desc => 'The brush height' },
+ { name => 'mask_bpp', type => 'int32',
+ desc => 'The brush mask bpp' },
+ { name => 'color_bpp', type => 'int32',
+ desc => 'The brush color bpp' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ {
+ GimpTempBuf *mask = gimp_brush_get_mask (brush);
+ GimpTempBuf *pixmap = gimp_brush_get_pixmap (brush);
+ const Babl *format;
+
+ format = gimp_babl_compat_u8_mask_format (
+ gimp_temp_buf_get_format (mask));
+
+ width = gimp_brush_get_width (brush);
+ height = gimp_brush_get_height (brush);
+ mask_bpp = babl_format_get_bytes_per_pixel (format);
+
+ if (pixmap)
+ {
+ format = gimp_babl_compat_u8_format (
+ gimp_temp_buf_get_format (pixmap));
+
+ color_bpp = babl_format_get_bytes_per_pixel (format);
+ }
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_pixels {
+ $blurb = 'Retrieves information about the specified brush.';
+
+ $help = <<'HELP';
+This procedure retrieves information about the specified brush. This
+includes the brush extents (width and height) and its pixels data.
+HELP
+
+ &mitch_pdb_misc('2004', '2.2');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'width', type => 'int32', void_ret => 1,
+ desc => 'The brush width' },
+ { name => 'height', type => 'int32',
+ desc => 'The brush height' },
+ { name => 'mask_bpp', type => 'int32',
+ desc => 'The brush mask bpp' },
+ { name => 'mask_bytes', type => 'int8array',
+ desc => 'The brush mask data',
+ array => { desc => 'Length of brush mask data' } },
+ { name => 'color_bpp', type => 'int32',
+ desc => 'The brush color bpp' },
+ { name => 'color_bytes', type => 'int8array',
+ desc => 'The brush color data',
+ array => { desc => 'Length of brush color data' } }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ {
+ GimpTempBuf *mask = gimp_brush_get_mask (brush);
+ GimpTempBuf *pixmap = gimp_brush_get_pixmap (brush);
+ const Babl *format;
+ gpointer data;
+
+ format = gimp_babl_compat_u8_mask_format (
+ gimp_temp_buf_get_format (mask));
+ data = gimp_temp_buf_lock (mask, format, GEGL_ACCESS_READ);
+
+ width = gimp_temp_buf_get_width (mask);
+ height = gimp_temp_buf_get_height (mask);
+ mask_bpp = babl_format_get_bytes_per_pixel (format);
+ num_mask_bytes = gimp_temp_buf_get_height (mask) *
+ gimp_temp_buf_get_width (mask) * mask_bpp;
+ mask_bytes = g_memdup (data, num_mask_bytes);
+
+ gimp_temp_buf_unlock (mask, data);
+
+ if (pixmap)
+ {
+ format = gimp_babl_compat_u8_format (
+ gimp_temp_buf_get_format (pixmap));
+ data = gimp_temp_buf_lock (pixmap, format, GEGL_ACCESS_READ);
+
+ color_bpp = babl_format_get_bytes_per_pixel (format);
+ num_color_bytes = gimp_temp_buf_get_height (pixmap) *
+ gimp_temp_buf_get_width (pixmap) *
+ color_bpp;
+ color_bytes = g_memdup (data, num_color_bytes);
+
+ gimp_temp_buf_unlock (pixmap, data);
+ }
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_spacing {
+ $blurb = 'Gets the brush spacing.';
+
+ $help = <<'HELP';
+This procedure returns the spacing setting for the specified brush.
+The return value is an integer between 0 and 1000 which represents
+percentage of the maximum of the width and height of the mask.
+HELP
+
+ &mitch_pdb_misc('2004', '2.2');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'spacing', type => '0 <= int32 <= 1000', void_ret => 1,
+ desc => 'The brush spacing' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ spacing = gimp_brush_get_spacing (brush);
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_shape {
+ $blurb = 'Gets the shape of a generated brush.';
+
+ $help = <<'HELP';
+This procedure gets the shape value for a generated brush. If
+called for any other type of brush, it does not succeed. The
+current possibilities are Circle (GIMP_BRUSH_GENERATED_CIRCLE),
+Square (GIMP_BRUSH_GENERATED_SQUARE), and Diamond
+(GIMP_BRUSH_GENERATED_DIAMOND). Other shapes are likely to be
+added in the future.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'shape', type => 'enum GimpBrushGeneratedShape',
+ desc => 'The brush shape' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ shape = GIMP_BRUSH_GENERATED (brush)->shape;
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_radius {
+ $blurb = 'Gets the radius of a generated brush.';
+
+ $help = <<'HELP';
+This procedure gets the radius value for a generated brush. If
+called for any other type of brush, it does not succeed.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'radius', type => 'float',
+ desc => 'The radius of the brush in pixels' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ radius = GIMP_BRUSH_GENERATED (brush)->radius;
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_spikes {
+ $blurb = 'Gets the number of spikes for a generated brush.';
+
+ $help = <<'HELP';
+This procedure gets the number of spikes for a generated brush.
+If called for any other type of brush, it does not succeed.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'spikes', type => 'int32',
+ desc => 'The number of spikes on the brush.' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ spikes = GIMP_BRUSH_GENERATED (brush)->spikes;
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_hardness {
+ $blurb = 'Gets the hardness of a generated brush.';
+
+ $help = <<'HELP';
+This procedure gets the hardness of a generated brush. The
+hardness of a brush is the amount its intensity fades at the
+outside edge, as a float between 0.0 and 1.0.
+If called for any other type of brush, the function does not
+succeed.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'hardness', type => 'float',
+ desc => 'The hardness of the brush.' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ hardness = GIMP_BRUSH_GENERATED (brush)->hardness;
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_aspect_ratio {
+ $blurb = 'Gets the aspect ratio of a generated brush.';
+
+ $help = <<'HELP';
+This procedure gets the aspect ratio of a generated brush.
+If called for any other type of brush, it does not succeed.
+The return value is a float between 0.0 and 1000.0.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'aspect_ratio', type => 'float',
+ desc => 'The aspect ratio of the brush.' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ aspect_ratio = GIMP_BRUSH_GENERATED (brush)->aspect_ratio;
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_get_angle {
+ $blurb = 'Gets the rotation angle of a generated brush.';
+
+ $help = <<'HELP';
+This procedure gets the angle of rotation for a generated brush.
+If called for any other type of brush, it does not succeed.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' }
+ );
+
+ @outargs = (
+ { name => 'angle', type => 'float',
+ desc => 'The rotation angle of the brush in degree.' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
+
+ if (brush)
+ angle = GIMP_BRUSH_GENERATED (brush)->angle;
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_set_spacing {
+ $blurb = 'Sets the brush spacing.';
+
+ $help = <<'HELP';
+This procedure modifies the spacing setting for the specified brush.
+The value should be a integer between 0 and 1000.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' },
+ { name => 'spacing', type => '0 <= int32 <= 1000',
+ desc => 'The brush spacing' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
+
+ if (brush)
+ gimp_brush_set_spacing (brush, spacing);
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_set_shape {
+ $blurb = 'Sets the shape of a generated brush.';
+
+ $help = <<'HELP';
+This procedure sets the shape value for a generated brush. If
+called for any other type of brush, it does not succeed. The
+current possibilities are Circle (GIMP_BRUSH_GENERATED_CIRCLE),
+Square (GIMP_BRUSH_GENERATED_SQUARE), and Diamond
+(GIMP_BRUSH_GENERATED_DIAMOND). Other shapes are likely to be
+added in the future.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' },
+ { name => 'shape_in', type => 'enum GimpBrushGeneratedShape',
+ desc => 'The brush shape' }
+ );
+
+ @outargs = (
+ { name => 'shape_out', type => 'enum GimpBrushGeneratedShape',
+ desc => 'The brush shape actually assigned' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
+
+ if (brush)
+ {
+ gimp_brush_generated_set_shape (GIMP_BRUSH_GENERATED (brush),
+ shape_in);
+ shape_out = GIMP_BRUSH_GENERATED (brush)->shape;
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_set_radius {
+ $blurb = 'Sets the radius of a generated brush.';
+
+ $help = <<'HELP';
+This procedure sets the radius for a generated brush. If
+called for any other type of brush, it does not succeed.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' },
+ { name => 'radius_in', type => 'float',
+ desc => 'The desired brush radius in pixel' }
+ );
+
+ @outargs = (
+ { name => 'radius_out', type => 'float',
+ desc => 'The brush radius actually assigned' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
+
+ if (brush)
+ {
+ gimp_brush_generated_set_radius (GIMP_BRUSH_GENERATED (brush),
+ radius_in);
+ radius_out = GIMP_BRUSH_GENERATED (brush)->radius;
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_set_spikes {
+ $blurb = 'Sets the number of spikes for a generated brush.';
+
+ $help = <<'HELP';
+This procedure sets the number of spikes for a generated brush. If
+called for any other type of brush, it does not succeed.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' },
+ { name => 'spikes_in', type => 'int32',
+ desc => 'The desired number of spikes' }
+ );
+
+ @outargs = (
+ { name => 'spikes_out', type => 'int32',
+ desc => 'The number of spikes actually assigned' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
+
+ if (brush)
+ {
+ gimp_brush_generated_set_spikes (GIMP_BRUSH_GENERATED (brush),
+ spikes_in);
+ spikes_out = GIMP_BRUSH_GENERATED (brush)->spikes;
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_set_hardness {
+ $blurb = 'Sets the hardness of a generated brush.';
+
+ $help = <<'HELP';
+This procedure sets the hardness for a generated brush. If
+called for any other type of brush, it does not succeed.
+The value should be a float between 0.0 and 1.0.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' },
+ { name => 'hardness_in', type => 'float',
+ desc => 'The desired brush hardness' }
+ );
+
+ @outargs = (
+ { name => 'hardness_out', type => 'float',
+ desc => 'The brush hardness actually assigned' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
+
+ if (brush)
+ {
+ gimp_brush_generated_set_hardness (GIMP_BRUSH_GENERATED (brush),
+ hardness_in);
+ hardness_out = GIMP_BRUSH_GENERATED (brush)->hardness;
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_set_aspect_ratio {
+ $blurb = 'Sets the aspect ratio of a generated brush.';
+
+ $help = <<'HELP';
+This procedure sets the aspect ratio for a generated brush.
+If called for any other type of brush, it does not succeed.
+The value should be a float between 0.0 and 1000.0.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' },
+ { name => 'aspect_ratio_in', type => 'float',
+ desc => 'The desired brush aspect ratio' }
+ );
+
+ @outargs = (
+ { name => 'aspect_ratio_out', type => 'float',
+ desc => 'The brush aspect ratio actually assigned' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
+
+ if (brush)
+ {
+ gimp_brush_generated_set_aspect_ratio (GIMP_BRUSH_GENERATED (brush),
+ aspect_ratio_in);
+ aspect_ratio_out = GIMP_BRUSH_GENERATED (brush)->aspect_ratio;
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+sub brush_set_angle {
+ $blurb = 'Sets the rotation angle of a generated brush.';
+
+ $help = <<'HELP';
+This procedure sets the rotation angle for a generated brush. If
+called for any other type of brush, it does not succeed.
+HELP
+
+ &bill_pdb_misc('2004', '2.4');
+
+ @inargs = (
+ { name => 'name', type => 'string', non_empty => 1,
+ desc => 'The brush name' },
+ { name => 'angle_in', type => 'float',
+ desc => 'The desired brush rotation angle in degree' }
+ );
+
+ @outargs = (
+ { name => 'angle_out', type => 'float',
+ desc => 'The brush rotation angle actually assigned' }
+ );
+
+ %invoke = (
+ code => <<'CODE'
+{
+ GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
+
+ if (brush)
+ {
+ gimp_brush_generated_set_angle (GIMP_BRUSH_GENERATED (brush),
+ angle_in);
+ angle_out = GIMP_BRUSH_GENERATED (brush)->angle;
+ }
+ else
+ success = FALSE;
+}
+CODE
+ );
+}
+
+
+@headers = qw(<string.h>
+ "gegl/gimp-babl-compat.h"
+ "core/gimp.h"
+ "core/gimpbrush.h"
+ "core/gimpbrushgenerated.h"
+ "core/gimpcontext.h"
+ "core/gimpdatafactory.h"
+ "core/gimptempbuf.h"
+ "gimppdb-utils.h");
+
+@procs = qw(brush_new
+ brush_duplicate
+ brush_is_generated
+ brush_rename
+ brush_delete
+ brush_is_editable
+ brush_get_info
+ brush_get_pixels
+ brush_get_spacing brush_set_spacing
+ brush_get_shape brush_set_shape
+ brush_get_radius brush_set_radius
+ brush_get_spikes brush_set_spikes
+ brush_get_hardness brush_set_hardness
+ brush_get_aspect_ratio brush_set_aspect_ratio
+ brush_get_angle brush_set_angle);
+
+%exports = (app => [@procs], lib => [@procs]);
+
+$desc = 'Brush';
+$doc_title = 'gimpbrush';
+$doc_short_desc = 'Functions operating on a single brush.';
+$doc_long_desc = 'Functions operating on a single brush.';
+
+1;