diff options
| author | monsta <[email protected]> | 2016-11-06 14:42:18 +0300 | 
|---|---|---|
| committer | monsta <[email protected]> | 2016-11-06 14:42:18 +0300 | 
| commit | 65371f53dbb06180b750dad7c19e7bcf0f8651d6 (patch) | |
| tree | 0b387d0a17207e13ce662da55970c97b50bc55db /plugin-loaders/python | |
| parent | 7dd02941b3647477dfe0cf8177c2eeff8bfe7b84 (diff) | |
| download | pluma-65371f53dbb06180b750dad7c19e7bcf0f8651d6.tar.bz2 pluma-65371f53dbb06180b750dad7c19e7bcf0f8651d6.tar.xz | |
drop Python plugins support and --enable-python build option
it requires PyGTK so won't even build with GTK+3
but keep plugins themselves for future porting to libpeas
Diffstat (limited to 'plugin-loaders/python')
| -rw-r--r-- | plugin-loaders/python/Makefile.am | 36 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/Makefile.am | 115 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/pluma.defs | 1461 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/pluma.override | 461 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/plumacommands.defs | 45 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/plumacommands.override | 122 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/plumamessage.override | 556 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/plumaplugin.override | 193 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/plumautils.defs | 67 | ||||
| -rw-r--r-- | plugin-loaders/python/bindings/plumautils.override | 85 | ||||
| -rw-r--r-- | plugin-loaders/python/pluma-plugin-loader-python.c | 719 | ||||
| -rw-r--r-- | plugin-loaders/python/pluma-plugin-loader-python.h | 61 | ||||
| -rw-r--r-- | plugin-loaders/python/pluma-plugin-python.c | 281 | ||||
| -rw-r--r-- | plugin-loaders/python/pluma-plugin-python.h | 88 | 
14 files changed, 0 insertions, 4290 deletions
| diff --git a/plugin-loaders/python/Makefile.am b/plugin-loaders/python/Makefile.am deleted file mode 100644 index 8cb55668..00000000 --- a/plugin-loaders/python/Makefile.am +++ /dev/null @@ -1,36 +0,0 @@ -# C plugin loader - -SUBDIRS = bindings -loaderdir = $(libdir)/pluma/plugin-loaders - -AM_CPPFLAGS = \ -	-I$(top_srcdir) 						\ -	-I$(top_builddir)						\ -	-I$(top_srcdir)/pluma						\ -	-I$(top_builddir)/pluma						\ -	$(PLUMA_CFLAGS) 						\ -	$(WARN_CFLAGS)							\ -	$(DISABLE_DEPRECATED_CFLAGS)					\ -	$(PYGTK_CFLAGS)							\ -	$(PYTHON_CFLAGS)						\ -	-DPLUMA_PLUGINS_LIBS_DIR=\"$(PLUMA_PLUGINS_LIBS_DIR)\"		\ -	-DPLUMA_LOCALEDIR=\""$(prefix)/$(DATADIRNAME)/locale"\" - -loader_LTLIBRARIES = libpythonloader.la - - -NOINST_H_FILES = \ -	pluma-plugin-loader-python.h	\ -	pluma-plugin-python.h - -libpythonloader_la_SOURCES = \ -	pluma-plugin-loader-python.c 	\ -	pluma-plugin-python.c		\ -	$(NOINST_H_FILES) - -libpythonloader_la_LDFLAGS = $(LOADER_LIBTOOL_FLAGS) -libpythonloader_la_LIBADD = \ -	$(PLUMA_LIBS) 			\ -	bindings/pluma.la - --include $(top_srcdir)/git.mk diff --git a/plugin-loaders/python/bindings/Makefile.am b/plugin-loaders/python/bindings/Makefile.am deleted file mode 100644 index f9493e2d..00000000 --- a/plugin-loaders/python/bindings/Makefile.am +++ /dev/null @@ -1,115 +0,0 @@ -## Process this file with automake to produce Makefile.in - -noinst_LTLIBRARIES = \ -	pluma.la - -nodist_pluma_la_SOURCES = 	\ -	pluma.c			\ -	plumautils.c		\ -	plumacommands.c - -pluma_la_LDFLAGS = \ -	-module -avoid-version - -pluma_la_LIBADD = \ -	$(PYTHON_LIB_LOC)       \ -	$(PYTHON_LIBS)		\ -	$(PYTHON_EXTRA_LIBS)	\ -	$(PYGTK_LIBS) - -pluma_la_CFLAGS = \ -	-I$(top_srcdir)					\ -	-I$(top_builddir)				\ -	-I$(top_srcdir)/pluma				\ -	-I$(top_builddir)/pluma				\ -	-I$(top_srcdir)/plugin-loaders/python		\ -	-I$(top_builddir)/plugin-loaders/python		\ -	$(PLUMA_CFLAGS)					\ -	$(NO_STRICT_ALIASING_CFLAGS)			\ -	$(PYGTK_CFLAGS)					\ -	$(PYTHON_CFLAGS)				\ -	$(AM_CFLAGS) - -$(top_builddir)/pluma/pluma-enum-types.h: -	cd $(top_builddir)/pluma && $(MAKE) pluma-enum-types.h - -pluma.c: pluma.defs pluma.override plumaplugin.override plumamessage.override $(top_builddir)/pluma/pluma-enum-types.h -	( cd $(srcdir) && $(PYGTK_CODEGEN) \ -		--register $(PYGTK_DEFSDIR)/pango-types.defs \ -		--register $(PYGTK_DEFSDIR)/gdk-types.defs \ -		--register $(PYGTK_DEFSDIR)/gtk-types.defs \ -		--register $(PYGTK_DEFSDIR)/gtksourceview2.defs \ -		--register $(PYGOBJECT_DEFSDIR)/gio-types.defs \ -		--override $*.override \ -		--prefix py$* $(<F) ) > $@  - -plumautils.c: plumautils.defs plumautils.override -	( cd $(srcdir) && $(PYGTK_CODEGEN) \ -		--override $*.override \ -		--prefix py$* $(<F) ) > $@  - -plumacommands.c: plumacommands.defs plumacommands.override pluma.defs -	( cd $(srcdir) && $(PYGTK_CODEGEN) \ -		--register pluma.defs \ -		--register $(PYGTK_DEFSDIR)/gtk-types.defs \ -		--override $*.override \ -		--prefix py$* $(<F) ) > $@  - -BINDING_PLUMA_HEADERS_SRCDIR_IN = \ -	pluma/pluma-app.h		\ -	pluma/pluma-document.h		\ -	pluma/pluma-encodings.h		\ -	pluma/pluma-plugin.h		\ -	plugin-loaders/python/pluma-plugin-python.h \ -	pluma/pluma-view.h		\ -	pluma/pluma-statusbar.h		\ -	pluma/pluma-tab.h 		\ -	pluma/pluma-panel.h 		\ -	pluma/pluma-window.h 		\ -	pluma/pluma-help.h		\ -	pluma/pluma-debug.h		\ -	pluma/pluma-message-type.h	\ -	pluma/pluma-message.h		\ -	pluma/pluma-message-bus.h	\ -	pluma/pluma-language-manager.h - -BINDING_UTILS_HEADERS_SRCDIR_IN = \ -	pluma/pluma-utils.h - -BINDING_COMMANDS_HEADERS_SRCDIR_IN = \ -	pluma/pluma-commands.h - -BINDING_HEADERS_BUILDDIR_IN =  - -BINDING_PLUMA_HEADERS_SRCDIR	:= $(addprefix $(top_srcdir)/,$(BINDING_PLUMA_HEADERS_SRCDIR_IN)) -BINDING_UTILS_HEADERS_SRCDIR	:= $(addprefix $(top_srcdir)/,$(BINDING_UTILS_HEADERS_SRCDIR_IN)) -BINDING_COMMANDS_HEADERS_SRCDIR	:= $(addprefix $(top_srcdir)/,$(BINDING_COMMANDS_HEADERS_SRCDIR_IN)) - -BINDING_HEADERS_BUILDDIR	:= $(addprefix $(top_builddir)/,$(BINDING_HEADERS_BUILDDIR_IN)) - -regenerate-python-binding: -	$(PYGTK_H2DEF) $(sort $(BINDING_PLUMA_HEADERS_SRCDIR) $(BINDING_HEADERS_BUILDDIR)) > pluma.defs.new -	$(PYGTK_H2DEF) $(sort $(BINDING_UTILS_HEADERS_SRCDIR) $(BINDING_HEADERS_BUILDDIR)) > plumautils.defs.new -	$(PYGTK_H2DEF) $(sort $(BINDING_COMMANDS_HEADERS_SRCDIR) $(BINDING_HEADERS_BUILDDIR)) > plumacommands.defs.new - -BUILT_SOURCES = \ -	pluma.c		\ -	plumautils.c	\ -	plumacommands.c - -EXTRA_DIST = \ -	pluma.override		\ -	pluma.defs		\ -	plumautils.override	\ -	plumautils.defs		\ -	plumacommands.override 	\ -	plumacommands.defs	\ -	plumamessage.override	\ -	plumaplugin.override - -CLEANFILES = $(BUILT_SOURCES) - -dist-hook: -	cd $(distdir); rm -f $(BUILT_SOURCES) - --include $(top_srcdir)/git.mk diff --git a/plugin-loaders/python/bindings/pluma.defs b/plugin-loaders/python/bindings/pluma.defs deleted file mode 100644 index f4e799f1..00000000 --- a/plugin-loaders/python/bindings/pluma.defs +++ /dev/null @@ -1,1461 +0,0 @@ -;; -*- scheme -*- -; object definitions ... -(define-object App -  (in-module "Pluma") -  (parent "GObject") -  (c-name "PlumaApp") -  (gtype-id "PLUMA_TYPE_APP") -) - -(define-object Document -  (in-module "Pluma") -  (parent "GtkSourceBuffer") -  (c-name "PlumaDocument") -  (gtype-id "PLUMA_TYPE_DOCUMENT") -) - -(define-object Message -  (in-module "Pluma") -  (parent "GObject") -  (c-name "PlumaMessage") -  (gtype-id "PLUMA_TYPE_MESSAGE") -) - -(define-object MessageBus -  (in-module "Pluma") -  (parent "GObject") -  (c-name "PlumaMessageBus") -  (gtype-id "PLUMA_TYPE_MESSAGE_BUS") -) - -(define-object Panel -  (in-module "Pluma") -  (parent "GtkVBox") -  (c-name "PlumaPanel") -  (gtype-id "PLUMA_TYPE_PANEL") -) - -(define-object __Plugin -  (in-module "Pluma") -  (parent "GObject") -  (c-name "PlumaPlugin") -  (gtype-id "PLUMA_TYPE_PLUGIN") -) - -(define-object Plugin -  (in-module "Pluma") -  (parent "PlumaPlugin") -  (c-name "PlumaPluginPython") -  (gtype-id "PLUMA_TYPE_PLUGIN_PYTHON") -) - -(define-object Statusbar -  (in-module "Pluma") -  (parent "GtkStatusbar") -  (c-name "PlumaStatusbar") -  (gtype-id "PLUMA_TYPE_STATUSBAR") -) - -(define-object Tab -  (in-module "Pluma") -  (parent "GtkVBox") -  (c-name "PlumaTab") -  (gtype-id "PLUMA_TYPE_TAB") -) - -(define-object View -  (in-module "Pluma") -  (parent "GtkSourceView") -  (c-name "PlumaView") -  (gtype-id "PLUMA_TYPE_VIEW") -) - -(define-object Window -  (in-module "Pluma") -  (parent "GtkWindow") -  (c-name "PlumaWindow") -  (gtype-id "PLUMA_TYPE_WINDOW") -) - -;; Enumerations and flags ... - -(define-flags LockdownMask -  (in-module "Pluma") -  (c-name "PlumaLockdownMask") -  (gtype-id "PLUMA_TYPE_LOCKDOWN_MASK") -  (values -    '("command-line" "PLUMA_LOCKDOWN_COMMAND_LINE") -    '("printing" "PLUMA_LOCKDOWN_PRINTING") -    '("print-setup" "PLUMA_LOCKDOWN_PRINT_SETUP") -    '("save-to-disk" "PLUMA_LOCKDOWN_SAVE_TO_DISK") -    '("all" "PLUMA_LOCKDOWN_ALL") -  ) -) - -(define-flags SearchFlags -  (in-module "Pluma") -  (c-name "PlumaSearchFlags") -  (gtype-id "PLUMA_TYPE_SEARCH_FLAGS") -  (values -    '("dont-set-flags" "PLUMA_SEARCH_DONT_SET_FLAGS") -    '("entire-word" "PLUMA_SEARCH_ENTIRE_WORD") -    '("case-sensitive" "PLUMA_SEARCH_CASE_SENSITIVE") -  ) -) - -(define-flags DocumentSaveFlags -  (in-module "Pluma") -  (c-name "PlumaDocumentSaveFlags") -  (gtype-id "PLUMA_TYPE_DOCUMENT_SAVE_FLAGS") -  (values -    '("ignore-mtime" "PLUMA_DOCUMENT_SAVE_IGNORE_MTIME") -    '("ignore-backup" "PLUMA_DOCUMENT_SAVE_IGNORE_BACKUP") -    '("preserve-backup" "PLUMA_DOCUMENT_SAVE_PRESERVE_BACKUP") -  ) -) - -(define-enum TabState -  (in-module "Pluma") -  (c-name "PlumaTabState") -  (gtype-id "PLUMA_TYPE_TAB_STATE") -  (values -    '("normal" "PLUMA_TAB_STATE_NORMAL") -    '("loading" "PLUMA_TAB_STATE_LOADING") -    '("reverting" "PLUMA_TAB_STATE_REVERTING") -    '("saving" "PLUMA_TAB_STATE_SAVING") -    '("printing" "PLUMA_TAB_STATE_PRINTING") -    '("print-previewing" "PLUMA_TAB_STATE_PRINT_PREVIEWING") -    '("showing-print-preview" "PLUMA_TAB_STATE_SHOWING_PRINT_PREVIEW") -    '("generic-not-editable" "PLUMA_TAB_STATE_GENERIC_NOT_EDITABLE") -    '("loading-error" "PLUMA_TAB_STATE_LOADING_ERROR") -    '("reverting-error" "PLUMA_TAB_STATE_REVERTING_ERROR") -    '("saving-error" "PLUMA_TAB_STATE_SAVING_ERROR") -    '("generic-error" "PLUMA_TAB_STATE_GENERIC_ERROR") -    '("closing" "PLUMA_TAB_STATE_CLOSING") -  ) -) - -(define-flags WindowState -  (in-module "Pluma") -  (c-name "PlumaWindowState") -  (gtype-id "PLUMA_TYPE_WINDOW_STATE") -  (values -    '("normal" "PLUMA_WINDOW_STATE_NORMAL") -    '("saving" "PLUMA_WINDOW_STATE_SAVING") -    '("printing" "PLUMA_WINDOW_STATE_PRINTING") -    '("loading" "PLUMA_WINDOW_STATE_LOADING") -    '("error" "PLUMA_WINDOW_STATE_ERROR") -    '("saving-session" "PLUMA_WINDOW_STATE_SAVING_SESSION")     -  ) -) - -;; Boxed types -(define-boxed Encoding -  (in-module "Pluma") -  (c-name "PlumaEncoding") -  (gtype-id "PLUMA_TYPE_ENCODING") -  (copy-func "pluma_encoding_copy") -  (release-func "pluma_encoding_free") -;;  (fields -;;    '("gint" "index") -;;    '("gchar*" "charset") -;;    '("gchar*" "name") -;;  ) -) - -(define-boxed MessageType -  (in-module "Pluma") -  (c-name "PlumaMessageType") -  (gtype-id "PLUMA_TYPE_MESSAGE_TYPE") -  (copy-func "pluma_message_type_ref") -  (release-func "pluma_message_type_unref") -) - - -;; From ../../pluma/pluma-app.h - -(define-function pluma_app_get_type -  (c-name "pluma_app_get_type") -  (return-type "GType") -) - -(define-function app_get_default -  (c-name "pluma_app_get_default") -  (return-type "PlumaApp*") -) - -; deprecated version ! -(define-function pluma_app_get_default -  (c-name "pluma_app_get_default_deprecated") -  (return-type "PlumaApp*") -) - -(define-method create_window -  (of-object "PlumaApp") -  (c-name "pluma_app_create_window") -  (return-type "PlumaWindow*") -  (parameters -    '("GdkScreen*" "screen") -  ) -) - -(define-method get_windows -  (of-object "PlumaApp") -  (c-name "pluma_app_get_windows") -  (return-type "const-GList*") -) - -(define-method get_active_window -  (of-object "PlumaApp") -  (c-name "pluma_app_get_active_window") -  (return-type "PlumaWindow*") -) - -(define-method get_documents -  (of-object "PlumaApp") -  (c-name "pluma_app_get_documents") -  (return-type "GList*") -) - -(define-method get_views -  (of-object "PlumaApp") -  (c-name "pluma_app_get_views") -  (return-type "GList*") -) - -(define-method get_lockdown -  (of-object "PlumaApp") -  (c-name "pluma_app_get_lockdown") -  (return-type "PlumaLockdownMask") -) - - -;; From ../../pluma/pluma-document.h - -(define-function document_error_quark -  (c-name "pluma_document_error_quark") -  (return-type "GQuark") -) - -(define-function pluma_document_get_type -  (c-name "pluma_document_get_type") -  (return-type "GType") -) - -(define-function pluma_document_new -  (c-name "pluma_document_new") -  (is-constructor-of "PlumaDocument") -  (return-type "PlumaDocument*") -) - -(define-method get_location -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_location") -  (return-type "GFile*") -) - -(define-method get_uri -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_uri") -  (return-type "gchar*") -) - -(define-method set_uri -  (of-object "PlumaDocument") -  (c-name "pluma_document_set_uri") -  (return-type "none") -  (parameters -    '("const-gchar*" "uri") -  ) -) - -(define-method get_uri_for_display -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_uri_for_display") -  (return-type "gchar*") -) - -(define-method get_short_name_for_display -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_short_name_for_display") -  (return-type "gchar*") -) - -(define-method get_content_type -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_content_type") -  (return-type "gchar*") -) - -(define-method get_mime_type -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_mime_type") -  (return-type "gchar*") -) - -(define-method get_readonly -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_readonly") -  (return-type "gboolean") -) - -(define-method load -  (of-object "PlumaDocument") -  (c-name "pluma_document_load") -  (return-type "none") -  (parameters -    '("const-gchar*" "uri") -    '("const-PlumaEncoding*" "encoding") -    '("gint" "line_pos") -    '("gboolean" "create") -  ) -) - -(define-method insert_file -  (of-object "PlumaDocument") -  (c-name "pluma_document_insert_file") -  (return-type "gboolean") -  (parameters -    '("GtkTextIter*" "iter") -    '("const-gchar*" "uri") -    '("const-PlumaEncoding*" "encoding") -  ) -) - -(define-method load_cancel -  (of-object "PlumaDocument") -  (c-name "pluma_document_load_cancel") -  (return-type "gboolean") -) - -(define-method save -  (of-object "PlumaDocument") -  (c-name "pluma_document_save") -  (parameters -    '("PlumaDocumentSaveFlags" "flags") -  ) -  (return-type "none") -) - -(define-method save_as -  (of-object "PlumaDocument") -  (c-name "pluma_document_save_as") -  (return-type "none") -  (parameters -    '("const-gchar*" "uri") -    '("const-PlumaEncoding*" "encoding") -    '("PlumaDocumentSaveFlags" "flags") -  ) -) - -(define-method is_untouched -  (of-object "PlumaDocument") -  (c-name "pluma_document_is_untouched") -  (return-type "gboolean") -) - -(define-method is_untitled -  (of-object "PlumaDocument") -  (c-name "pluma_document_is_untitled") -  (return-type "gboolean") -) - -(define-method is_local -  (of-object "PlumaDocument") -  (c-name "pluma_document_is_local") -  (return-type "gboolean") -) - -(define-method get_deleted -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_deleted") -  (return-type "gboolean") -) - -(define-method goto_line -  (of-object "PlumaDocument") -  (c-name "pluma_document_goto_line") -  (return-type "gboolean") -  (parameters -    '("gint" "line") -  ) -) - -(define-method set_search_text -  (of-object "PlumaDocument") -  (c-name "pluma_document_set_search_text") -  (return-type "none") -  (parameters -    '("const-gchar*" "text") -    '("guint" "flags") -  ) -) - -(define-method get_search_text -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_search_text") -  (return-type "gchar*") -  (parameters -    '("guint*" "flags") -  ) -) - -(define-method get_can_search_again -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_can_search_again") -  (return-type "gboolean") -) - -(define-method search_forward -  (of-object "PlumaDocument") -  (c-name "pluma_document_search_forward") -  (return-type "gboolean") -  (parameters -    '("const-GtkTextIter*" "start") -    '("const-GtkTextIter*" "end") -    '("GtkTextIter*" "match_start") -    '("GtkTextIter*" "match_end") -  ) -) - -(define-method replace_all -  (of-object "PlumaDocument") -  (c-name "pluma_document_replace_all") -  (return-type "gint") -  (parameters -    '("const-gchar*" "find") -    '("const-gchar*" "replace") -    '("guint" "flags") -  ) -) - -(define-method search_backward -  (of-object "PlumaDocument") -  (c-name "pluma_document_search_backward") -  (return-type "gboolean") -  (parameters -    '("const-GtkTextIter*" "start") -    '("const-GtkTextIter*" "end") -    '("GtkTextIter*" "match_start") -    '("GtkTextIter*" "match_end") -  ) -) - -(define-method set_language -  (of-object "PlumaDocument") -  (c-name "pluma_document_set_language") -  (return-type "none") -  (parameters -    '("GtkSourceLanguage*" "lang" (null-ok)) -  ) -) - -(define-method get_language -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_language") -  (return-type "GtkSourceLanguage*") -) - -(define-method get_encoding -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_encoding") -  (return-type "const-PlumaEncoding*") -) - -(define-method set_enable_search_highlighting -  (of-object "PlumaDocument") -  (c-name "pluma_document_set_enable_search_highlighting") -  (return-type "none") -  (parameters -    '("gboolean" "enable") -  ) -) - -(define-method get_enable_search_highlighting -  (of-object "PlumaDocument") -  (c-name "pluma_document_get_enable_search_highlighting") -  (return-type "gboolean") -) - -;; From ../../pluma/pluma-encodings.h - -(define-function pluma_encoding_get_type -  (c-name "pluma_encoding_get_type") -  (return-type "GType") -) - -(define-method copy -  (of-object "PlumaEncoding") -  (c-name "pluma_encoding_copy") -  (return-type "PlumaEncoding*") -) - -(define-method free -  (of-object "PlumaEncoding") -  (c-name "pluma_encoding_free") -  (return-type "none") -) - -(define-function encoding_get_from_charset -  (c-name "pluma_encoding_get_from_charset") -  (return-type "const-PlumaEncoding*") -  (parameters -    '("const-gchar*" "charset") -  ) -) - -; Deprecated version ! -(define-function pluma_encoding_get_from_charset -  (c-name "pluma_encoding_get_from_charset_deprecated") -  (return-type "const-PlumaEncoding*") -  (parameters -    '("const-gchar*" "charset") -  ) -) - -(define-function encoding_get_from_index -  (c-name "pluma_encoding_get_from_index") -  (return-type "const-PlumaEncoding*") -  (parameters -    '("gint" "index") -  ) -) - -; Deprecated version ! -(define-function pluma_encoding_get_from_index -  (c-name "pluma_encoding_get_from_index_deprecated") -  (return-type "const-PlumaEncoding*") -  (parameters -    '("gint" "index") -  ) -) - -(define-method to_string -  (of-object "PlumaEncoding") -  (c-name "pluma_encoding_to_string") -  (return-type "gchar*") -) - -(define-method get_name -  (of-object "PlumaEncoding") -  (c-name "pluma_encoding_get_name") -  (return-type "const-gchar*") -) - -(define-method get_charset -  (of-object "PlumaEncoding") -  (c-name "pluma_encoding_get_charset") -  (return-type "const-gchar*") -) - -(define-function encoding_get_utf8 -  (c-name "pluma_encoding_get_utf8") -  (return-type "const-PlumaEncoding*") -) - -; Deprecated version ! -(define-function pluma_encoding_get_utf8 -  (c-name "pluma_encoding_get_utf8_deprecated") -  (return-type "const-PlumaEncoding*") -) - -(define-function encoding_get_current -  (c-name "pluma_encoding_get_current") -  (return-type "const-PlumaEncoding*") -) - -; Deprecated version ! -(define-function pluma_encoding_get_current -  (c-name "pluma_encoding_get_current_deprecated") -  (return-type "const-PlumaEncoding*") -) - -;; From ../../pluma/pluma-help.h - -(define-function help_display -  (c-name "pluma_help_display") -  (return-type "gboolean") -  (parameters -    '("GtkWindow*" "parent") -    '("const-gchar*" "name") -    '("const-gchar*" "link_id") -  ) -) - - - -;; From ../../pluma/pluma-panel.h - -(define-function pluma_panel_get_type -  (c-name "pluma_panel_get_type") -  (return-type "GType") -) - -(define-function pluma_panel_new -  (c-name "pluma_panel_new") -  (is-constructor-of "PlumaPanel") -  (return-type "GtkWidget*") -) - -(define-method add_item -  (of-object "PlumaPanel") -  (c-name "pluma_panel_add_item") -  (return-type "none") -  (parameters -    '("GtkWidget*" "item") -    '("const-gchar*" "name") -    '("GtkWidget*" "image") -  ) -) - -(define-method add_item_with_stock_icon -  (of-object "PlumaPanel") -  (c-name "pluma_panel_add_item_with_stock_icon") -  (return-type "none") -  (parameters -    '("GtkWidget*" "item") -    '("const-gchar*" "name") -    '("const-gchar*" "stock_id") -  ) -) - -(define-method remove_item -  (of-object "PlumaPanel") -  (c-name "pluma_panel_remove_item") -  (return-type "gboolean") -  (parameters -    '("GtkWidget*" "item") -  ) -) - -(define-method activate_item -  (of-object "PlumaPanel") -  (c-name "pluma_panel_activate_item") -  (return-type "gboolean") -  (parameters -    '("GtkWidget*" "item") -  ) -) - -(define-method item_is_active -  (of-object "PlumaPanel") -  (c-name "pluma_panel_item_is_active") -  (return-type "gboolean") -  (parameters -    '("GtkWidget*" "item") -  ) -) - -(define-method get_orientation -  (of-object "PlumaPanel") -  (c-name "pluma_panel_get_orientation") -  (return-type "GtkOrientation") -) - -(define-method get_n_items -  (of-object "PlumaPanel") -  (c-name "pluma_panel_get_n_items") -  (return-type "gint") -) - - -;; From ../../pluma/pluma-plugin.h - -(define-function pluma_plugin_get_type -  (c-name "pluma_plugin_get_type") -  (return-type "GType") -) - -(define-method get_install_dir -  (of-object "PlumaPlugin") -  (c-name "pluma_plugin_get_install_dir") -  (return-type "gchar*") -) - -(define-method get_data_dir -  (of-object "PlumaPlugin") -  (c-name "pluma_plugin_get_data_dir") -  (return-type "gchar*") -) - -(define-method activate -  (of-object "PlumaPlugin") -  (c-name "pluma_plugin_activate") -  (return-type "none") -  (parameters -    '("PlumaWindow*" "window") -  ) -) - -(define-method deactivate -  (of-object "PlumaPlugin") -  (c-name "pluma_plugin_deactivate") -  (return-type "none") -  (parameters -    '("PlumaWindow*" "window") -  ) -) - -(define-method update_ui -  (of-object "PlumaPlugin") -  (c-name "pluma_plugin_update_ui") -  (return-type "none") -  (parameters -    '("PlumaWindow*" "window") -  ) -) - -(define-method is_configurable -  (of-object "PlumaPlugin") -  (c-name "pluma_plugin_is_configurable") -  (return-type "gboolean") -) - -(define-method create_configure_dialog -  (of-object "PlumaPlugin") -  (c-name "pluma_plugin_create_configure_dialog") -  (return-type "GtkWidget*") -) - -;; From ../pluma/pluma-plugin-python.h - -(define-function pluma_plugin_python_get_type -  (c-name "pluma_plugin_python_get_type") -  (return-type "GType") -) - -(define-function pluma_plugin_python_new -  (c-name "pluma_plugin_python_new") -  (is-constructor-of "PlumaPluginPython") -  (return-type "PlumaPluginPython*") -) - -;; From ../../pluma/pluma-status-bar.h - -(define-method flash_message -  (of-object "PlumaStatusbar") -  (c-name "pluma_statusbar_flash_message") -  (return-type "none") -  (parameters -    '("int" "context_id") -    '("const-gchar*" "message") -  ) - ) - -;; From ../../pluma/pluma-tab.h - -(define-function pluma_tab_get_type -  (c-name "pluma_tab_get_type") -  (return-type "GType") -) - -(define-method get_view -  (of-object "PlumaTab") -  (c-name "pluma_tab_get_view") -  (return-type "PlumaView*") -) - -(define-method get_document -  (of-object "PlumaTab") -  (c-name "pluma_tab_get_document") -  (return-type "PlumaDocument*") -) - -(define-function tab_get_from_document -  (c-name "pluma_tab_get_from_document") -  (return-type "PlumaTab*") -  (parameters -    '("PlumaDocument*" "doc") -  ) -) - -; Deprecated version ! -(define-function pluma_tab_get_from_document -  (c-name "pluma_tab_get_from_document_deprecated") -  (return-type "PlumaTab*") -  (parameters -    '("PlumaDocument*" "doc") -  ) -) - -(define-method get_state -  (of-object "PlumaTab") -  (c-name "pluma_tab_get_state") -  (return-type "PlumaTabState") -) - -(define-method set_auto_save_enabled -  (of-object "PlumaTab") -  (c-name "pluma_tab_set_auto_save_enabled") -  (return-type "none") -  (parameters -    '("gboolean" "enable") -  ) -) - -(define-method get_auto_save_enabled -  (of-object "PlumaTab") -  (c-name "pluma_tab_get_auto_save_enabled") -  (return-type "gboolean") -) - -(define-method set_auto_save_interval -  (of-object "PlumaTab") -  (c-name "pluma_tab_set_auto_save_interval") -  (return-type "none") -  (parameters -    '("gint" "interval") -  ) -) - -(define-method get_auto_save_interval -  (of-object "PlumaTab") -  (c-name "pluma_tab_get_auto_save_interval") -  (return-type "gint") -) - -;; From ../../pluma/pluma-view.h - -(define-function pluma_view_get_type -  (c-name "pluma_view_get_type") -  (return-type "GtkType") -) - -(define-function pluma_view_new -  (c-name "pluma_view_new") -  (is-constructor-of "PlumaView") -  (return-type "GtkWidget*") -  (parameters -    '("PlumaDocument*" "doc") -  ) -) - -(define-method cut_clipboard -  (of-object "PlumaView") -  (c-name "pluma_view_cut_clipboard") -  (return-type "none") -) - -(define-method copy_clipboard -  (of-object "PlumaView") -  (c-name "pluma_view_copy_clipboard") -  (return-type "none") -) - -(define-method paste_clipboard -  (of-object "PlumaView") -  (c-name "pluma_view_paste_clipboard") -  (return-type "none") -) - -(define-method delete_selection -  (of-object "PlumaView") -  (c-name "pluma_view_delete_selection") -  (return-type "none") -) - -(define-method select_all -  (of-object "PlumaView") -  (c-name "pluma_view_select_all") -  (return-type "none") -) - -(define-method scroll_to_cursor -  (of-object "PlumaView") -  (c-name "pluma_view_scroll_to_cursor") -  (return-type "none") -) - -(define-method set_font -  (of-object "PlumaView") -  (c-name "pluma_view_set_font") -  (return-type "none") -  (parameters -    '("gboolean" "def") -    '("const-gchar*" "font_name") -  ) -) - - - -;; From ../../pluma/pluma-window.h - -(define-function pluma_window_get_type -  (c-name "pluma_window_get_type") -  (return-type "GType") -) - -(define-method create_tab -  (of-object "PlumaWindow") -  (c-name "pluma_window_create_tab") -  (return-type "PlumaTab*") -  (parameters -    '("gboolean" "jump_to") -  ) -) - -(define-method create_tab_from_uri -  (of-object "PlumaWindow") -  (c-name "pluma_window_create_tab_from_uri") -  (return-type "PlumaTab*") -  (parameters -    '("const-gchar*" "uri") -    '("const-PlumaEncoding*" "encoding" (null-ok)) -    '("gint" "line_pos") -    '("gboolean" "create") -    '("gboolean" "jump_to") -  ) -) - -(define-method close_tab -  (of-object "PlumaWindow") -  (c-name "pluma_window_close_tab") -  (return-type "none") -  (parameters -    '("PlumaTab*" "tab") -  ) -) - -(define-method close_tabs -  (of-object "PlumaWindow") -  (c-name "pluma_window_close_tabs") -  (return-type "none") -  (parameters -    '("const-GList*" "tabs") -  ) -) - -(define-method close_all_tabs -  (of-object "PlumaWindow") -  (c-name "pluma_window_close_all_tabs") -  (return-type "none") -) - -(define-method get_active_tab -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_active_tab") -  (return-type "PlumaTab*") -) - -(define-method set_active_tab -  (of-object "PlumaWindow") -  (c-name "pluma_window_set_active_tab") -  (return-type "none") -  (parameters -    '("PlumaTab*" "tab") -  ) -) - -(define-method get_active_view -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_active_view") -  (return-type "PlumaView*") -) - -(define-method get_active_document -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_active_document") -  (return-type "PlumaDocument*") -) - -(define-method get_documents -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_documents") -  (return-type "GList*") -) - -(define-method get_unsaved_documents -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_unsaved_documents") -  (return-type "GList*") -) - -(define-method get_views -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_views") -  (return-type "GList*") -) - -(define-method get_group -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_group") -  (return-type "GtkWindowGroup*") -) - -(define-method get_side_panel -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_side_panel") -  (return-type "PlumaPanel*") -) - -(define-method get_bottom_panel -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_bottom_panel") -  (return-type "PlumaPanel*") -) - -(define-method get_statusbar -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_statusbar") -  (return-type "GtkWidget*") -) - -(define-method get_ui_manager -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_ui_manager") -  (return-type "GtkUIManager*") -) - -(define-method get_state -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_state") -  (return-type "PlumaWindowState") -) - -(define-method get_message_bus -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_message_bus") -  (return-type "PlumaMessageBus*") -) - -(define-method get_tab_from_uri -  (of-object "PlumaWindow") -  (c-name "pluma_window_get_tab_from_uri") -  (return-type "PlumaTab*") -  (parameters -    '("const-gchar*" "uri") -  ) -) - -;; From pluma-language-manager.h - -(define-function get_language_manager -  (c-name "pluma_get_language_manager") -  (return-type "GtkSourceLanguageManager*") -) - -(define-function language_manager_list_languages_sorted -  (c-name "pluma_language_manager_list_languages_sorted") -  (return-type "GSList*") -  (parameters -    '("GtkSourceLanguageManager*" "lm") -    '("gboolean" "include_hidden") -  ) -) - - -;; From pluma-message-bus.h - -(define-function pluma_message_bus_get_type -  (c-name "pluma_message_bus_get_type") -  (return-type "GType") -) - -(define-function message_bus_get_default -  (c-name "pluma_message_bus_get_default") -  (return-type "PlumaMessageBus*") -) - -(define-function pluma_message_bus_new -  (c-name "pluma_message_bus_new") -  (is-constructor-of "PlumaMessageBus") -  (return-type "PlumaMessageBus*") -) - -(define-method lookup -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_lookup") -  (return-type "PlumaMessageType*") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -  ) -) - -(define-method register -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_register") -  (return-type "PlumaMessageType*") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -    '("guint" "num_optional") -  ) -  (varargs #t) -) - -(define-method unregister -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_unregister") -  (return-type "none") -  (parameters -    '("PlumaMessageType*" "message_type") -  ) -) - -(define-method unregister_all -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_unregister_all") -  (return-type "none") -  (parameters -    '("const-gchar*" "object_path") -  ) -) - -(define-method is_registered -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_is_registered") -  (return-type "gboolean") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -  ) -) - -(define-method connect -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_connect") -  (return-type "guint") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -    '("PlumaMessageCallback" "callback") -    '("gpointer" "userdata") -    '("GDestroyNotify" "destroy_data") -  ) -) - -(define-method disconnect -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_disconnect") -  (return-type "none") -  (parameters -    '("guint" "id") -  ) -) - -(define-method disconnect_by_func -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_disconnect_by_func") -  (return-type "none") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -    '("PlumaMessageCallback" "callback") -    '("gpointer" "userdata") -  ) -) - -(define-method block -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_block") -  (return-type "none") -  (parameters -    '("guint" "id") -  ) -) - -(define-method block_by_func -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_block_by_func") -  (return-type "none") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -    '("PlumaMessageCallback" "callback") -    '("gpointer" "userdata") -  ) -) - -(define-method unblock -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_unblock") -  (return-type "none") -  (parameters -    '("guint" "id") -  ) -) - -(define-method unblock_by_func -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_unblock_by_func") -  (return-type "none") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -    '("PlumaMessageCallback" "callback") -    '("gpointer" "userdata") -  ) -) - -(define-method send_message -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_send_message") -  (return-type "none") -  (parameters -    '("PlumaMessage*" "message") -  ) -) - -(define-method send_message_sync -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_send_message_sync") -  (return-type "none") -  (parameters -    '("PlumaMessage*" "message") -  ) -) - -(define-method send -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_send") -  (return-type "none") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -  ) -  (varargs #t) -) - -(define-method send_sync -  (of-object "PlumaMessageBus") -  (c-name "pluma_message_bus_send_sync") -  (return-type "PlumaMessage*") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -  ) -  (varargs #t) -) - - -;; From pluma-message-type.h - -(define-function pluma_message_type_get_type -  (c-name "pluma_message_type_get_type") -  (return-type "GType") -) - -(define-function pluma_message_type_is_supported -  (c-name "pluma_message_type_is_supported") -  (return-type "gboolean") -  (parameters -    '("GType" "type") -  ) -) - -(define-function pluma_message_type_identifier -  (c-name "pluma_message_type_identifier") -  (return-type "gchar*") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -  ) -) - -(define-function pluma_message_type_new -  (c-name "pluma_message_type_new") -  (is-constructor-of "PlumaMessageType") -  (return-type "PlumaMessageType*") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -    '("guint" "num_optional") -  ) -  (varargs #t) -) - -(define-function pluma_message_type_new_valist -  (c-name "pluma_message_type_new_valist") -  (return-type "PlumaMessageType*") -  (parameters -    '("const-gchar*" "object_path") -    '("const-gchar*" "method") -    '("guint" "num_optional") -    '("va_list" "va_args") -  ) -) - -(define-method ref -  (of-object "PlumaMessageType") -  (c-name "pluma_message_type_ref") -  (return-type "PlumaMessageType*") -) - -(define-method unref -  (of-object "PlumaMessageType") -  (c-name "pluma_message_type_unref") -  (return-type "none") -) - -(define-method instantiate_valist -  (of-object "PlumaMessageType") -  (c-name "pluma_message_type_instantiate_valist") -  (return-type "PlumaMessage*") -  (parameters -    '("va_list" "va_args") -  ) -) - -(define-method instantiate -  (of-object "PlumaMessageType") -  (c-name "pluma_message_type_instantiate") -  (return-type "PlumaMessage*") -  (parameters -  ) -  (varargs #t) -) - -(define-method get_object_path -  (of-object "PlumaMessageType") -  (c-name "pluma_message_type_get_object_path") -  (return-type "const-gchar*") -) - -(define-method get_method -  (of-object "PlumaMessageType") -  (c-name "pluma_message_type_get_method") -  (return-type "const-gchar*") -) - -(define-method lookup -  (of-object "PlumaMessageType") -  (c-name "pluma_message_type_lookup") -  (return-type "GType") -  (parameters -    '("const-gchar*" "key") -  ) -) - -(define-method foreach -  (of-object "PlumaMessageType") -  (c-name "pluma_message_type_foreach") -  (return-type "none") -  (parameters -    '("PlumaMessageTypeForeach" "func") -    '("gpointer" "user_data") -  ) -) - - -;; From pluma-message.h - -(define-function pluma_message_get_type -  (c-name "pluma_message_get_type") -  (return-type "GType") -) - -(define-method get -  (of-object "PlumaMessage") -  (c-name "pluma_message_get") -  (return-type "none") -  (parameters -  ) -  (varargs #t) -) - -(define-method get_valist -  (of-object "PlumaMessage") -  (c-name "pluma_message_get_valist") -  (return-type "none") -  (parameters -    '("va_list" "var_args") -  ) -) - -(define-method get_value -  (of-object "PlumaMessage") -  (c-name "pluma_message_get_value") -  (return-type "none") -  (parameters -    '("const-gchar*" "key") -    '("GValue*" "value") -  ) -) - -(define-method set -  (of-object "PlumaMessage") -  (c-name "pluma_message_set") -  (return-type "none") -  (parameters -  ) -  (varargs #t) -) - -(define-method set_valist -  (of-object "PlumaMessage") -  (c-name "pluma_message_set_valist") -  (return-type "none") -  (parameters -    '("va_list" "var_args") -  ) -) - -(define-method set_value -  (of-object "PlumaMessage") -  (c-name "pluma_message_set_value") -  (return-type "none") -  (parameters -    '("const-gchar*" "key") -    '("GValue*" "value") -  ) -) - -(define-method set_valuesv -  (of-object "PlumaMessage") -  (c-name "pluma_message_set_valuesv") -  (return-type "none") -  (parameters -    '("const-gchar**" "keys") -    '("GValue*" "values") -    '("gint" "n_values") -  ) -) - -(define-method get_object_path -  (of-object "PlumaMessage") -  (c-name "pluma_message_get_object_path") -  (return-type "const-gchar*") -) - -(define-method get_method -  (of-object "PlumaMessage") -  (c-name "pluma_message_get_method") -  (return-type "const-gchar*") -) - -(define-method has_key -  (of-object "PlumaMessage") -  (c-name "pluma_message_has_key") -  (return-type "gboolean") -  (parameters -    '("const-gchar*" "key") -  ) -) - -(define-method get_key_type -  (of-object "PlumaMessage") -  (c-name "pluma_message_get_key_type") -  (return-type "GType") -  (parameters -    '("const-gchar*" "key") -  ) -) - -(define-method validate -  (of-object "PlumaMessage") -  (c-name "pluma_message_validate") -  (return-type "gboolean") -) - - -;; From ../../pluma/pluma-debug.h - -(define-function debug -  (c-name "pluma_debug") -  (parameters -    '("const-gchar*" "message") -  ) -  (return-type "none") -) - diff --git a/plugin-loaders/python/bindings/pluma.override b/plugin-loaders/python/bindings/pluma.override deleted file mode 100644 index 3de7c069..00000000 --- a/plugin-loaders/python/bindings/pluma.override +++ /dev/null @@ -1,461 +0,0 @@ -%% -headers -#include <pygobject.h> -#include <pygtk/pygtk.h> - -#include <pluma/pluma-language-manager.h> -#include <pluma/pluma-plugin.h> -#include <pluma/pluma-app.h> -#include <pluma/pluma-encodings.h> -#include <pluma/pluma-enum-types.h> -#include <pluma/pluma-statusbar.h> -#include <pluma/pluma-debug.h> -#include <pluma/pluma-help.h> - -#include "pluma-plugin-python.h" - -void pypluma_register_classes (PyObject *d);  -void pypluma_add_constants (PyObject *module, const gchar *strip_prefix); - -static PyObject * -_helper_wrap_gobject_glist (const GList *list) -{ -    PyObject *py_list; -    const GList *tmp; - -    if ((py_list = PyList_New(0)) == NULL) { -        return NULL; -    } -    for (tmp = list; tmp != NULL; tmp = tmp->next) { -        PyObject *py_obj = pygobject_new(G_OBJECT(tmp->data)); - -        if (py_obj == NULL) { -            Py_DECREF(py_list); -            return NULL; -        } -        PyList_Append(py_list, py_obj); -        Py_DECREF(py_obj); -    } -    return py_list; -} - -static PyObject * -_helper_wrap_gobject_gslist (const GSList *list) -{ -    PyObject *py_list; -    const GSList *tmp; - -    if ((py_list = PyList_New(0)) == NULL) { -        return NULL; -    } -    for (tmp = list; tmp != NULL; tmp = tmp->next) { -        PyObject *py_obj = pygobject_new(G_OBJECT(tmp->data)); - -        if (py_obj == NULL) { -            Py_DECREF(py_list); -            return NULL; -        } -        PyList_Append(py_list, py_obj); -        Py_DECREF(py_obj); -    } -    return py_list; -} -%% -include -  plumaplugin.override -  plumamessage.override -%% -modulename pluma  -%% -import gtk.Widget as PyGtkWidget_Type -import gobject.GObject as PyGObject_Type -import gtk.gdk.Screen as PyGdkScreen_Type -import gtk.VBox as PyGtkVBox_Type -import gtk.Window as PyGtkWindow_Type -import gtk.Image as PyGtkImage_Type -import gtk.Statusbar as PyGtkStatusbar_Type -import gtksourceview2.Buffer as PyGtkSourceBuffer_Type -import gtksourceview2.View as PyGtkSourceView_Type -import gtksourceview2.Language as PyGtkSourceLanguage_Type -import gtksourceview2.LanguageManager as PyGtkSourceLanguageManager_Type -%% -ignore-glob -  *_get_type -  pluma_document_error_quark -  pluma_panel_add_item_with_stock_icon -%% -override pluma_app_create_window kwargs -static PyObject * -_wrap_pluma_app_create_window(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    static char *kwlist[] = { "screen", NULL}; -    PyGObject *screen = NULL; -    PlumaWindow *ret; - -    if (!PyArg_ParseTupleAndKeywords(args, kwargs, -			"|O!", kwlist, -			&PyGdkScreen_Type, &screen)) -        return NULL; - -    ret = pluma_app_create_window(PLUMA_APP(self->obj), -				  screen ? GDK_SCREEN(screen->obj) : NULL); - -    /* pygobject_new handles NULL checking */ -    return pygobject_new((GObject *)ret); -} -%% -override pluma_app_get_windows -static PyObject * -_wrap_pluma_app_get_windows(PyGObject *self) -{ -    const GList *list; -    PyObject *py_list; - -    list = pluma_app_get_windows (PLUMA_APP (self->obj)); - -    py_list = _helper_wrap_gobject_glist (list); - -    return py_list; -} -%% -override pluma_app_get_views -static PyObject * -_wrap_pluma_app_get_views(PyGObject *self) -{ -    GList *list; -    PyObject *py_list; - -    list = pluma_app_get_views (PLUMA_APP (self->obj)); - -    py_list = _helper_wrap_gobject_glist (list); - -    g_list_free (list); - -    return py_list; -} -%% -override pluma_app_get_documents -static PyObject * -_wrap_pluma_app_get_documents(PyGObject *self) -{ -    GList *list; -    PyObject *py_list; - -    list = pluma_app_get_documents (PLUMA_APP (self->obj)); - -    py_list = _helper_wrap_gobject_glist (list); - -    g_list_free (list); - -    return py_list; -} -%% -override pluma_window_get_documents -static PyObject * -_wrap_pluma_window_get_documents(PyGObject *self) -{ -    GList *list; -    PyObject *py_list; - -    list = pluma_window_get_documents (PLUMA_WINDOW (self->obj)); - -    py_list = _helper_wrap_gobject_glist (list); - -    g_list_free(list); - -    return py_list; -} -%% -override pluma_window_get_unsaved_documents -static PyObject * -_wrap_pluma_window_get_unsaved_documents(PyGObject *self) -{ -    GList *list; -    PyObject *py_list; - -    list = pluma_window_get_unsaved_documents (PLUMA_WINDOW (self->obj)); - -    py_list = _helper_wrap_gobject_glist (list); - -    g_list_free(list); - -    return py_list; -} -%% -override pluma_window_get_views -static PyObject * -_wrap_pluma_window_get_views(PyGObject *self) -{ -    GList *list; -    PyObject *py_list; - -    list = pluma_window_get_views (PLUMA_WINDOW (self->obj)); - -    py_list = _helper_wrap_gobject_glist (list); - -    g_list_free(list); - -    return py_list; -} -%% -override pluma_window_close_tabs kwargs -static PyObject * -_wrap_pluma_window_close_tabs (PyGObject *self, -			       PyObject  *args, -			       PyObject  *kwargs) -{ -	static char *kwlist[] = { "tabs", NULL }; -	PyObject *list, *item; -	GList *glist = NULL; -	int len, i; - -	if (!PyArg_ParseTupleAndKeywords (args, kwargs, -					  "O:PlumaWindow.close_tabs", kwlist, -					  &list)) -		return NULL; - -	if (!PySequence_Check (list)) -	{ -		PyErr_SetString (PyExc_TypeError, -				 "first argument must be a sequence"); -		return NULL; -	} - -	len = PySequence_Length (list); - -	for (i = 0; i < len; i++) -	{ -		item = PySequence_GetItem (list, i); -		Py_DECREF(item); - -		if (!pygobject_check (item, &PyPlumaTab_Type)) -		{ -			PyErr_SetString (PyExc_TypeError, -					 "sequence item not a Gtkwidget object"); -			g_list_free (glist); -			return NULL; -		} - -		glist = g_list_append (glist, pygobject_get (item)); -	} - -	pluma_window_close_tabs (PLUMA_WINDOW (self->obj), glist); - -	g_list_free (glist); -	Py_INCREF (Py_None); -	return Py_None; -} -%% -override pluma_document_get_search_text -static PyObject * -_wrap_pluma_document_get_search_text(PyGObject *self) -{ -    PyObject *tuple, *string; -    guint flags; -    gchar *ret; - -    ret = pluma_document_get_search_text (PLUMA_DOCUMENT (self->obj), &flags); - -    tuple = PyTuple_New(2); -    if (ret) { -        string = PyString_FromString(ret); -        PyTuple_SetItem(tuple, 0, string); -    } else { -        Py_INCREF(Py_None); -        PyTuple_SetItem(tuple, 0, Py_None); -    } -    PyTuple_SetItem(tuple, 1, PyInt_FromLong(flags)); - -    g_free(ret); - -    return tuple; -} -%% -override pluma_panel_add_item kwargs -static PyObject * -_wrap_pluma_panel_add_item(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    static char *kwlist1[] = { "item", "name", "image", NULL }; -    static char *kwlist2[] = { "item", "name", "stock_id", NULL }; -    PyGObject *item, *image; -    char *name = NULL; -    char *stock_id = NULL; - -    if (PyArg_ParseTupleAndKeywords(args, kwargs, "O!sO!:PlumaPanel.add_item", kwlist1, &PyGtkWidget_Type, &item, &name, &PyGtkImage_Type, &image)) { -        pluma_panel_add_item(PLUMA_PANEL(self->obj), GTK_WIDGET(item->obj), name, GTK_WIDGET(image->obj)); -        Py_INCREF(Py_None); -        return Py_None; -    } - -    PyErr_Clear(); - -    if (PyArg_ParseTupleAndKeywords(args, kwargs, "O!ss:PlumaPanel.add_item", kwlist2, &PyGtkWidget_Type, &item, &name, &stock_id)) { -        pluma_panel_add_item_with_stock_icon(PLUMA_PANEL(self->obj), GTK_WIDGET(item->obj), name, stock_id); -        Py_INCREF(Py_None); -        return Py_None; -    } - -    PyErr_Clear(); -    PyErr_SetString(PyExc_TypeError, "the last arg should be either a gtk.Image or a stock_id string"); -    return NULL; -} -%% -override pluma_app_get_default_deprecated -/* deprecated wrappers */ -static PyObject * -_wrap_pluma_app_get_default_deprecated(PyObject *self) -{ -    if (PyErr_Warn(PyExc_DeprecationWarning, "use pluma.app_get_default instead") < 0) -	return NULL; -    return _wrap_pluma_app_get_default(self); -} -%% -override pluma_encoding_get_from_charset_deprecated kwargs -static PyObject * -_wrap_pluma_encoding_get_from_charset_deprecated(PyObject *self, PyObject *args, PyObject *kwargs) -{ -    if (PyErr_Warn(PyExc_DeprecationWarning, "use pluma.encoding_get_from_charset instead") < 0) -	return NULL; -    return _wrap_pluma_encoding_get_from_charset(self, args, kwargs); -} -%% -override pluma_encoding_get_from_index_deprecated kwargs -static PyObject * -_wrap_pluma_encoding_get_from_index_deprecated(PyObject *self, PyObject *args, PyObject *kwargs) -{ -    if (PyErr_Warn(PyExc_DeprecationWarning, "use pluma.encoding_get_from_index instead") < 0) -	return NULL; -    return _wrap_pluma_encoding_get_from_index(self, args, kwargs); -} -%% -override pluma_encoding_get_utf8_deprecated -static PyObject * -_wrap_pluma_encoding_get_utf8_deprecated(PyObject *self) -{ -    if (PyErr_Warn(PyExc_DeprecationWarning, "use pluma.encoding_get_utf8 instead") < 0) -	return NULL; -    return _wrap_pluma_encoding_get_utf8(self); -} -%% -override pluma_encoding_get_current_deprecated -static PyObject * -_wrap_pluma_encoding_get_current_deprecated(PyObject *self) -{ -    if (PyErr_Warn(PyExc_DeprecationWarning, "use pluma.encoding_get_current instead") < 0) -	return NULL; -    return _wrap_pluma_encoding_get_current(self); -} -%% -override pluma_tab_get_from_document_deprecated kwargs -static PyObject * -_wrap_pluma_tab_get_from_document_deprecated(PyObject *self, PyObject *args, PyObject *kwargs) -{ -    if (PyErr_Warn(PyExc_DeprecationWarning, "use pluma.tab_get_from_document instead") < 0) -	return NULL; -    return _wrap_pluma_tab_get_from_document(self, args, kwargs); -} -%% -override pluma_language_manager_list_languages_sorted kwargs -static PyObject * -_wrap_pluma_language_manager_list_languages_sorted(PyObject *self, PyObject *args, PyObject *kwargs) -{ -    static char *kwlist[] = { "lm", "include_hidden", NULL }; -    PyGObject *lm; -    int include_hidden; -    PyObject *py_list; -    GSList *list; - -    if (!PyArg_ParseTupleAndKeywords (args, kwargs, -                                      "O!i:language_manager_list_languages_sorted", -                                      kwlist, &PyGtkSourceLanguageManager_Type, &lm, -                                      &include_hidden)) -        return NULL; - -    list = pluma_language_manager_list_languages_sorted (GTK_SOURCE_LANGUAGE_MANAGER (lm->obj), -                                                         include_hidden); - -    py_list = _helper_wrap_gobject_gslist (list); - -    g_slist_free (list); - -    return py_list; -} -%% -override pluma_debug kwargs -static PyObject * -_wrap_pluma_debug(PyObject *self, PyObject *args, PyObject *kwargs) -{ -    static char *kwlist[] = { "message", NULL }; -    PyObject *traceback_module, *mdict, *func, *traceback, *tuple; -    PyObject *filename, *lineno, *funcname; -    char *message = NULL; - -    if (g_getenv ("PLUMA_DEBUG_PLUGINS") == NULL) -    { -        Py_INCREF (Py_None); -        return Py_None; -    } - -    if (!PyArg_ParseTupleAndKeywords (args, kwargs, "|s", kwlist, &message)) -        return NULL; - -    traceback_module = PyImport_ImportModule ("traceback"); -    if (traceback_module == NULL) -    { -        g_warning ("traceback module cannot be imported"); -        Py_INCREF (Py_None); -        return Py_None; -    } - -    mdict = PyModule_GetDict (traceback_module); -    func = PyDict_GetItemString (mdict, "extract_stack"); -    traceback = PyObject_CallFunction (func, "zi", NULL, 1); -    tuple = PyList_GetItem (traceback, 0); - -    if (tuple == NULL || !PyTuple_Check (tuple)) -    { -        g_warning ("traceback tuple is null!"); -    } -    else -    { -        filename = PyTuple_GetItem (tuple, 0); -        lineno = PyTuple_GetItem (tuple, 1); -        funcname = PyTuple_GetItem (tuple, 2); - -        if (message == NULL) -            pluma_debug (PLUMA_DEBUG_PLUGINS, -                         PyString_AsString (filename), -                         PyInt_AsLong (lineno), -                         PyString_AsString (funcname)); -        else -            pluma_debug_message (PLUMA_DEBUG_PLUGINS, -                                 PyString_AsString (filename), -                                 PyInt_AsLong (lineno), -                                 PyString_AsString (funcname), -                                 "%s", -                                 message); -    } -    Py_DECREF (traceback); -    Py_DECREF (traceback_module); - -    Py_INCREF (Py_None); -    return Py_None; -} -%% -override pluma_statusbar_flash_message kwargs -static PyObject * -_wrap_pluma_statusbar_flash_message(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    static char *kwlist[] = { "context_id", "message", NULL }; -    int context_id; -    char *message; - -    if (!PyArg_ParseTupleAndKeywords(args, kwargs,"is:PlumaStatusbar.flash_message", kwlist, &context_id, &message)) -        return NULL; -    -    pluma_statusbar_flash_message(PLUMA_STATUSBAR(self->obj), context_id, "%s", message); - -    Py_INCREF(Py_None); -    return Py_None; -} -%% diff --git a/plugin-loaders/python/bindings/plumacommands.defs b/plugin-loaders/python/bindings/plumacommands.defs deleted file mode 100644 index 241b52d6..00000000 --- a/plugin-loaders/python/bindings/plumacommands.defs +++ /dev/null @@ -1,45 +0,0 @@ -;; -*- scheme -*- -; object definitions ... -;; Enumerations and flags ... - - -;; From ../../pluma/pluma-commands.h - -(define-function load_uri -  (c-name "pluma_commands_load_uri") -  (return-type "none") -  (parameters -    '("PlumaWindow*" "window") -    '("const-gchar*" "uri") -    '("const-PlumaEncoding*" "encoding") -    '("gint" "line_pos") -  ) -) - -(define-function load_uris -  (c-name "pluma_commands_load_uris") -  (return-type "gint") -  (parameters -    '("PlumaWindow*" "window") -    '("const-GSList*" "uris") -    '("const-PlumaEncoding*" "encoding") -    '("gint" "line_pos") -  ) -) - -(define-function save_document -  (c-name "pluma_commands_save_document") -  (return-type "none") -  (parameters -    '("PlumaWindow*" "window") -    '("PlumaDocument*" "document") -  ) -) - -(define-function save_all_documents -  (c-name "pluma_commands_save_all_documents") -  (return-type "none") -  (parameters -    '("PlumaWindow*" "window") -  ) -) diff --git a/plugin-loaders/python/bindings/plumacommands.override b/plugin-loaders/python/bindings/plumacommands.override deleted file mode 100644 index 9713b5e0..00000000 --- a/plugin-loaders/python/bindings/plumacommands.override +++ /dev/null @@ -1,122 +0,0 @@ -%% -headers -#define NO_IMPORT_PYGOBJECT -#define NO_IMPORT_PYGTK -#include <pygobject.h> -#include <pygtk/pygtk.h> - -#include "pluma-commands.h" -#include "pluma-window.h" - -void pyplumacommands_register_classes (PyObject *d); -void pyplumacommands_add_constants (PyObject *module, const gchar *strip_prefix); - -%% -modulename pluma.commands -%% -import pluma.Window as PyPlumaWindow_Type -import pluma.Document as PyPlumaDocument_Type -%% -ignore-glob -  _* -%% -override pluma_commands_load_uri kwargs  -static PyObject * -_wrap_pluma_commands_load_uri (PyObject *self, PyObject *args, PyObject *kwargs) -{ -	static char *kwlist[] = { "window", "uri", "encoding", "line_pos", NULL }; -	PyGObject *window; -	char *uri; -	int line_pos = 0; -	PyObject *py_encoding = NULL; -	PlumaEncoding *encoding = NULL; - -	if (!PyArg_ParseTupleAndKeywords (args, kwargs, "O!s|Oi:load_uri",  -	                                  kwlist, &PyPlumaWindow_Type,  -	                                  &window, &uri, &py_encoding,  -	                                  &line_pos)) -		return NULL; -     -	if (py_encoding != NULL && py_encoding != Py_None) -	{ -		if (pyg_boxed_check (py_encoding, PLUMA_TYPE_ENCODING)) -			encoding = pyg_boxed_get (py_encoding, PlumaEncoding); -		else -		{ -			PyErr_SetString (PyExc_TypeError,  -			                 "encoding should be a PlumaEncoding"); -			return NULL; -		} -	} - -	pluma_commands_load_uri (PLUMA_WINDOW (window->obj), uri, encoding,  -	                        line_pos); -	Py_INCREF (Py_None); -	return Py_None; -} -%% -override pluma_commands_load_uris kwargs  -static PyObject * -_wrap_pluma_commands_load_uris (PyObject *self, PyObject *args, PyObject *kwargs) -{ -	static char *kwlist[] = { "window", "uris", "encoding", "line_pos", NULL }; -	PyGObject *window; -	GSList *uris = NULL; -	int line_pos = 0; -	PyObject *py_encoding = NULL; -	PyObject *list; -	PyObject *item; -	PlumaEncoding *encoding = NULL; -	int len; -	int i; - -	if (!PyArg_ParseTupleAndKeywords (args, kwargs, "O!O|Oi:load_uri",  -	                                  kwlist, &PyPlumaWindow_Type,  -	                                  &window, &list, &py_encoding,  -	                                  &line_pos)) -		return NULL; -     -	if (py_encoding != NULL && py_encoding != Py_None) -	{ -		if (pyg_boxed_check (py_encoding, PLUMA_TYPE_ENCODING)) -			encoding = pyg_boxed_get (py_encoding, PlumaEncoding); -		else { -			PyErr_SetString (PyExc_TypeError,  -			                 "encoding should be a PlumaEncoding"); -			return NULL; -		} -	} - -	if (!PySequence_Check (list)) -	{ -		PyErr_SetString (PyExc_TypeError,  -		                 "second argument must be a sequence"); -		return NULL; -	} - -	len = PySequence_Length (list); - -	for (i = 0; i < len; i++) -	{ -		item = PySequence_GetItem (list, i); -		Py_DECREF (item); - -		if (!PyString_Check (item)) -		{ -			PyErr_SetString (PyExc_TypeError, -					 "sequence item not a string"); -			g_slist_free (uris); -			return NULL; -		} - -		uris = g_slist_prepend (uris, PyString_AsString (item)); -	} - -	uris = g_slist_reverse (uris); -	pluma_commands_load_uris (PLUMA_WINDOW (window->obj), uris,  -	                          encoding, line_pos); -	g_slist_free (uris); - -	Py_INCREF (Py_None); -	return Py_None; -} diff --git a/plugin-loaders/python/bindings/plumamessage.override b/plugin-loaders/python/bindings/plumamessage.override deleted file mode 100644 index be1090a0..00000000 --- a/plugin-loaders/python/bindings/plumamessage.override +++ /dev/null @@ -1,556 +0,0 @@ -%% -headers - -#include <pluma/pluma-message-bus.h> -#include <pluma/pluma-message.h> - -static GType -_helper_wrap_get_gtype_from_pytype (PyObject *pytype) -{ -    PyTypeObject *type = (PyTypeObject *)pytype; -     -    if (type == &PyList_Type || type == &PyTuple_Type) -    	return G_TYPE_STRV; - -    return pyg_type_from_object (pytype); -} - -static gchar * -_helper_wrap_get_string (PyObject *obj) -{ -	PyObject *str; -	gchar *result; -	 -	str = PyObject_Str (obj); -	 -	if (!str) -		return NULL; -	 -	result = g_strdup (PyString_AsString (str)); -	Py_DECREF (str); -	 -	return result; -} - -static int -_helper_wrap_list_to_gvalue (GValue *gvalue, PyObject *pyvalue) -{ -	int num; -	gchar **lst; -	gint i; -	 -	num = PySequence_Size (pyvalue); -	lst = g_new0 (gchar *, num + 1); -	 -	for (i = 0; i < num; i++) -	{ -		lst[i] = _helper_wrap_get_string (PySequence_GetItem (pyvalue, i)); -		 -		if (lst[i] == NULL) -		{ -			g_strfreev (lst); -			return 1; -		} -	} -	 -	g_value_set_boxed (gvalue, lst); -	g_strfreev (lst); -	 -	return 0; -} - -static int -_helper_wrap_get_gvalue_from_pyobject (GValue *gvalue, PyObject *pyvalue) -{ -	if (pyvalue->ob_type == &PyList_Type || pyvalue->ob_type == &PyTuple_Type) -		return _helper_wrap_list_to_gvalue (gvalue, pyvalue); - -	return pyg_value_from_pyobject(gvalue, pyvalue); -} - -static int -_helper_wrap_message_set_value(PlumaMessage *message, PyObject *pykey, PyObject *pyvalue) -{ -    gchar *key; -    GType gtype; -    GValue value = {0,}; - -    key = _helper_wrap_get_string(pykey); -     -    if (key == NULL) -        return 0; - -    gtype = pluma_message_get_key_type(message, key); -     -    if (gtype == 0) { -        PyErr_SetString(PyExc_TypeError, "invalid key"); -        g_free (key); -        return 0; -    } - -    g_value_init(&value, gtype); -     -    if (_helper_wrap_get_gvalue_from_pyobject (&value, pyvalue)) { -        PyErr_SetString(PyExc_TypeError, -                        "value is of the wrong type for this key"); -        g_free (key); -        return 0; -    } - -    pluma_message_set_value(message, key, &value); -    g_value_unset(&value); -    g_free (key); -     -    return 1; -} - -typedef void (*ParsePairFunc)(PyObject *key, PyObject *value, gpointer user_data); - -static void -_helper_parse_pairs_dict (PyObject *dict, ParsePairFunc func, gpointer user_data) -{ -    if (!dict) -        return; -     -    PyObject *key, *value; -    Py_ssize_t i = 0; -     -    while (PyDict_Next(dict, &i, &key, &value)) -    { -        func(key, value, user_data); -    } -} - -static void -_helper_parse_pairs(PyObject *args, PyObject *kwargs, ParsePairFunc func, gpointer user_data) -{ -    guint len; -    guint i; -     -    len = PyTuple_Size(args); -     -    for (i = 0; i < len; ++i) -    { -    	PyObject *d = PyTuple_GetItem(args, i); -    	 -    	if (PyDict_Check(d)) -            _helper_parse_pairs_dict(d, func, user_data); -    } -   -    _helper_parse_pairs_dict(kwargs, func, user_data);   -} - -static void -_helper_message_set(PyObject *key, PyObject *value, PlumaMessage *message) -{ -    _helper_wrap_message_set_value(message, key, value); -} - -static void -_helper_message_set_values(PlumaMessage *message, PyObject *args, PyObject *kwargs) -{ -    _helper_parse_pairs(args, kwargs, (ParsePairFunc)_helper_message_set, message); -} - -static PlumaMessage * -_helper_wrap_create_message(PlumaMessageBus *bus, PyObject *args, PyObject *kwargs) -{ -    PyObject *pypath, *pymethod, *pydict; -     -    if (!PyArg_ParseTuple(args, "OO|O:PlumaMessage.create", &pypath, &pymethod, &pydict)) -        return NULL; -     -    gchar *object_path = _helper_wrap_get_string(pypath); -    gchar *method = _helper_wrap_get_string(pymethod); -     -    PlumaMessageType *message_type = pluma_message_bus_lookup (bus, object_path, method); -    PlumaMessage *message; -      -    if (message_type) -    { -        message = pluma_message_type_instantiate(message_type, NULL); -        _helper_message_set_values(message, args, kwargs); -    } -    else -    { -    	PyErr_SetString(PyExc_StandardError, "Message type does not exist"); -        message = NULL; -    } -     -    g_free(object_path); -    g_free(method); -     -    return message; -} - -typedef struct { -    PyObject *func; -    PyObject *data; -} PyPlumaCustomNotify; - -static void  -pypluma_custom_destroy_notify(gpointer user_data) -{ -    PyPlumaCustomNotify *cunote = user_data; -    PyGILState_STATE state; -     -    g_return_if_fail(user_data); -    state = pyg_gil_state_ensure(); -    Py_XDECREF(cunote->func); -    Py_XDECREF(cunote->data); -    pyg_gil_state_release(state); -     -    g_free(cunote); -} -%% -ignore-glob -  *_get_type -  pluma_message_type_foreach -  pluma_message_type_instantiate_valist -  pluma_message_type_new_valist -  pluma_message_get_valist -  pluma_message_set_valist -  pluma_message_set_valuesv -  pluma_message_bus_disconnect_by_func -  pluma_message_bus_block_by_func -  pluma_message_bus_unblock_by_func -%% -override pluma_message_type_new kwargs - -typedef struct -{ -    PlumaMessageType *message_type; -    PyObject *optional; -} MessageTypeSetInfo; - -static void -_message_type_set(PyObject *key, PyObject *value, MessageTypeSetInfo *info) -{ -    GType gtype; -     -    gchar *k = _helper_wrap_get_string(key); - -    if (!k) -        return; - -    gtype = _helper_wrap_get_gtype_from_pytype(value); -     -    gboolean optional = info->optional && PySequence_Contains(info->optional, key); -     -    pluma_message_type_set(info->message_type, optional, k, gtype, NULL); -    g_free(k); -} - -static int -_wrap_pluma_message_type_new(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    PyObject *pypath, *pymethod, *optional = NULL, *pydict; -     -    if (!PyArg_ParseTuple(args, "OO|OO:PlumaMessageType.new", &pypath, &pymethod, &optional, &pydict)) -        return -1; -     -    PlumaMessageType *message_type = PLUMA_MESSAGE_TYPE(g_object_new(pyg_type_from_object((PyObject *) self), NULL)); -     -    MessageTypeSetInfo info = {message_type, optional && PySequence_Check(optional) ? optional : NULL}; -    _helper_parse_pairs (args, kwargs, (ParsePairFunc)_message_type_set, &info); -     -    self->obj = (GObject *)message_type;     -    pygobject_register_wrapper((PyObject *) self); -     -    return 0; -} -%% -override pluma_message_type_instantiate kwargs -static PyObject * -_wrap_pluma_message_type_instantiate(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    PlumaMessageType *message_type = PLUMA_MESSAGE_TYPE (self->obj); -    PlumaMessage *message = pluma_message_type_instantiate(message_type, NULL); -     -    _helper_message_set_values(message, args, kwargs); -     -    return pygobject_new((GObject *)message); -} -%% -override pluma_message_get args -static PyObject * -_wrap_pluma_message_get(PyGObject *self, PyObject *args) -{ -    guint len, i; -    PyObject *ret; - -    len = PyTuple_Size(args); -     -    ret = PyTuple_New(len); -     -    for (i = 0; i < len; i++) { -        GValue value = { 0, }; -        PyObject *py_key = PyTuple_GetItem(args, i); -        gchar *key = _helper_wrap_get_string(py_key); -         -        if (!key) { -	    PyErr_SetString(PyExc_TypeError, "keys must be strings"); -	    Py_DECREF(ret); -	    return NULL; -	} -	 -	pluma_message_get_value (PLUMA_MESSAGE (self->obj), key, &value); -	g_free (key); - -	PyTuple_SetItem(ret, i, pyg_value_as_pyobject(&value, TRUE)); -	g_value_unset(&value); -    } -     -    return ret; -} -%% -override pluma_message_get_value kwargs -static PyObject * -_wrap_pluma_message_get_value(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    static char *kwlist[] = { "key", NULL }; -    const gchar *key; -    PyObject *ret; -    GValue value = { 0, }; -     -    if (!PyArg_ParseTupleAndKeywords(args, kwargs, "s:PlumaMessage.get_value", kwlist, &key)) -        return NULL; - -    pluma_message_get_value(PLUMA_MESSAGE(self->obj), key, &value); -    ret = pyg_value_as_pyobject(&value, TRUE); -    g_value_unset(&value); -     -    return ret; -} -%% -override pluma_message_set_value kwargs -static PyObject * -_wrap_pluma_message_set_value(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    static char *kwlist[] = { "key", "value", NULL }; -    PyObject *pykey, *pyvalue; -     -    if (!PyArg_ParseTupleAndKeywords(args, kwargs, "OO:PlumaMessage.set_value", kwlist, &pykey, &pyvalue)) -        return NULL; -     -    if (!_helper_wrap_message_set_value(PLUMA_MESSAGE(self->obj), pykey, pyvalue)) -        return NULL; -     -    Py_INCREF(Py_None); -    return Py_None; -} -%% -override pluma_message_set kwargs -static PyObject * -_wrap_pluma_message_set (PyGObject *self, PyObject *args, PyObject *kwargs) { -    _helper_message_set_values(PLUMA_MESSAGE(self->obj), args, kwargs); - -    Py_INCREF(Py_None); -    return Py_None; -} -%% -override pluma_message_bus_new -static int -_wrap_pluma_message_bus_new(PyGObject *self) -{ -    pygobject_construct (self, NULL); -     -    if (!self->obj) { -        PyErr_SetString (PyExc_RuntimeError, "could not create pluma.MessageBus object"); -        return -1; -    } - -    return 0; -} -%% -new-constructor PLUMA_TYPE_MESSAGE_BUS -%% -override pluma_message_bus_register kwargs -static PyObject * -_wrap_pluma_message_bus_register(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    PyObject *pypath, *pymethod, *optional = NULL, *pydict; -    PlumaMessageBus *bus = PLUMA_MESSAGE_BUS(self->obj); - -    if (!PyArg_ParseTuple(args, "OO|OO:PlumaMessageBus.register", &pypath, &pymethod, &optional, &pydict)) -        return NULL; -     -    gchar *object_path = _helper_wrap_get_string(pypath); -    gchar *method = _helper_wrap_get_string(pymethod); -     -    PlumaMessageType *message_type = pluma_message_bus_register(bus, object_path, method, 0, NULL); -     -    g_free(object_path); -    g_free(method); -     -    if (!message_type) -    { -    	PyErr_SetString(PyExc_StandardError, "Message type already exists"); -    	return NULL; -    } -     -    MessageTypeSetInfo info = {message_type, optional && PySequence_Check(optional) ? optional : NULL}; -    _helper_parse_pairs (args, kwargs, (ParsePairFunc)_message_type_set, &info); -     -    return pyg_boxed_new(PLUMA_TYPE_MESSAGE_TYPE, message_type, TRUE, TRUE); -} -%% -override pluma_message_bus_connect kwargs -static void -pypluma_message_bus_connect_cb(PlumaMessageBus *bus, PlumaMessage *message, gpointer data) -{ -    PyGILState_STATE state; -    PyPlumaCustomNotify *cunote = data; -    PyObject *pybus, *pymessage, *retobj; - -    g_assert(cunote->func); - -    state = pyg_gil_state_ensure(); - -    pybus = pygobject_new((GObject *)bus); -    pymessage = pygobject_new((GObject *)message); - -    if (cunote->data) { -        retobj = PyEval_CallFunction(cunote->func, "(NNO)", pybus, pymessage, cunote->data); -    } else { -        retobj = PyEval_CallFunction(cunote->func, "(NN)", pybus, pymessage); -    } - -    if (PyErr_Occurred()) { -        PyErr_Print(); -    } - -    Py_XDECREF(retobj); - -    pyg_gil_state_release(state); -} - -static PyObject * -_wrap_pluma_message_bus_connect(PyGObject *self, PyObject *args, PyObject *kwargs)  -{ -    static char *kwlist[] = { "domain", "name", "func", "data", NULL }; -    PyObject *pyfunc, *pyarg = NULL; -    const gchar *domain; -    const gchar *name; -    PyPlumaCustomNotify *cunote; - -    if (!PyArg_ParseTupleAndKeywords(args, kwargs, -				     "ssO|O:PlumaMessageBus.connect", -				     kwlist, &domain, &name, &pyfunc, &pyarg)) -        return NULL; - -    if (!PyCallable_Check(pyfunc)) { -        PyErr_SetString(PyExc_TypeError, "func must be a callable object"); -        return NULL; -    } -    cunote = g_new(PyPlumaCustomNotify, 1); -    Py_INCREF(pyfunc); -    cunote->func = pyfunc; -    Py_XINCREF(pyarg); -    cunote->data = pyarg; - -    guint id = pluma_message_bus_connect(PLUMA_MESSAGE_BUS(self->obj), -                                         domain, -                                         name, -                                         pypluma_message_bus_connect_cb, -                                         (gpointer)cunote, -                                         pypluma_custom_destroy_notify); -    return PyLong_FromUnsignedLong(id); -} -%% -override pluma_message_bus_send kwargs -static PyObject * -_wrap_pluma_message_bus_send(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    /* create a new message object */ -    PlumaMessage *message; -    PlumaMessageBus *bus = PLUMA_MESSAGE_BUS(self->obj); -    message = _helper_wrap_create_message(bus, args, kwargs); -     -    if (!message) -        return NULL; -     -    pluma_message_bus_send_message(bus, message); -    g_object_unref (message); -     -    Py_INCREF(Py_None); -    return Py_None; -} -%% -override pluma_message_bus_send_sync kwargs -static PyObject * -_wrap_pluma_message_bus_send_sync(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -    /* create a new message object */ -    PlumaMessage *message; -    PlumaMessageBus *bus = PLUMA_MESSAGE_BUS(self->obj); -     -    message = _helper_wrap_create_message(bus, args, kwargs); -     -    if (!message) -        return NULL; -     -    pluma_message_bus_send_message_sync(bus, message); -    return pygobject_new((GObject *)message); -} -%% -override-slot PlumaMessage.tp_getattro -static PyObject * -_wrap_pluma_message_tp_getattro(PyObject *self, PyObject *attrname) -{ -	PlumaMessage *message = PLUMA_MESSAGE(((PyGObject *)self)->obj); -	PlumaMessageType *type; - -	gchar *name = _helper_wrap_get_string (attrname); -	gboolean exists; -	gboolean intype; -	PyObject *ret; -	 -	if (name == NULL) -	{ -		PyErr_SetString(PyExc_TypeError, "attr name somehow not a string"); -		return NULL; -	} -	 -	g_object_get (message, "type", &type, NULL); -	intype = pluma_message_type_lookup (type, name) != G_TYPE_INVALID; -	pluma_message_type_unref (type); -	 -	exists = pluma_message_has_key (message, name); -	 -	if (!intype) -	{ -		ret = PyObject_GenericGetAttr(self, attrname); -	} -	else if (exists) -	{ -		GValue value = { 0, }; -		pluma_message_get_value (message, name, &value); -		ret = pyg_value_as_pyobject(&value, TRUE); -		g_value_unset (&value); -	} -	else -	{ -		Py_INCREF(Py_None); -		ret = Py_None; -	} - -	g_free (name); -	return ret; -} -%% -override-slot PlumaMessage.tp_setattro -static int -_wrap_pluma_message_tp_setattro(PyObject *self, PyObject *attrname, PyObject *value) -{ -	PlumaMessage *message = PLUMA_MESSAGE(((PyGObject *)self)->obj); - -	if (!_helper_wrap_message_set_value(message, attrname, value)) -	{ -		return PyObject_GenericSetAttr(self, attrname, value); -	} -	else -	{ -		return 1; -	} -} diff --git a/plugin-loaders/python/bindings/plumaplugin.override b/plugin-loaders/python/bindings/plumaplugin.override deleted file mode 100644 index a2aad78f..00000000 --- a/plugin-loaders/python/bindings/plumaplugin.override +++ /dev/null @@ -1,193 +0,0 @@ -%% -headers -#include <pluma/pluma-plugin.h> -#include <pluma/pluma-window.h> -%% -override pluma_plugin_activate kwargs -static PyObject * -_wrap_pluma_plugin_activate(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -	gpointer klass, klass2; -	static char *kwlist[] = { "window", NULL }; -	PyGObject *window; -	PyObject *cls = (PyObject *)(((PyObject *)self)->ob_type); -	 -	if (!PyArg_ParseTupleAndKeywords (args,  -					  kwargs, -					  "O!:PlumaPlugin.activate",  -					  kwlist, -					  &PyPlumaWindow_Type,  -					  &window)) -		return NULL; - -	klass = g_type_class_ref (pyg_type_from_object (cls)); -	 -	if (PLUMA_IS_PLUGIN_PYTHON_CLASS (klass)) -	{ -		klass2 = g_type_class_peek_parent (klass); -		g_type_class_unref (klass); -		klass = g_type_class_ref (G_TYPE_FROM_CLASS (klass2)); -	} - -	if (PLUMA_PLUGIN_CLASS (klass)->activate) -		PLUMA_PLUGIN_CLASS (klass)->activate (PLUMA_PLUGIN (self->obj),  -						      PLUMA_WINDOW (window->obj)); -	else { -		PyErr_SetString (PyExc_NotImplementedError,  -				 "virtual method PlumaPlugin.activate not implemented"); -		g_type_class_unref (klass); -		return NULL; -	} - -	g_type_class_unref (klass); -	Py_INCREF(Py_None); -	return Py_None; -} - -%% -override pluma_plugin_deactivate kwargs -static PyObject * -_wrap_pluma_plugin_deactivate(PyGObject *self, PyObject *args, PyObject *kwargs) -{ -	gpointer klass, klass2; -	static char *kwlist[] = {"window", NULL}; -	PyGObject *window; -	PyObject *cls = (PyObject *)(((PyObject *)self)->ob_type); - -	if (!PyArg_ParseTupleAndKeywords (args,  -					  kwargs, -					  "O!:PlumaPlugin.deactivate",  -					  kwlist, -					  &PyPlumaWindow_Type,  -					  &window)) -		return NULL; - -	klass = g_type_class_ref (pyg_type_from_object (cls)); - -	if (PLUMA_IS_PLUGIN_PYTHON_CLASS (klass)) -	{ -		klass2 = g_type_class_peek_parent (klass); -		g_type_class_unref (klass); -		klass = g_type_class_ref (G_TYPE_FROM_CLASS (klass2)); -	} -	 -	if (PLUMA_PLUGIN_CLASS (klass)->deactivate) -		PLUMA_PLUGIN_CLASS (klass)->deactivate (PLUMA_PLUGIN (self->obj),  -							PLUMA_WINDOW (window->obj)); -	else { -		PyErr_SetString (PyExc_NotImplementedError,  -				 "virtual method PlumaPlugin.deactivate not implemented"); -		g_type_class_unref (klass); -		return NULL; -	} - -	g_type_class_unref (klass); -	Py_INCREF(Py_None); -	return Py_None; -} - -%% -override pluma_plugin_update_ui kwargs -static PyObject * -_wrap_pluma_plugin_update_ui (PyGObject *self, PyObject *args, PyObject *kwargs) -{ -	gpointer klass, klass2; -	static char *kwlist[] = {"window", NULL}; -	PyGObject *window; -	PyObject *cls = (PyObject *)(((PyObject *)self)->ob_type); - -	if (!PyArg_ParseTupleAndKeywords (args,  -					  kwargs, -					  "O!:PlumaPlugin.update_ui",  -					  kwlist, -					  &PyPlumaWindow_Type,  -					  &window)) -		return NULL; - -	klass = g_type_class_ref (pyg_type_from_object (cls)); - -	if (PLUMA_IS_PLUGIN_PYTHON_CLASS (klass)) -	{ -		klass2 = g_type_class_peek_parent (klass); -		g_type_class_unref (klass); -		klass = g_type_class_ref (G_TYPE_FROM_CLASS (klass2)); -	} -	 -	if (PLUMA_PLUGIN_CLASS (klass)->update_ui) -		PLUMA_PLUGIN_CLASS (klass)->update_ui (PLUMA_PLUGIN (self->obj),  -						       PLUMA_WINDOW (window->obj)); -	else { -		PyErr_SetString (PyExc_NotImplementedError,  -				 "virtual method PlumaPlugin.update_ui not implemented"); -		g_type_class_unref (klass); -		return NULL; -	} - -	g_type_class_unref (klass); -	Py_INCREF(Py_None); -	return Py_None; -} - -%% -override pluma_plugin_is_configurable -static PyObject * -_wrap_pluma_plugin_is_configurable (PyGObject *self) -{ -	int ret; -	gpointer klass, klass2; -	PyObject *cls = (PyObject *)(((PyObject *)self)->ob_type); - -	klass = g_type_class_ref (pyg_type_from_object (cls)); - -	if (PLUMA_IS_PLUGIN_PYTHON_CLASS (klass)) -	{ -		klass2 = g_type_class_peek_parent (klass); -		g_type_class_unref (klass); -		klass = g_type_class_ref (G_TYPE_FROM_CLASS (klass2)); -	} -	 -	if (PLUMA_PLUGIN_CLASS (klass)->is_configurable) -		ret = PLUMA_PLUGIN_CLASS (klass)->is_configurable (PLUMA_PLUGIN (self->obj)); -	else { -		PyErr_SetString (PyExc_NotImplementedError,  -				 "virtual method PlumaPlugin.is_configurable not implemented"); -		g_type_class_unref (klass); -		return NULL; -	} - -	g_type_class_unref (klass); -	return PyBool_FromLong (ret); -} - -%% -override pluma_plugin_configure_dialog -static PyObject * -_wrap_pluma_plugin_create_configure_dialog (PyGObject *self) -{ -	GtkWidget *ret; -	gpointer klass, klass2; -	PyObject *cls = (PyObject *)(((PyObject *)self)->ob_type); - -	klass = g_type_class_ref(pyg_type_from_object (cls)); - -	if (PLUMA_IS_PLUGIN_PYTHON_CLASS (klass)) -	{ -		klass2 = g_type_class_peek_parent (klass); -		g_type_class_unref (klass); -		klass = g_type_class_ref (G_TYPE_FROM_CLASS (klass2)); -	} -	 -	if (PLUMA_PLUGIN_CLASS (klass)->create_configure_dialog) -		ret = PLUMA_PLUGIN_CLASS (klass)->create_configure_dialog (PLUMA_PLUGIN (self->obj)); -	else { -		PyErr_SetString (PyExc_NotImplementedError,  -				 "virtual method PlumaPlugin.create_configure_dialog not implemented"); -		g_type_class_unref (klass); -		return NULL; -	} - -	g_type_class_unref (klass); - -	/* pygobject_new handles NULL checking */ -	return pygobject_new ((GObject *)ret); -} diff --git a/plugin-loaders/python/bindings/plumautils.defs b/plugin-loaders/python/bindings/plumautils.defs deleted file mode 100644 index a9a4738d..00000000 --- a/plugin-loaders/python/bindings/plumautils.defs +++ /dev/null @@ -1,67 +0,0 @@ -;; -*- scheme -*- - -;; From ../../pluma/pluma-utils.h - -(define-function uri_has_writable_scheme -  (c-name "pluma_utils_uri_has_writable_scheme") -  (return-type "gboolean") -  (parameters -    '("const-gchar*" "uri") -  ) -) - -(define-function uri_has_file_scheme -  (c-name "pluma_utils_uri_has_file_scheme") -  (return-type "gboolean") -  (parameters -    '("const-gchar*" "uri") -  ) -) - -(define-function uri_exists -  (c-name "pluma_utils_uri_exists") -  (return-type "gboolean") -  (parameters -    '("const-gchar*" "text_uri") -  ) -) - -(define-function uri_is_valid -  (c-name "pluma_utils_is_valid_uri") -  (return-type "gboolean") -  (parameters -    '("const-gchar*" "uri") -  ) -) - -(define-function uri_get_dirname -  (c-name "pluma_utils_uri_get_dirname") -  (return-type "gchar*") -  (parameters -    '("const-char*" "uri") -  ) -) - -(define-function menu_position_under_widget -  (c-name "pluma_utils_menu_position_under_widget") -  (return-type "none") -  (parameters -    '("GtkMenu*" "menu") -    '("gint*" "x") -    '("gint*" "y") -    '("gboolean*" "push_in") -    '("gpointer" "user_data") -  ) -) - -(define-function menu_position_under_tree_view -  (c-name "pluma_utils_menu_position_under_tree_view") -  (return-type "none") -  (parameters -    '("GtkMenu*" "menu") -    '("gint*" "x") -    '("gint*" "y") -    '("gboolean*" "push_in") -    '("gpointer" "user_data") -  ) -) diff --git a/plugin-loaders/python/bindings/plumautils.override b/plugin-loaders/python/bindings/plumautils.override deleted file mode 100644 index 3b2116e9..00000000 --- a/plugin-loaders/python/bindings/plumautils.override +++ /dev/null @@ -1,85 +0,0 @@ -%% -headers -#define NO_IMPORT_PYGOBJECT -#define NO_IMPORT_PYGTK -#include <pygobject.h> -#include <pygtk/pygtk.h> - -#include "pluma-utils.h" - -void pyplumautils_register_classes (PyObject *d); -void pyplumautils_add_constants (PyObject *module, const gchar *strip_prefix); - -%% -modulename pluma.utils -%% -import gtk.Widget as PyGtkWidget_Type -import gtk.TreeView as PyGtkTreeView_Type -import gtk.Menu as PyGtkMenu_Type -%% -ignore-glob -  _* -%% -override pluma_utils_menu_position_under_widget kwargs -static PyObject * -_wrap_pluma_utils_menu_position_under_widget (PyObject *self, -					      PyObject *args, -					      PyObject *kwargs) -{ -	static char *kwlist[] = { "menu", "widget", NULL }; -	PyObject *py_menu, *py_widget; -	GtkMenu *menu; -	GtkWidget *widget; -	gint x, y; -	gboolean push_in; -	PyObject *tuple; -	 -	if (!PyArg_ParseTupleAndKeywords (args, kwargs, -					  "O!O!", kwlist, -					  &PyGtkMenu_Type, &py_menu, -					  &PyGtkWidget_Type, &py_widget)) -		return NULL; -	 -	menu   = GTK_MENU (pygobject_get (py_menu)); -	widget = GTK_WIDGET (pygobject_get (py_widget)); - -	pluma_utils_menu_position_under_widget (menu, &x, &y, &push_in, widget); - -	tuple = PyTuple_New (3); -	PyTuple_SetItem (tuple, 0, PyInt_FromLong (x)); -	PyTuple_SetItem (tuple, 1, PyInt_FromLong (y)); -	PyTuple_SetItem (tuple, 2, PyBool_FromLong (push_in)); -	return tuple; -} -%% -override pluma_utils_menu_position_under_tree_view kwargs -static PyObject * -_wrap_pluma_utils_menu_position_under_tree_view (PyObject *self, -					         PyObject *args, -					         PyObject *kwargs) -{ -	static char *kwlist[] = { "menu", "tree_view", NULL }; -	PyObject *py_menu, *py_view; -	GtkMenu *menu; -	GtkTreeView *view; -	gint x, y; -	gboolean push_in; -	PyObject *tuple; -	 -	if (!PyArg_ParseTupleAndKeywords (args, kwargs, -					  "O!O!", kwlist, -					  &PyGtkMenu_Type, &py_menu, -					  &PyGtkTreeView_Type, &py_view)) -		return NULL; -	 -	menu = GTK_MENU (pygobject_get (py_menu)); -	view = GTK_TREE_VIEW (pygobject_get (py_view)); - -	pluma_utils_menu_position_under_widget (menu, &x, &y, &push_in, view); - -	tuple = PyTuple_New (3); -	PyTuple_SetItem (tuple, 0, PyInt_FromLong (x)); -	PyTuple_SetItem (tuple, 1, PyInt_FromLong (y)); -	PyTuple_SetItem (tuple, 2, PyBool_FromLong (push_in)); -	return tuple; -} diff --git a/plugin-loaders/python/pluma-plugin-loader-python.c b/plugin-loaders/python/pluma-plugin-loader-python.c deleted file mode 100644 index 6c856844..00000000 --- a/plugin-loaders/python/pluma-plugin-loader-python.c +++ /dev/null @@ -1,719 +0,0 @@ -/* - * pluma-plugin-loader-python.c - * This file is part of pluma - * - * Copyright (C) 2008 - Jesse van den Kieboom - * - * 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 - * Foundation, Inc., 51 Franklin St, Fifth Floor,  - * Boston, MA 02110-1301, USA.  - */ - -#include "pluma-plugin-loader-python.h" -#include "pluma-plugin-python.h" -#include <pluma/pluma-object-module.h> - -#define NO_IMPORT_PYGOBJECT -#define NO_IMPORT_PYGTK - -#include <Python.h> -#include <pygobject.h> -#include <pygtk/pygtk.h> -#include <signal.h> -#include "config.h" - -#if PY_VERSION_HEX < 0x02050000 -typedef int Py_ssize_t; -#define PY_SSIZE_T_MAX INT_MAX -#define PY_SSIZE_T_MIN INT_MIN -#endif - -#define PLUMA_PLUGIN_LOADER_PYTHON_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE((object), PLUMA_TYPE_PLUGIN_LOADER_PYTHON, PlumaPluginLoaderPythonPrivate)) - -struct _PlumaPluginLoaderPythonPrivate -{ -	GHashTable *loaded_plugins; -	guint idle_gc; -	gboolean init_failed; -}; - -typedef struct -{ -	PyObject *type; -	PyObject *instance; -	gchar    *path; -} PythonInfo; - -static void pluma_plugin_loader_iface_init (gpointer g_iface, gpointer iface_data); - -/* Exported by pypluma module */ -void pypluma_register_classes (PyObject *d); -void pypluma_add_constants (PyObject *module, const gchar *strip_prefix); -extern PyMethodDef pypluma_functions[]; - -/* Exported by pyplumautils module */ -void pyplumautils_register_classes (PyObject *d); -extern PyMethodDef pyplumautils_functions[]; - -/* Exported by pyplumacommands module */ -void pyplumacommands_register_classes (PyObject *d); -extern PyMethodDef pyplumacommands_functions[]; - -/* We retreive this to check for correct class hierarchy */ -static PyTypeObject *PyPlumaPlugin_Type; - -PLUMA_PLUGIN_LOADER_REGISTER_TYPE (PlumaPluginLoaderPython, pluma_plugin_loader_python, G_TYPE_OBJECT, pluma_plugin_loader_iface_init); - - -static PyObject * -find_python_plugin_type (PlumaPluginInfo *info, -			 PyObject        *pymodule) -{ -	PyObject *locals, *key, *value; -	Py_ssize_t pos = 0; -	 -	locals = PyModule_GetDict (pymodule); - -	while (PyDict_Next (locals, &pos, &key, &value)) -	{ -		if (!PyType_Check(value)) -			continue; - -		if (PyObject_IsSubclass (value, (PyObject*) PyPlumaPlugin_Type)) -			return value; -	} -	 -	g_warning ("No PlumaPlugin derivative found in Python plugin '%s'", -		   pluma_plugin_info_get_name (info)); -	return NULL; -} - -static PlumaPlugin * -new_plugin_from_info (PlumaPluginLoaderPython *loader, -		      PlumaPluginInfo         *info) -{ -	PythonInfo *pyinfo; -	PyTypeObject *pytype; -	PyObject *pyobject; -	PyGObject *pygobject; -	PlumaPlugin *instance; -	PyObject *emptyarg; - -	pyinfo = (PythonInfo *)g_hash_table_lookup (loader->priv->loaded_plugins, info); -	 -	if (pyinfo == NULL) -		return NULL; -	 -	pytype = (PyTypeObject *)pyinfo->type; -	 -	if (pytype->tp_new == NULL) -		return NULL; - -	emptyarg = PyTuple_New(0); -	pyobject = pytype->tp_new (pytype, emptyarg, NULL); -	Py_DECREF (emptyarg); -	 -	if (pyobject == NULL) -	{ -		g_error ("Could not create instance for %s.", pluma_plugin_info_get_name (info)); -		return NULL; -	} - -	pygobject = (PyGObject *)pyobject; -	 -	if (pygobject->obj != NULL) -	{ -		Py_DECREF (pyobject); -		g_error ("Could not create instance for %s (GObject already initialized).", pluma_plugin_info_get_name (info)); -		return NULL; -	} -	 -	pygobject_construct (pygobject, -			     "install-dir", pyinfo->path, -			     "data-dir-name", pluma_plugin_info_get_module_name (info), -			     NULL); -	 -	if (pygobject->obj == NULL) -	{ -		g_error ("Could not create instance for %s (GObject not constructed).", pluma_plugin_info_get_name (info)); -		Py_DECREF (pyobject); - -		return NULL; -	} - -	/* now call tp_init manually */ -	if (PyType_IsSubtype (pyobject->ob_type, pytype) &&  -	    pyobject->ob_type->tp_init != NULL) -	{ -		emptyarg = PyTuple_New(0); -		pyobject->ob_type->tp_init (pyobject, emptyarg, NULL); -		Py_DECREF (emptyarg); -	} - -	instance = PLUMA_PLUGIN (pygobject->obj); -	pyinfo->instance = (PyObject *)pygobject; - -	/* make sure to register the python instance for the PlumaPluginPython -	   object to it can wrap the virtual pluma plugin funcs back to python */ -	_pluma_plugin_python_set_instance (PLUMA_PLUGIN_PYTHON (instance), (PyObject *)pygobject); -	 -	/* we return a reference here because the other is owned by python */ -	return PLUMA_PLUGIN (g_object_ref (instance)); -} - -static PlumaPlugin * -add_python_info (PlumaPluginLoaderPython *loader, -		 PlumaPluginInfo         *info, -		 PyObject		 *module, -		 const gchar             *path, -		 PyObject                *type) -{ -	PythonInfo *pyinfo; -	 -	pyinfo = g_new (PythonInfo, 1); -	pyinfo->path = g_strdup (path); -	pyinfo->type = type; - -	Py_INCREF (pyinfo->type); -	 -	g_hash_table_insert (loader->priv->loaded_plugins, info, pyinfo); -	 -	return new_plugin_from_info (loader, info); -} - -static const gchar * -pluma_plugin_loader_iface_get_id (void) -{ -	return "Python"; -} - -static PlumaPlugin * -pluma_plugin_loader_iface_load (PlumaPluginLoader *loader, -				PlumaPluginInfo   *info, -				const gchar       *path) -{ -	PlumaPluginLoaderPython *pyloader = PLUMA_PLUGIN_LOADER_PYTHON (loader); -	PyObject *main_module, *main_locals, *pytype; -	PyObject *pymodule, *fromlist; -	gchar *module_name; -	PlumaPlugin *result; -	 -	if (pyloader->priv->init_failed) -	{ -		g_warning ("Cannot load python plugin Python '%s' since pluma was" -		           "not able to initialize the Python interpreter.", -		           pluma_plugin_info_get_name (info)); -		return NULL; -	} -	 -	/* see if py definition for the plugin is already loaded */ -	result = new_plugin_from_info (pyloader, info); -	 -	if (result != NULL) -		return result; -	 -	main_module = PyImport_AddModule ("pluma.plugins"); -	if (main_module == NULL) -	{ -		g_warning ("Could not get pluma.plugins."); -		return NULL; -	} -	 -	/* If we have a special path, we register it */ -	if (path != NULL) -	{ -		PyObject *sys_path = PySys_GetObject ("path"); -		PyObject *pypath = PyString_FromString (path); - -		if (PySequence_Contains (sys_path, pypath) == 0) -			PyList_Insert (sys_path, 0, pypath); - -		Py_DECREF (pypath); -	} -	 -	main_locals = PyModule_GetDict (main_module); -	 -	/* we need a fromlist to be able to import modules with a '.' in the -	   name. */ -	fromlist = PyTuple_New(0); -	module_name = g_strdup (pluma_plugin_info_get_module_name (info)); -	 -	pymodule = PyImport_ImportModuleEx (module_name,  -					    main_locals,  -					    main_locals,  -					    fromlist); -	 -	Py_DECREF(fromlist); - -	if (!pymodule) -	{ -		g_free (module_name); -		PyErr_Print (); -		return NULL; -	} - -	PyDict_SetItemString (main_locals, module_name, pymodule); -	g_free (module_name); -	 -	pytype = find_python_plugin_type (info, pymodule); -	 -	if (pytype) -		return add_python_info (pyloader, info, pymodule, path, pytype); - -	return NULL; -} - -static void -pluma_plugin_loader_iface_unload (PlumaPluginLoader *loader, -				  PlumaPluginInfo   *info) -{ -	PlumaPluginLoaderPython *pyloader = PLUMA_PLUGIN_LOADER_PYTHON (loader); -	PythonInfo *pyinfo; -	PyGILState_STATE state; -	 -	pyinfo = (PythonInfo *)g_hash_table_lookup (pyloader->priv->loaded_plugins, info); -	 -	if (!pyinfo) -		return; -	 -	state = pyg_gil_state_ensure (); -	Py_XDECREF (pyinfo->instance); -	pyg_gil_state_release (state); -	 -	pyinfo->instance = NULL; -} - -static gboolean -run_gc (PlumaPluginLoaderPython *loader) -{ -	while (PyGC_Collect ()) -		; - -	loader->priv->idle_gc = 0; -	return FALSE; -} - -static void -pluma_plugin_loader_iface_garbage_collect (PlumaPluginLoader *loader) -{ -	PlumaPluginLoaderPython *pyloader; -	 -	if (!Py_IsInitialized()) -		return; - -	pyloader = PLUMA_PLUGIN_LOADER_PYTHON (loader); - -	/* -	 * We both run the GC right now and we schedule -	 * a further collection in the main loop. -	 */ - -	while (PyGC_Collect ()) -		; - -	if (pyloader->priv->idle_gc == 0) -		pyloader->priv->idle_gc = g_idle_add ((GSourceFunc)run_gc, pyloader); -} - -static void -pluma_plugin_loader_iface_init (gpointer g_iface,  -				gpointer iface_data) -{ -	PlumaPluginLoaderInterface *iface = (PlumaPluginLoaderInterface *)g_iface; -	 -	iface->get_id = pluma_plugin_loader_iface_get_id; -	iface->load = pluma_plugin_loader_iface_load; -	iface->unload = pluma_plugin_loader_iface_unload; -	iface->garbage_collect = pluma_plugin_loader_iface_garbage_collect; -} - -static void -pluma_python_shutdown (PlumaPluginLoaderPython *loader) -{ -	if (!Py_IsInitialized ()) -		return; - -	if (loader->priv->idle_gc != 0) -	{ -		g_source_remove (loader->priv->idle_gc); -		loader->priv->idle_gc = 0; -	} - -	while (PyGC_Collect ()) -		;	 - -	Py_Finalize (); -} - - -/* C equivalent of - *    import pygtk - *    pygtk.require ("2.0") - */ -static gboolean -pluma_check_pygtk2 (void) -{ -	PyObject *pygtk, *mdict, *require; - -	/* pygtk.require("2.0") */ -	pygtk = PyImport_ImportModule ("pygtk"); -	if (pygtk == NULL) -	{ -		g_warning ("Error initializing Python interpreter: could not import pygtk."); -		return FALSE; -	} - -	mdict = PyModule_GetDict (pygtk); -	require = PyDict_GetItemString (mdict, "require"); -	PyObject_CallObject (require, -			     Py_BuildValue ("(S)", PyString_FromString ("2.0"))); -	if (PyErr_Occurred()) -	{ -		g_warning ("Error initializing Python interpreter: pygtk 2 is required."); -		return FALSE; -	} - -	return TRUE; -} - -/* Note: the following two functions are needed because - * init_pyobject and init_pygtk which are *macros* which in case - * case of error set the PyErr and then make the calling - * function return behind our back. - * It's up to the caller to check the result with PyErr_Occurred() - */ -static void -pluma_init_pygobject (void) -{ -	init_pygobject_check (2, 11, 5); /* FIXME: get from config */ -} - -static void -pluma_init_pygtk (void) -{ -	PyObject *gtk, *mdict, *version, *required_version; - -	init_pygtk (); - -	/* there isn't init_pygtk_check(), do the version -	 * check ourselves */ -	gtk = PyImport_ImportModule("gtk"); -	mdict = PyModule_GetDict(gtk); -	version = PyDict_GetItemString (mdict, "pygtk_version"); -	if (!version) -	{ -		PyErr_SetString (PyExc_ImportError, -				 "PyGObject version too old"); -		return; -	} - -	required_version = Py_BuildValue ("(iii)", 2, 4, 0); /* FIXME */ - -	if (PyObject_Compare (version, required_version) == -1) -	{ -		PyErr_SetString (PyExc_ImportError, -				 "PyGObject version too old"); -		Py_DECREF (required_version); -		return; -	} - -	Py_DECREF (required_version); -} - -static void -old_gtksourceview_init (void) -{ -	PyErr_SetString(PyExc_ImportError, -			"gtksourceview module not allowed, use gtksourceview2"); -} - -static void -pluma_init_pygtksourceview (void) -{ -	PyObject *gtksourceview, *mdict, *version, *required_version; - -	gtksourceview = PyImport_ImportModule("gtksourceview2"); -	if (gtksourceview == NULL) -	{ -		PyErr_SetString (PyExc_ImportError, -				 "could not import gtksourceview"); -		return; -	} - -	mdict = PyModule_GetDict (gtksourceview); -	version = PyDict_GetItemString (mdict, "pygtksourceview2_version"); -	if (!version) -	{ -		PyErr_SetString (PyExc_ImportError, -				 "PyGtkSourceView version too old"); -		return; -	} - -	required_version = Py_BuildValue ("(iii)", 0, 8, 0); /* FIXME */ - -	if (PyObject_Compare (version, required_version) == -1) -	{ -		PyErr_SetString (PyExc_ImportError, -				 "PyGtkSourceView version too old"); -		Py_DECREF (required_version); -		return; -	} - -	Py_DECREF (required_version); - -	/* Create a dummy 'gtksourceview' module to prevent -	 * loading of the old 'gtksourceview' modules that -	 * has conflicting symbols with the gtksourceview2 module. -	 * Raise an exception when trying to import it. -	 */ -	PyImport_AppendInittab ("gtksourceview", old_gtksourceview_init); -} - -static gboolean -pluma_python_init (PlumaPluginLoaderPython *loader) -{ -	PyObject *mdict, *tuple; -	PyObject *pluma, *plumautils, *plumacommands, *plumaplugins; -	PyObject *gettext, *install, *gettext_args; -	//char *argv[] = { "pluma", NULL }; -	char *argv[] = { PLUMA_PLUGINS_LIBS_DIR, NULL }; -#ifdef HAVE_SIGACTION -	gint res; -	struct sigaction old_sigint; -#endif - -	if (loader->priv->init_failed) -	{ -		/* We already failed to initialized Python, don't need to -		 * retry again */ -		return FALSE; -	} -	 -	if (Py_IsInitialized ()) -	{ -		/* Python has already been successfully initialized */ -		return TRUE; -	} - -	/* We are trying to initialize Python for the first time, -	   set init_failed to FALSE only if the entire initialization process -	   ends with success */ -	loader->priv->init_failed = TRUE; - -	/* Hack to make python not overwrite SIGINT: this is needed to avoid -	 * the crash reported on bug #326191 */ - -	/* CHECK: can't we use Py_InitializeEx instead of Py_Initialize in order -          to avoid to manage signal handlers ? - Paolo (Dec. 31, 2006) */ - -#ifdef HAVE_SIGACTION -	/* Save old handler */ -	res = sigaction (SIGINT, NULL, &old_sigint);   -	if (res != 0) -	{ -		g_warning ("Error initializing Python interpreter: cannot get " -		           "handler to SIGINT signal (%s)", -		           g_strerror (errno)); - -		return FALSE; -	} -#endif - -	/* Python initialization */ -	Py_Initialize (); - -#ifdef HAVE_SIGACTION -	/* Restore old handler */ -	res = sigaction (SIGINT, &old_sigint, NULL); -	if (res != 0) -	{ -		g_warning ("Error initializing Python interpreter: cannot restore " -		           "handler to SIGINT signal (%s).", -		           g_strerror (errno)); - -		goto python_init_error; -	} -#endif - -	PySys_SetArgv (1, argv); - -	if (!pluma_check_pygtk2 ()) -	{ -		/* Warning message already printed in check_pygtk2 */ -		goto python_init_error; -	} - -	/* import gobject */	 -	pluma_init_pygobject (); -	if (PyErr_Occurred ()) -	{ -		g_warning ("Error initializing Python interpreter: could not import pygobject."); - -		goto python_init_error;		 -	} - -	/* import gtk */ -	pluma_init_pygtk (); -	if (PyErr_Occurred ()) -	{ -		g_warning ("Error initializing Python interpreter: could not import pygtk."); - -		goto python_init_error; -	} -	 -	/* import gtksourceview */ -	pluma_init_pygtksourceview (); -	if (PyErr_Occurred ()) -	{ -		PyErr_Print (); - -		g_warning ("Error initializing Python interpreter: could not import pygtksourceview."); - -		goto python_init_error; -	}	 -	 -	/* import pluma */ -	pluma = Py_InitModule ("pluma", pypluma_functions); -	mdict = PyModule_GetDict (pluma); - -	pypluma_register_classes (mdict); -	pypluma_add_constants (pluma, "PLUMA_"); - -	/* pluma version */ -	tuple = Py_BuildValue("(iii)",  -			      PLUMA_MAJOR_VERSION, -			      PLUMA_MINOR_VERSION, -			      PLUMA_MICRO_VERSION); -	PyDict_SetItemString(mdict, "version", tuple); -	Py_DECREF(tuple); -	 -	/* Retrieve the Python type for pluma.Plugin */ -	PyPlumaPlugin_Type = (PyTypeObject *) PyDict_GetItemString (mdict, "Plugin");  -	if (PyPlumaPlugin_Type == NULL) -	{ -		PyErr_Print (); - -		goto python_init_error; -	} - -	/* import pluma.utils */ -	plumautils = Py_InitModule ("pluma.utils", pyplumautils_functions); -	PyDict_SetItemString (mdict, "utils", plumautils); - -	/* import pluma.commands */ -	plumacommands = Py_InitModule ("pluma.commands", pyplumacommands_functions); -	PyDict_SetItemString (mdict, "commands", plumacommands); - -	/* initialize empty pluma.plugins module */ -	plumaplugins = Py_InitModule ("pluma.plugins", NULL); -	PyDict_SetItemString (mdict, "plugins", plumaplugins); - -	mdict = PyModule_GetDict (plumautils); -	pyplumautils_register_classes (mdict); -	 -	mdict = PyModule_GetDict (plumacommands); -	pyplumacommands_register_classes (mdict); - -	/* i18n support */ -	gettext = PyImport_ImportModule ("gettext"); -	if (gettext == NULL) -	{ -		g_warning ("Error initializing Python interpreter: could not import gettext."); - -		goto python_init_error; -	} - -	mdict = PyModule_GetDict (gettext); -	install = PyDict_GetItemString (mdict, "install"); -	gettext_args = Py_BuildValue ("ss", GETTEXT_PACKAGE, PLUMA_LOCALEDIR); -	PyObject_CallObject (install, gettext_args); -	Py_DECREF (gettext_args); -	 -	/* Python has been successfully initialized */ -	loader->priv->init_failed = FALSE; -	 -	return TRUE; -	 -python_init_error: - -	g_warning ("Please check the installation of all the Python related packages required " -	           "by pluma and try again."); - -	PyErr_Clear (); - -	pluma_python_shutdown (loader); - -	return FALSE; -} - -static void -pluma_plugin_loader_python_finalize (GObject *object) -{ -	PlumaPluginLoaderPython *pyloader = PLUMA_PLUGIN_LOADER_PYTHON (object); -	 -	g_hash_table_destroy (pyloader->priv->loaded_plugins); -	pluma_python_shutdown (pyloader); - -	G_OBJECT_CLASS (pluma_plugin_loader_python_parent_class)->finalize (object); -} - -static void -pluma_plugin_loader_python_class_init (PlumaPluginLoaderPythonClass *klass) -{ -	GObjectClass *object_class = G_OBJECT_CLASS (klass); -	 -	object_class->finalize = pluma_plugin_loader_python_finalize; - -	g_type_class_add_private (object_class, sizeof (PlumaPluginLoaderPythonPrivate)); -} - -static void -pluma_plugin_loader_python_class_finalize (PlumaPluginLoaderPythonClass *klass) -{ -} - -static void -destroy_python_info (PythonInfo *info) -{ -	PyGILState_STATE state = pyg_gil_state_ensure (); -	Py_XDECREF (info->type);	 -	pyg_gil_state_release (state); -	 -	g_free (info->path); -	g_free (info); -} - -static void -pluma_plugin_loader_python_init (PlumaPluginLoaderPython *self) -{ -	self->priv = PLUMA_PLUGIN_LOADER_PYTHON_GET_PRIVATE (self); -	 -	/* initialize python interpreter */ -	pluma_python_init (self); - -	/* loaded_plugins maps PlumaPluginInfo to a PythonInfo */ -	self->priv->loaded_plugins = g_hash_table_new_full (g_direct_hash, -						            g_direct_equal, -						            NULL, -						            (GDestroyNotify)destroy_python_info); -} - -PlumaPluginLoaderPython * -pluma_plugin_loader_python_new () -{ -	GObject *loader = g_object_new (PLUMA_TYPE_PLUGIN_LOADER_PYTHON, NULL); - -	return PLUMA_PLUGIN_LOADER_PYTHON (loader); -} - diff --git a/plugin-loaders/python/pluma-plugin-loader-python.h b/plugin-loaders/python/pluma-plugin-loader-python.h deleted file mode 100644 index 7463d0fc..00000000 --- a/plugin-loaders/python/pluma-plugin-loader-python.h +++ /dev/null @@ -1,61 +0,0 @@ -/* - * pluma-plugin-loader-python.h - * This file is part of pluma - * - * Copyright (C) 2008 - Jesse van den Kieboom - * - * 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 - * Foundation, Inc., 51 Franklin St, Fifth Floor,  - * Boston, MA 02110-1301, USA.  - */ - -#ifndef __PLUMA_PLUGIN_LOADER_PYTHON_H__ -#define __PLUMA_PLUGIN_LOADER_PYTHON_H__ - -#include <pluma/pluma-plugin-loader.h> - -G_BEGIN_DECLS - -#define PLUMA_TYPE_PLUGIN_LOADER_PYTHON		(pluma_plugin_loader_python_get_type ()) -#define PLUMA_PLUGIN_LOADER_PYTHON(obj)		(G_TYPE_CHECK_INSTANCE_CAST ((obj), PLUMA_TYPE_PLUGIN_LOADER_PYTHON, PlumaPluginLoaderPython)) -#define PLUMA_PLUGIN_LOADER_PYTHON_CONST(obj)	(G_TYPE_CHECK_INSTANCE_CAST ((obj), PLUMA_TYPE_PLUGIN_LOADER_PYTHON, PlumaPluginLoaderPython const)) -#define PLUMA_PLUGIN_LOADER_PYTHON_CLASS(klass)	(G_TYPE_CHECK_CLASS_CAST ((klass), PLUMA_TYPE_PLUGIN_LOADER_PYTHON, PlumaPluginLoaderPythonClass)) -#define PLUMA_IS_PLUGIN_LOADER_PYTHON(obj)		(G_TYPE_CHECK_INSTANCE_TYPE ((obj), PLUMA_TYPE_PLUGIN_LOADER_PYTHON)) -#define PLUMA_IS_PLUGIN_LOADER_PYTHON_CLASS(klass)	(G_TYPE_CHECK_CLASS_TYPE ((klass), PLUMA_TYPE_PLUGIN_LOADER_PYTHON)) -#define PLUMA_PLUGIN_LOADER_PYTHON_GET_CLASS(obj)	(G_TYPE_INSTANCE_GET_CLASS ((obj), PLUMA_TYPE_PLUGIN_LOADER_PYTHON, PlumaPluginLoaderPythonClass)) - -typedef struct _PlumaPluginLoaderPython		PlumaPluginLoaderPython; -typedef struct _PlumaPluginLoaderPythonClass		PlumaPluginLoaderPythonClass; -typedef struct _PlumaPluginLoaderPythonPrivate	PlumaPluginLoaderPythonPrivate; - -struct _PlumaPluginLoaderPython { -	GObject parent; -	 -	PlumaPluginLoaderPythonPrivate *priv; -}; - -struct _PlumaPluginLoaderPythonClass { -	GObjectClass parent_class; -}; - -GType pluma_plugin_loader_python_get_type (void) G_GNUC_CONST; -PlumaPluginLoaderPython *pluma_plugin_loader_python_new(void); - -/* All the loaders must implement this function */ -G_MODULE_EXPORT GType register_pluma_plugin_loader (GTypeModule * module); - -G_END_DECLS - -#endif /* __PLUMA_PLUGIN_LOADER_PYTHON_H__ */ - diff --git a/plugin-loaders/python/pluma-plugin-python.c b/plugin-loaders/python/pluma-plugin-python.c deleted file mode 100644 index bdb1ea95..00000000 --- a/plugin-loaders/python/pluma-plugin-python.c +++ /dev/null @@ -1,281 +0,0 @@ -/* - * pluma-plugin-python.c - * This file is part of pluma - * - * Copyright (C) 2005 Raphael Slinckx - * Copyright (C) 2008 Jesse van den Kieboom - * - * 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 - * Foundation, Inc., 51 Franklin St, Fifth Floor,  - * Boston, MA 02110-1301, USA.  - */ - -#include <config.h> - -#include "pluma-plugin-python.h" - -#include <pluma/pluma-plugin.h> -#include <pluma/pluma-debug.h> -#include <pygobject.h> -#include <string.h> - -#define PLUMA_PLUGIN_PYTHON_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), PLUMA_TYPE_PLUGIN_PYTHON, PlumaPluginPythonPrivate)) - -static GObjectClass *parent_class; - -struct _PlumaPluginPythonPrivate  -{ -	PyObject *instance; -}; - -static void	 pluma_plugin_python_class_init		(PlumaPluginPythonClass *klass); -static void	 pluma_plugin_python_init 		(PlumaPluginPython      *plugin); - -G_DEFINE_TYPE (PlumaPluginPython, pluma_plugin_python, PLUMA_TYPE_PLUGIN) - -static PyObject * -call_python_method (PlumaPluginPythonPrivate *priv, -		    PlumaWindow		     *window, -		    gchar		     *method) -{ -	PyObject *py_ret = NULL; - -	g_return_val_if_fail (PyObject_HasAttrString (priv->instance, method), NULL); - -	if (window == NULL) -	{ -		py_ret = PyObject_CallMethod (priv->instance, -					      method, -					      NULL); -	} -	else -	{ -		py_ret = PyObject_CallMethod (priv->instance, -					      method, -					      "(N)", -					      pygobject_new (G_OBJECT (window))); -	} -	 -	if (!py_ret) -		PyErr_Print (); - -	return py_ret; -} - -static gboolean -check_py_object_is_gtk_widget (PyObject *py_obj) -{ -	static PyTypeObject *_PyGtkWidget_Type = NULL; - -	if (_PyGtkWidget_Type == NULL) -	{ -		PyObject *module; - -	    	if ((module = PyImport_ImportModule ("gtk"))) -	    	{ -			PyObject *moddict = PyModule_GetDict (module); -			_PyGtkWidget_Type = (PyTypeObject *) PyDict_GetItemString (moddict, "Widget"); -	    	} - -		if (_PyGtkWidget_Type == NULL) -		{ -			PyErr_SetString(PyExc_TypeError, "could not find Python gtk widget type"); -			PyErr_Print(); - -			return FALSE; -		} -	} - -	return PyObject_TypeCheck (py_obj, _PyGtkWidget_Type) ? TRUE : FALSE; -} - -static void -impl_update_ui (PlumaPlugin *plugin, -		PlumaWindow *window) -{ -	PyGILState_STATE state = pyg_gil_state_ensure (); -	PlumaPluginPythonPrivate *priv = PLUMA_PLUGIN_PYTHON(plugin)->priv; -	 -	if (PyObject_HasAttrString (priv->instance, "update_ui")) -	{		 -		PyObject *py_ret = call_python_method (priv, window, "update_ui"); -		 -		if (py_ret) -		{ -			Py_XDECREF (py_ret); -		} -	} -	else -		PLUMA_PLUGIN_CLASS (parent_class)->update_ui (plugin, window); - -	pyg_gil_state_release (state); -} - -static void -impl_deactivate (PlumaPlugin *plugin, -		 PlumaWindow *window) -{ -	PyGILState_STATE state = pyg_gil_state_ensure (); -	PlumaPluginPythonPrivate *priv = PLUMA_PLUGIN_PYTHON(plugin)->priv; -	 -	if (PyObject_HasAttrString (priv->instance, "deactivate")) -	{		 -		PyObject *py_ret = call_python_method (priv, window, "deactivate"); -		 -		if (py_ret) -		{ -			Py_XDECREF (py_ret); -		} -	} -	else -		PLUMA_PLUGIN_CLASS (parent_class)->deactivate (plugin, window); - -	pyg_gil_state_release (state); -} - -static void -impl_activate (PlumaPlugin *plugin, -	       PlumaWindow *window) -{ -	PyGILState_STATE state = pyg_gil_state_ensure (); -	PlumaPluginPythonPrivate *priv = PLUMA_PLUGIN_PYTHON(plugin)->priv; -		 -	if (PyObject_HasAttrString (priv->instance, "activate")) -	{ -		PyObject *py_ret = call_python_method (priv, window, "activate"); - -		if (py_ret) -		{ -			Py_XDECREF (py_ret); -		} -	} -	else -		PLUMA_PLUGIN_CLASS (parent_class)->activate (plugin, window); -	 -	pyg_gil_state_release (state); -} - -static GtkWidget * -impl_create_configure_dialog (PlumaPlugin *plugin) -{ -	PyGILState_STATE state = pyg_gil_state_ensure (); -	PlumaPluginPythonPrivate *priv = PLUMA_PLUGIN_PYTHON(plugin)->priv; -	GtkWidget *ret = NULL; -	 -	if (PyObject_HasAttrString (priv->instance, "create_configure_dialog")) -	{ -		PyObject *py_ret = call_python_method (priv, NULL, "create_configure_dialog"); -	 -		if (py_ret) -		{ -			if (check_py_object_is_gtk_widget (py_ret)) -			{ -				ret = GTK_WIDGET (pygobject_get (py_ret)); -				g_object_ref (ret); -			} -			else -			{ -				PyErr_SetString(PyExc_TypeError, "return value for create_configure_dialog is not a GtkWidget"); -				PyErr_Print(); -			} -			 -			Py_DECREF (py_ret); -		} -	} -	else -		ret = PLUMA_PLUGIN_CLASS (parent_class)->create_configure_dialog (plugin); -  -	pyg_gil_state_release (state); -	 -	return ret; -} - -static gboolean -impl_is_configurable (PlumaPlugin *plugin) -{ -	PyGILState_STATE state = pyg_gil_state_ensure (); -	PlumaPluginPythonPrivate *priv = PLUMA_PLUGIN_PYTHON(plugin)->priv; -	PyObject *dict = priv->instance->ob_type->tp_dict;	 -	gboolean result; -	 -	if (dict == NULL) -		result = FALSE; -	else if (!PyDict_Check(dict)) -		result = FALSE; -	else  -		result = PyDict_GetItemString(dict, "create_configure_dialog") != NULL; - -	pyg_gil_state_release (state); -	 -	return result; -} - -void -_pluma_plugin_python_set_instance (PlumaPluginPython *plugin,  -				  PyObject 	    *instance) -{ -	PyGILState_STATE state = pyg_gil_state_ensure (); -	 -	/* we don't increment the instance here because we are the instance, -	   when it dies, we also die */ -	plugin->priv->instance = instance; -	pyg_gil_state_release (state); -} - -PyObject * -_pluma_plugin_python_get_instance (PlumaPluginPython *plugin) -{ -	return plugin->priv->instance; -} - -static void -pluma_plugin_python_init (PlumaPluginPython *plugin) -{ -	plugin->priv = PLUMA_PLUGIN_PYTHON_GET_PRIVATE(plugin); - -	pluma_debug_message (DEBUG_PLUGINS, "Creating Python plugin instance"); -	plugin->priv->instance = 0; -} - -static void -pluma_plugin_python_finalize (GObject *object) -{ -	PyGILState_STATE state; -	 -	pluma_debug_message (DEBUG_PLUGINS, "Finalizing Python plugin instance"); - -	state = pyg_gil_state_ensure (); -	Py_XDECREF (PLUMA_PLUGIN_PYTHON(object)->priv->instance); -	pyg_gil_state_release (state); -	 -	G_OBJECT_CLASS (parent_class)->finalize (object); -} - -static void -pluma_plugin_python_class_init (PlumaPluginPythonClass *klass) -{ -	PlumaPluginClass *plugin_class = PLUMA_PLUGIN_CLASS (klass); - -	parent_class = g_type_class_peek_parent (klass); - -	g_type_class_add_private (klass, sizeof (PlumaPluginPythonPrivate)); -	G_OBJECT_CLASS (klass)->finalize = pluma_plugin_python_finalize; - -	plugin_class->activate = impl_activate; -	plugin_class->deactivate = impl_deactivate; -	plugin_class->update_ui = impl_update_ui; -	plugin_class->create_configure_dialog = impl_create_configure_dialog; -	plugin_class->is_configurable = impl_is_configurable; -} - diff --git a/plugin-loaders/python/pluma-plugin-python.h b/plugin-loaders/python/pluma-plugin-python.h deleted file mode 100644 index ad5341fb..00000000 --- a/plugin-loaders/python/pluma-plugin-python.h +++ /dev/null @@ -1,88 +0,0 @@ -/* - * pluma-plugin-python.h - * This file is part of pluma - * - * Copyright (C) 2005 - Raphael Slinckx - * Copyright (C) 2008 - Jesse van den Kieboom - * - * 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 - * Foundation, Inc., 51 Franklin St, Fifth Floor,  - * Boston, MA 02110-1301, USA.  - */ - -#ifndef __PLUMA_PLUGIN_PYTHON_H__ -#define __PLUMA_PLUGIN_PYTHON_H__ - -#define NO_IMPORT_PYGOBJECT - -#include <glib-object.h> -#include <pygobject.h> - -#include <pluma/pluma-plugin.h> - -G_BEGIN_DECLS - -/* - * Type checking and casting macros - */ -#define PLUMA_TYPE_PLUGIN_PYTHON		(pluma_plugin_python_get_type()) -#define PLUMA_PLUGIN_PYTHON(obj)		(G_TYPE_CHECK_INSTANCE_CAST((obj), PLUMA_TYPE_PLUGIN_PYTHON, PlumaPluginPython)) -#define PLUMA_PLUGIN_PYTHON_CLASS(klass)	(G_TYPE_CHECK_CLASS_CAST((klass), PLUMA_TYPE_PLUGIN_PYTHON, PlumaPluginPythonClass)) -#define PLUMA_IS_PLUGIN_PYTHON(obj)		(G_TYPE_CHECK_INSTANCE_TYPE((obj), PLUMA_TYPE_PLUGIN_PYTHON)) -#define PLUMA_IS_PLUGIN_PYTHON_CLASS(klass)	(G_TYPE_CHECK_CLASS_TYPE ((klass), PLUMA_TYPE_PLUGIN_PYTHON)) -#define PLUMA_PLUGIN_PYTHON_GET_CLASS(obj)	(G_TYPE_INSTANCE_GET_CLASS((obj), PLUMA_TYPE_PLUGIN_PYTHON, PlumaPluginPythonClass)) - -/* Private structure type */ -typedef struct _PlumaPluginPythonPrivate PlumaPluginPythonPrivate; - -/* - * Main object structure - */ -typedef struct _PlumaPluginPython PlumaPluginPython; - -struct _PlumaPluginPython  -{ -	PlumaPlugin parent; -	 -	/*< private > */ -	PlumaPluginPythonPrivate *priv; -}; - -/* - * Class definition - */ -typedef struct _PlumaPluginPythonClass PlumaPluginPythonClass; - -struct _PlumaPluginPythonClass  -{ -	PlumaPluginClass parent_class; -}; - -/* - * Public methods - */ -GType	 pluma_plugin_python_get_type 		(void) G_GNUC_CONST; - - -/*  - * Private methods - */ -void	  _pluma_plugin_python_set_instance	(PlumaPluginPython *plugin,  -						 PyObject 	   *instance); -PyObject *_pluma_plugin_python_get_instance	(PlumaPluginPython *plugin); - -G_END_DECLS - -#endif  /* __PLUMA_PLUGIN_PYTHON_H__ */ - | 
