1997-11-24 22:05:25 +00:00
/* The GIMP -- an image manipulation program
2003-07-03 00:47:26 +00:00
* Copyright ( C ) 1995 - 2003 Spencer Kimball and Peter Mattis
1997-11-24 22:05:25 +00:00
*
* 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 .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
1998-04-13 05:44:11 +00:00
* Foundation , Inc . , 59 Temple Place - Suite 330 , Boston , MA 02111 - 1307 , USA .
1997-11-24 22:05:25 +00:00
*/
1999-03-28 06:55:29 +00:00
/* NOTE: This file is autogenerated by pdbgen.pl. */
2000-12-29 15:22:01 +00:00
# include "config.h"
2004-07-10 20:29:11 +00:00
# include <glib-object.h>
2000-12-29 15:22:01 +00:00
2001-08-17 14:27:31 +00:00
# include "pdb-types.h"
1999-03-28 06:55:29 +00:00
# include "procedural_db.h"
1997-11-24 22:05:25 +00:00
2001-10-31 21:20:09 +00:00
# include "core/gimp.h"
2003-10-06 12:17:11 +00:00
# include "core/gimpcontainer.h"
2001-05-09 02:32:03 +00:00
# include "core/gimpimage.h"
1997-11-24 22:05:25 +00:00
1999-03-28 06:55:29 +00:00
static ProcRecord display_new_proc ;
static ProcRecord display_delete_proc ;
2005-09-05 20:47:12 +00:00
static ProcRecord display_get_window_handle_proc ;
1999-03-28 06:55:29 +00:00
static ProcRecord displays_flush_proc ;
2002-12-03 12:10:21 +00:00
static ProcRecord displays_reconnect_proc ;
1997-11-24 22:05:25 +00:00
1999-03-28 06:55:29 +00:00
void
2001-07-04 19:31:35 +00:00
register_display_procs ( Gimp * gimp )
1997-11-24 22:05:25 +00:00
{
2001-07-04 19:31:35 +00:00
procedural_db_register ( gimp , & display_new_proc ) ;
procedural_db_register ( gimp , & display_delete_proc ) ;
2005-09-05 20:47:12 +00:00
procedural_db_register ( gimp , & display_get_window_handle_proc ) ;
2001-07-04 19:31:35 +00:00
procedural_db_register ( gimp , & displays_flush_proc ) ;
2002-12-03 12:10:21 +00:00
procedural_db_register ( gimp , & displays_reconnect_proc ) ;
1999-03-28 06:55:29 +00:00
}
1997-11-24 22:05:25 +00:00
1999-03-28 06:55:29 +00:00
static Argument *
2004-08-10 18:47:21 +00:00
display_new_invoker ( Gimp * gimp ,
GimpContext * context ,
GimpProgress * progress ,
Argument * args )
1999-03-28 06:55:29 +00:00
{
gboolean success = TRUE ;
Argument * return_args ;
GimpImage * gimage ;
2004-07-10 20:29:11 +00:00
GimpObject * display = NULL ;
1999-03-28 06:55:29 +00:00
2001-07-11 12:39:49 +00:00
gimage = gimp_image_get_by_ID ( gimp , args [ 0 ] . value . pdb_int ) ;
2002-08-29 17:21:21 +00:00
if ( ! GIMP_IS_IMAGE ( gimage ) )
1999-03-28 06:55:29 +00:00
success = FALSE ;
1997-11-24 22:05:25 +00:00
if ( success )
{
2004-07-10 20:29:11 +00:00
display = gimp_create_display ( gimp , gimage , GIMP_UNIT_PIXEL , 1.0 ) ;
2004-03-26 16:38:44 +00:00
2003-12-08 12:28:29 +00:00
success = ( display ! = NULL ) ;
2004-03-26 16:38:44 +00:00
2002-10-24 13:06:03 +00:00
/* the first display takes ownership of the image */
if ( success & & gimage - > disp_count = = 1 )
2004-03-26 16:49:18 +00:00
g_object_unref ( gimage ) ;
1997-11-24 22:05:25 +00:00
}
1999-03-28 06:55:29 +00:00
return_args = procedural_db_return_args ( & display_new_proc , success ) ;
1997-11-24 22:05:25 +00:00
if ( success )
2004-07-10 20:29:11 +00:00
return_args [ 1 ] . value . pdb_int = gimp_get_display_ID ( gimp , display ) ;
1997-11-24 22:05:25 +00:00
return return_args ;
}
1999-03-28 06:55:29 +00:00
static ProcArg display_new_inargs [ ] =
1997-11-24 22:05:25 +00:00
{
1999-03-28 06:55:29 +00:00
{
2001-05-21 13:58:46 +00:00
GIMP_PDB_IMAGE ,
1997-11-24 22:05:25 +00:00
" image " ,
1999-03-28 06:55:29 +00:00
" The image "
1997-11-24 22:05:25 +00:00
}
} ;
1999-03-28 06:55:29 +00:00
static ProcArg display_new_outargs [ ] =
1997-11-24 22:05:25 +00:00
{
1999-03-28 06:55:29 +00:00
{
2001-05-21 13:58:46 +00:00
GIMP_PDB_DISPLAY ,
1997-11-24 22:05:25 +00:00
" display " ,
1999-03-28 06:55:29 +00:00
" The new display "
1997-11-24 22:05:25 +00:00
}
} ;
1999-03-28 06:55:29 +00:00
static ProcRecord display_new_proc =
1997-11-24 22:05:25 +00:00
{
2005-08-02 22:52:23 +00:00
" gimp-display-new " ,
" gimp-display-new " ,
1999-03-28 06:55:29 +00:00
" Create a new display for the specified image. " ,
" Creates a new display for the specified image. If the image already has a display, another is added. Multiple displays are handled transparently by the GIMP. The newly created display is returned and can be subsequently destroyed with a call to 'gimp-display-delete'. This procedure only makes sense for use with the GIMP UI. " ,
1997-11-24 22:05:25 +00:00
" Spencer Kimball & Peter Mattis " ,
" Spencer Kimball & Peter Mattis " ,
" 1995-1996 " ,
2004-10-06 13:13:08 +00:00
NULL ,
2001-05-21 13:58:46 +00:00
GIMP_INTERNAL ,
1997-11-24 22:05:25 +00:00
1 ,
1999-03-28 06:55:29 +00:00
display_new_inargs ,
1997-11-24 22:05:25 +00:00
1 ,
1999-03-28 06:55:29 +00:00
display_new_outargs ,
{ { display_new_invoker } }
1997-11-24 22:05:25 +00:00
} ;
static Argument *
2004-08-10 18:47:21 +00:00
display_delete_invoker ( Gimp * gimp ,
GimpContext * context ,
GimpProgress * progress ,
Argument * args )
1997-11-24 22:05:25 +00:00
{
1999-03-28 06:55:29 +00:00
gboolean success = TRUE ;
2004-07-10 20:29:11 +00:00
GimpObject * display ;
1997-11-24 22:05:25 +00:00
2004-07-10 20:29:11 +00:00
display = gimp_get_display_by_ID ( gimp , args [ 0 ] . value . pdb_int ) ;
if ( ! GIMP_IS_OBJECT ( display ) )
1997-11-24 22:05:25 +00:00
success = FALSE ;
1999-03-28 06:55:29 +00:00
if ( success )
2004-07-10 20:29:11 +00:00
gimp_delete_display ( gimp , display ) ;
1999-03-28 06:55:29 +00:00
return procedural_db_return_args ( & display_delete_proc , success ) ;
1997-11-24 22:05:25 +00:00
}
1999-03-28 06:55:29 +00:00
static ProcArg display_delete_inargs [ ] =
1997-11-24 22:05:25 +00:00
{
1999-03-28 06:55:29 +00:00
{
2001-05-21 13:58:46 +00:00
GIMP_PDB_DISPLAY ,
1997-11-24 22:05:25 +00:00
" display " ,
1999-03-28 06:55:29 +00:00
" The display to delete "
1997-11-24 22:05:25 +00:00
}
} ;
1999-03-28 06:55:29 +00:00
static ProcRecord display_delete_proc =
1997-11-24 22:05:25 +00:00
{
2005-08-02 22:52:23 +00:00
" gimp-display-delete " ,
" gimp-display-delete " ,
1999-03-28 06:55:29 +00:00
" Delete the specified display. " ,
" This procedure removes the specified display. If this is the last remaining display for the underlying image, then the image is deleted also. " ,
1997-11-24 22:05:25 +00:00
" Spencer Kimball & Peter Mattis " ,
" Spencer Kimball & Peter Mattis " ,
" 1995-1996 " ,
2004-10-06 13:13:08 +00:00
NULL ,
2001-05-21 13:58:46 +00:00
GIMP_INTERNAL ,
1997-11-24 22:05:25 +00:00
1 ,
1999-03-28 06:55:29 +00:00
display_delete_inargs ,
1997-11-24 22:05:25 +00:00
0 ,
NULL ,
1999-03-28 06:55:29 +00:00
{ { display_delete_invoker } }
1997-11-24 22:05:25 +00:00
} ;
2005-09-05 20:47:12 +00:00
static Argument *
display_get_window_handle_invoker ( Gimp * gimp ,
GimpContext * context ,
GimpProgress * progress ,
Argument * args )
{
gboolean success = TRUE ;
Argument * return_args ;
GimpObject * display ;
gint32 window = 0 ;
display = gimp_get_display_by_ID ( gimp , args [ 0 ] . value . pdb_int ) ;
if ( ! GIMP_IS_OBJECT ( display ) )
success = FALSE ;
if ( success )
window = ( gint32 ) gimp_get_display_window ( gimp , display ) ;
return_args = procedural_db_return_args ( & display_get_window_handle_proc , success ) ;
if ( success )
return_args [ 1 ] . value . pdb_int = window ;
return return_args ;
}
static ProcArg display_get_window_handle_inargs [ ] =
{
{
GIMP_PDB_DISPLAY ,
" display " ,
" The display to get the window handle from "
}
} ;
static ProcArg display_get_window_handle_outargs [ ] =
{
{
GIMP_PDB_INT32 ,
" window " ,
" The native window handle or 0 "
}
} ;
static ProcRecord display_get_window_handle_proc =
{
" gimp-display-get-window-handle " ,
" gimp-display-get-window-handle " ,
" Get a handle to the native window for an image display. " ,
" This procedure returns a handle to the native window for a given image display. For example in the X backend of GDK, a native window handle is an Xlib XID. A value of 0 is returned for an invalid display or if this function is unimplemented for the windowing system that is being used. " ,
" Sven Neumann " ,
" Sven Neumann " ,
" 2005 " ,
NULL ,
GIMP_INTERNAL ,
1 ,
display_get_window_handle_inargs ,
1 ,
display_get_window_handle_outargs ,
{ { display_get_window_handle_invoker } }
} ;
1997-11-24 22:05:25 +00:00
static Argument *
2004-08-10 18:47:21 +00:00
displays_flush_invoker ( Gimp * gimp ,
GimpContext * context ,
GimpProgress * progress ,
Argument * args )
1997-11-24 22:05:25 +00:00
{
2003-10-06 12:17:11 +00:00
gimp_container_foreach ( gimp - > images , ( GFunc ) gimp_image_flush , NULL ) ;
1999-03-28 06:55:29 +00:00
return procedural_db_return_args ( & displays_flush_proc , TRUE ) ;
1997-11-24 22:05:25 +00:00
}
1999-03-28 06:55:29 +00:00
static ProcRecord displays_flush_proc =
1997-11-24 22:05:25 +00:00
{
2005-08-02 22:52:23 +00:00
" gimp-displays-flush " ,
" gimp-displays-flush " ,
1997-11-24 22:05:25 +00:00
" Flush all internal changes to the user interface " ,
1999-03-28 06:55:29 +00:00
" This procedure takes no arguments and returns nothing except a success status. Its purpose is to flush all pending updates of image manipulations to the user interface. It should be called whenever appropriate. " ,
1997-11-24 22:05:25 +00:00
" Spencer Kimball & Peter Mattis " ,
" Spencer Kimball & Peter Mattis " ,
" 1995-1996 " ,
2004-10-06 13:13:08 +00:00
NULL ,
2001-05-21 13:58:46 +00:00
GIMP_INTERNAL ,
1997-11-24 22:05:25 +00:00
0 ,
NULL ,
0 ,
NULL ,
1999-03-28 06:55:29 +00:00
{ { displays_flush_invoker } }
1997-11-24 22:05:25 +00:00
} ;
2002-12-03 12:10:21 +00:00
static Argument *
2004-08-10 18:47:21 +00:00
displays_reconnect_invoker ( Gimp * gimp ,
GimpContext * context ,
GimpProgress * progress ,
Argument * args )
2002-12-03 12:10:21 +00:00
{
gboolean success = TRUE ;
2003-12-08 12:28:29 +00:00
GimpImage * old_image ;
GimpImage * new_image ;
2002-12-03 12:10:21 +00:00
2003-12-08 12:28:29 +00:00
old_image = gimp_image_get_by_ID ( gimp , args [ 0 ] . value . pdb_int ) ;
if ( ! GIMP_IS_IMAGE ( old_image ) )
2002-12-03 12:10:21 +00:00
success = FALSE ;
2003-12-08 12:28:29 +00:00
new_image = gimp_image_get_by_ID ( gimp , args [ 1 ] . value . pdb_int ) ;
if ( ! GIMP_IS_IMAGE ( new_image ) )
2002-12-03 12:10:21 +00:00
success = FALSE ;
if ( success )
2004-11-29 16:59:53 +00:00
{
success = ( old_image ! = new_image & &
old_image - > disp_count > 0 & &
new_image - > disp_count = = 0 ) ;
if ( success )
{
gimp_reconnect_displays ( gimp , old_image , new_image ) ;
/* take ownership of the image */
if ( new_image - > disp_count > 0 )
g_object_unref ( new_image ) ;
}
}
2002-12-03 12:10:21 +00:00
return procedural_db_return_args ( & displays_reconnect_proc , success ) ;
}
static ProcArg displays_reconnect_inargs [ ] =
{
{
GIMP_PDB_IMAGE ,
2005-08-05 18:19:09 +00:00
" old-image " ,
2004-11-29 16:59:53 +00:00
" The old image (must have at least one display) "
2002-12-03 12:10:21 +00:00
} ,
{
GIMP_PDB_IMAGE ,
2005-08-05 18:19:09 +00:00
" new-image " ,
2002-12-03 12:10:21 +00:00
" The new image (must not have a display) "
}
} ;
static ProcRecord displays_reconnect_proc =
{
2005-08-02 22:52:23 +00:00
" gimp-displays-reconnect " ,
" gimp-displays-reconnect " ,
2002-12-03 12:10:21 +00:00
" Reconnect displays from one image to another image. " ,
2004-11-29 16:59:53 +00:00
" This procedure connects all displays of the old_image to the new_image. If the old_image has no display or new_image already has a display the reconnect is not performed and the procedure returns without success. You should rarely need to use this function. " ,
2002-12-03 12:10:21 +00:00
" Spencer Kimball & Peter Mattis " ,
" Spencer Kimball & Peter Mattis " ,
" 1995-1996 " ,
2004-10-06 13:13:08 +00:00
NULL ,
2002-12-03 12:10:21 +00:00
GIMP_INTERNAL ,
2 ,
displays_reconnect_inargs ,
0 ,
NULL ,
{ { displays_reconnect_invoker } }
} ;