We don't want an infinite number of traces because it takes some time to get. Until now I was keeping track of traces in app/errors.c, but that was very sucky because then I was limiting traces per session. Instead save them as a variable of a GimpCriticalDialog instance. Therefore only generate the traces for WARNING/CRITICAL at the last second, when calling the dialog. When too many traces are displayed, just fallback to just add error messages only. But then even errors without traces can be time-consuming (if you have dozens of thousands of errors in a few seconds, as I had the other day, updating the dialog for all of them would just freeze the whole application for a long time). So also keep track of errors as well and as last fallback, just send the remaining errors to the stderr.
116 lines
2.9 KiB
Text
116 lines
2.9 KiB
Text
# GIMP - The GNU Image Manipulation Program
|
|
# Copyright (C) 1998-1999 Manish Singh
|
|
|
|
# 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 <http://www.gnu.org/licenses/>.
|
|
|
|
# "Perlized" from C source by Manish Singh <yosh@gimp.org>
|
|
|
|
sub message {
|
|
$blurb = 'Displays a dialog box with a message.';
|
|
|
|
$help = <<'HELP';
|
|
Displays a dialog box with a message. Useful for status or error reporting.
|
|
The message must be in UTF-8 encoding.
|
|
HELP
|
|
|
|
&yosh_pdb_misc('1998');
|
|
|
|
@inargs = (
|
|
{ name => 'message', type => 'string',
|
|
desc => 'Message to display in the dialog' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
const gchar *domain = NULL;
|
|
|
|
if (gimp->plug_in_manager->current_plug_in)
|
|
domain = gimp_plug_in_get_undo_desc (gimp->plug_in_manager->current_plug_in);
|
|
gimp_show_message (gimp, G_OBJECT (progress), GIMP_MESSAGE_WARNING,
|
|
domain, message);
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub message_get_handler {
|
|
$blurb = <<'BLURB';
|
|
Returns the current state of where warning messages are displayed.
|
|
BLURB
|
|
|
|
$help = <<'HELP';
|
|
This procedure returns the way g_message warnings are displayed. They can be
|
|
shown in a dialog box or printed on the console where gimp was started.
|
|
HELP
|
|
|
|
&yosh_pdb_misc('1998');
|
|
|
|
@outargs = (
|
|
{ name => 'handler', type => 'enum GimpMessageHandlerType',
|
|
desc => 'The current handler type' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
handler = gimp->message_handler;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub message_set_handler {
|
|
$blurb = 'Controls where warning messages are displayed.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure controls how g_message warnings are displayed. They can be shown
|
|
in a dialog box or printed on the console where gimp was started.
|
|
HELP
|
|
|
|
&yosh_pdb_misc('1998');
|
|
|
|
@inargs = (
|
|
{ name => 'handler', type => 'enum GimpMessageHandlerType',
|
|
desc => 'The new handler type' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
gimp->message_handler = handler;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
|
|
@headers = qw(<string.h>
|
|
"core/gimp.h"
|
|
"plug-in/gimpplugin.h"
|
|
"plug-in/gimppluginmanager.h"
|
|
"gimp-intl.h");
|
|
|
|
@procs = qw(message
|
|
message_get_handler
|
|
message_set_handler);
|
|
|
|
%exports = (app => [@procs], lib => [@procs]);
|
|
|
|
$desc = 'Message procedures';
|
|
$doc_title = 'gimpmessage';
|
|
$doc_short_desc = 'Display a dialog box with a message.';
|
|
$doc_long_desc = 'Display a dialog box with a message.';
|
|
|
|
1;
|