diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:30:19 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:30:19 +0000 |
commit | 5c1676dfe6d2f3c837a5e074117b45613fd29a72 (patch) | |
tree | cbffb45144febf451e54061db2b21395faf94bfe /pdb/enumcode.pl | |
parent | Initial commit. (diff) | |
download | gimp-5c1676dfe6d2f3c837a5e074117b45613fd29a72.tar.xz gimp-5c1676dfe6d2f3c837a5e074117b45613fd29a72.zip |
Adding upstream version 2.10.34.upstream/2.10.34upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rwxr-xr-x | pdb/enumcode.pl | 240 |
1 files changed, 240 insertions, 0 deletions
diff --git a/pdb/enumcode.pl b/pdb/enumcode.pl new file mode 100755 index 0000000..8b8cfb8 --- /dev/null +++ b/pdb/enumcode.pl @@ -0,0 +1,240 @@ +#!/usr/bin/perl -w + +# GIMP - The GNU Image Manipulation Program +# Copyright (C) 1999-2003 Manish Singh <yosh@gimp.org> + +# 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 WITHOUTFILE 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/>. + +BEGIN { + $srcdir = $ENV{srcdir} || '.'; + $destdir = $ENV{destdir} || '.'; + $builddir = $ENV{builddir} || '.'; +} + +use lib $srcdir; + +require 'enums.pl'; +require 'util.pl'; + +*enums = \%Gimp::CodeGen::enums::enums; + +*write_file = \&Gimp::CodeGen::util::write_file; +*FILE_EXT = \$Gimp::CodeGen::util::FILE_EXT; + +my $enumfile = "$builddir/libgimp/gimpenums.h$FILE_EXT"; +open ENUMFILE, "> $enumfile" or die "Can't open $enumfile: $!\n"; + +print ENUMFILE <<'LGPL'; +/* LIBGIMP - The GIMP Library + * Copyright (C) 1995-2003 Peter Mattis and Spencer Kimball + * + * This library 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 3 of the License, or (at your option) any later version. + * + * This library 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 this library. If not, see + * <https://www.gnu.org/licenses/>. + */ + +/* NOTE: This file is autogenerated by enumcode.pl */ + +LGPL + +my $guard = "__GIMP_ENUMS_H__"; +print ENUMFILE <<HEADER; +#ifndef $guard +#define $guard + +G_BEGIN_DECLS + +HEADER + +foreach (sort keys %enums) { + if (! ($enums{$_}->{header} =~ /libgimp/) && + ! $enums{$_}->{external}) { + my $gtype = $func = $_; + + for ($gtype) { s/Gimp//; s/([A-Z][^A-Z]+)/\U$1\E_/g; s/_$// } + for ($func) { s/Gimp//; s/([A-Z][^A-Z]+)/\L$1\E_/g; s/_$// } + + print ENUMFILE "\n#define GIMP_TYPE_$gtype (gimp_$func\_get_type ())\n\n"; + print ENUMFILE "GType gimp_$func\_get_type (void) G_GNUC_CONST;\n\n"; + print ENUMFILE "typedef enum\n{\n"; + + my $enum = $enums{$_}; my $body = ""; + + foreach $symbol (@{$enum->{symbols}}) { + my $sym = $symbol; + $body .= " $sym"; + $body .= " = $enum->{mapping}->{$symbol}" if !$enum->{contig}; + $body .= ",\n"; + } + + $body =~ s/,\n$//s; + $body .= "\n} "; + $body .= "$_;\n\n"; + print ENUMFILE $body + } +} + +print ENUMFILE <<HEADER; + +void gimp_enums_init (void); + +const gchar ** gimp_enums_get_type_names (gint *n_type_names); + + +G_END_DECLS + +#endif /* $guard */ +HEADER + +close ENUMFILE; +&write_file($enumfile, "$destdir/libgimp"); + +$enumfile = "$builddir/libgimp/gimpenums.c.tail$FILE_EXT"; +open ENUMFILE, "> $enumfile" or die "Can't open $enumfile: $!\n"; + +print ENUMFILE <<CODE; + +typedef GType (* GimpGetTypeFunc) (void); + +static const GimpGetTypeFunc get_type_funcs[] = +{ +CODE + +my $first = 1; +foreach (sort keys %enums) { + if (! ($_ =~ /GimpUnit/)) { + my $enum = $enums{$_}; + my $func = $_; + my $gegl_enum = ($func =~ /Gegl/); + + for ($func) { s/Gimp//; s/Gegl//; s/PDB/Pdb/; + s/([A-Z][^A-Z]+)/\L$1\E_/g; s/_$// } + + print ENUMFILE ",\n" unless $first; + + if ($gegl_enum) { + print ENUMFILE " gegl_$func\_get_type"; + } else { + print ENUMFILE " gimp_$func\_get_type"; + } + + $first = 0; + } +} +print ENUMFILE "\n" unless $first; + +print ENUMFILE <<CODE; +}; + +static const gchar * const type_names[] = +{ +CODE + +$first = 1; +foreach (sort keys %enums) { + if (! ($_ =~ /GimpUnit/)) { + my $enum = $enums{$_}; + my $gtype = $_; + + print ENUMFILE ",\n" unless $first; + print ENUMFILE " \"$gtype\""; + + $first = 0; + } +} +print ENUMFILE "\n" unless $first; + +print ENUMFILE <<CODE; +}; + +static gboolean enums_initialized = FALSE; + +GType gimp_convert_dither_type_compat_get_type (void); +GType gimp_layer_mode_effects_get_type (void); + +/** + * gimp_enums_init: + * + * This function makes sure all the enum types are registered + * with the #GType system. This is intended for use by language + * bindings that need the symbols early, before gimp_main is run. + * It's not necessary for plug-ins to call this directly, because + * the normal plug-in initialization code will handle it implicitly. + * + * Since: 2.4 + **/ +void +gimp_enums_init (void) +{ + const GimpGetTypeFunc *funcs = get_type_funcs; + GQuark quark; + gint i; + + if (enums_initialized) + return; + + for (i = 0; i < G_N_ELEMENTS (get_type_funcs); i++, funcs++) + { + GType type = (*funcs) (); + + g_type_class_ref (type); + } + + /* keep compat enum code in sync with app/app.c (app_libs_init) */ + quark = g_quark_from_static_string ("gimp-compat-enum"); + + g_type_set_qdata (GIMP_TYPE_CONVERT_DITHER_TYPE, quark, + (gpointer) gimp_convert_dither_type_compat_get_type ()); + g_type_set_qdata (GIMP_TYPE_LAYER_MODE, quark, + (gpointer) gimp_layer_mode_effects_get_type ()); + + gimp_base_compat_enums_init (); + + enums_initialized = TRUE; +} + +/** + * gimp_enums_get_type_names: + * \@n_type_names: return location for the number of names + * + * This function gives access to the list of enums registered by libgimp. + * The returned array is static and must not be modified. + * + * Return value: an array with type names + * + * Since: 2.2 + **/ +const gchar ** +gimp_enums_get_type_names (gint *n_type_names) +{ + g_return_val_if_fail (n_type_names != NULL, NULL); + + *n_type_names = G_N_ELEMENTS (type_names); + + return (const gchar **) type_names; +} +CODE + +close ENUMFILE; +&write_file($enumfile, "$destdir/libgimp"); |