summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--README9
-rwxr-xr-xautogen.sh1
-rw-r--r--configure.ac132
-rw-r--r--data/pluma-bugreport.sh.in22
-rw-r--r--docs/reference/Makefile.am10
-rw-r--r--m4/python.m462
-rw-r--r--plugin-loaders/Makefile.am4
-rw-r--r--plugin-loaders/python/Makefile.am36
-rw-r--r--plugin-loaders/python/bindings/Makefile.am115
-rw-r--r--plugin-loaders/python/bindings/pluma.defs1461
-rw-r--r--plugin-loaders/python/bindings/pluma.override461
-rw-r--r--plugin-loaders/python/bindings/plumacommands.defs45
-rw-r--r--plugin-loaders/python/bindings/plumacommands.override122
-rw-r--r--plugin-loaders/python/bindings/plumamessage.override556
-rw-r--r--plugin-loaders/python/bindings/plumaplugin.override193
-rw-r--r--plugin-loaders/python/bindings/plumautils.defs67
-rw-r--r--plugin-loaders/python/bindings/plumautils.override85
-rw-r--r--plugin-loaders/python/pluma-plugin-loader-python.c719
-rw-r--r--plugin-loaders/python/pluma-plugin-loader-python.h61
-rw-r--r--plugin-loaders/python/pluma-plugin-python.c281
-rw-r--r--plugin-loaders/python/pluma-plugin-python.h88
-rw-r--r--plugins/Makefile.am5
-rw-r--r--pluma/pluma-plugin-info-priv.h3
-rw-r--r--tools/plugin_template/pluma-plugin.desktop.in3
24 files changed, 5 insertions, 4536 deletions
diff --git a/README b/README
index 1c23d4bf..a0c66afa 100644
--- a/README
+++ b/README
@@ -15,9 +15,6 @@ one document at the same time.
pluma supports most standard editing features, plus several not found in your
average text editor (plugins being the most notable of these).
-pluma plugins may also be written in the python scripting language: to enable
-python support you need the pygtk and mate-python-desktop bindings.
-
Although new features are always under development, currently pluma has:
* Complete support for UTF-8 text
@@ -27,7 +24,7 @@ Although new features are always under development, currently pluma has:
* Printing and Print Previewing Support
* File Revert
* A complete preferences interface
- * Configurable Plugin system, with optional python support
+ * Configurable Plugin system
Some of the plugins, packaged and installed with pluma include, among others:
@@ -36,10 +33,8 @@ Some of the plugins, packaged and installed with pluma include, among others:
* Spell checker
* Change case of selected text
* File Browser
- * Automatic snippet expansion
* Sort
* Insert Date/Time
- * External Tools
* Tag list
Other external plugins are also available.
@@ -61,8 +56,6 @@ Installation
============
pluma requires GTK+-2.16.x, GtkSourceView 2.4.x and MateConf libraries.
-PyGobject 2.12.x, PyGtk 2.12.x and PyGtkSourceView 2.4.x are required to
-enable python plugins support.
Simple install procedure:
diff --git a/autogen.sh b/autogen.sh
index f271c359..8b92c9e0 100755
--- a/autogen.sh
+++ b/autogen.sh
@@ -24,7 +24,6 @@ which yelp-build || {
}
REQUIRED_AUTOMAKE_VERSION=1.9
-REQUIRED_MACROS=python.m4
MATE_DATADIR="$mate_datadir"
USE_COMMON_DOC_BUILD=yes
diff --git a/configure.ac b/configure.ac
index ba1656a1..112fdd3c 100644
--- a/configure.ac
+++ b/configure.ac
@@ -204,123 +204,6 @@ dnl ================================================================
GLIB_GSETTINGS
dnl ================================================================
-dnl Python
-dnl ================================================================
-
-AC_MSG_CHECKING([whether Python support is requested])
-AC_ARG_ENABLE([python],
- AS_HELP_STRING([--enable-python],[Enable python support]),
- [enable_python=$enableval have_python=$enableval],
- [enable_python=autodetect have_python=yes])
-AC_MSG_RESULT([$enable_python])
-
-if test "x$have_python" != "xno"; then
- AM_PATH_PYTHON([2.5],[],[no])
- if test "x$PYTHON" = "x:"; then
- have_python=no
- fi
-fi
-
-if test "x$have_python" != "xno"; then
- AM_CHECK_PYTHON_HEADERS([],[have_python=no])
-fi
-
-if test "x$have_python" != "xno"; then
- PY_EXEC_PREFIX=`$PYTHON -c 'import sys ; print sys.exec_prefix'`
- PYTHON_LIBS="-lpython$PYTHON_VERSION"
-
- PY_PREFIX=`$PYTHON -c 'import sys ; print sys.prefix'`
- PYTHON_LIB_LOC="-L$libdir/python$PYTHON_VERSION/config"
- PYTHON_CFLAGS="-I$PY_PREFIX/include/python$PYTHON_VERSION"
- PYTHON_MAKEFILE="$libdir/python$PYTHON_VERSION/config/Makefile"
- PYTHON_BASEMODLIBS=`sed -n -e 's/^BASEMODLIBS=\(.*\)/\1/p' $PYTHON_MAKEFILE`
- PYTHON_OTHER_LIBS=`sed -n -e 's/^LIBS=\(.*\)/\1/p' $PYTHON_MAKEFILE`
- PYTHON_EXTRA_LIBS="$PYTHON_BASEMODLIBS $PYTHON_OTHER_LIBS"
-
- AC_SUBST([PYTHON_LIBS])
- AC_SUBST([PYTHON_LIB_LOC])
- AC_SUBST([PYTHON_CFLAGS])
- AC_SUBST([PYTHON_EXTRA_LIBS])
-fi
-
-if test "x$have_python" != "xyes"; then
- if test "x$enable_python" = "xyes"; then
- AC_MSG_ERROR([Python not found])
- elif test "x$enable_python" = "xautodetect"; then
- enable_python=no
- AC_MSG_WARN([Python not found, disabling python support])
- fi
-fi
-
-if test "x$have_python" != "xno"; then
- PYGOBJECT_REQUIRED=2.15.4
- PYGTK_REQUIRED=2.12.0
- PYGTKSOURCEVIEW_REQUIRED=2.9.2
-
- PKG_CHECK_MODULES([PYGTK], [
- pygobject-2.0 >= $PYGOBJECT_REQUIRED
- pygtk-2.0 >= $PYGTK_REQUIRED
- pygtksourceview-2.0 >= $PYGTKSOURCEVIEW_REQUIRED],
- [],
- [
- have_python=no
- if test "x$enable_python" = "xyes"; then
- AC_MSG_ERROR([$PYGTK_PKG_ERRORS])
- elif test "x$enable_python" = "xautodetect"; then
- enable_python=no
- AC_MSG_WARN([$PYGTK_PKG_ERRORS])
- AC_MSG_WARN([Disabling python support])
- fi
- ])
-fi
-
-if test "x$have_python" != "xno"; then
- AC_MSG_CHECKING([for pygtk defs])
- PYGTK_DEFSDIR=`$PKG_CONFIG --variable=defsdir pygtk-2.0`
- AC_MSG_RESULT([$PYGTK_DEFSDIR])
-
- AC_MSG_CHECKING([for pygobject defs])
- PYGOBJECT_DEFSDIR=`$PKG_CONFIG --variable=defsdir pygobject-2.0`
- AC_MSG_RESULT([$PYGOBJECT_DEFSDIR])
-
- AC_MSG_CHECKING([for pygtk codegen])
- PYGTK_CODEGEN="$PYTHON `$PKG_CONFIG --variable=codegendir pygtk-2.0`/codegen.py"
- AC_MSG_RESULT([$PYGTK_CODEGEN])
-
- AC_MSG_CHECKING([for pygtk h2def])
- PYGTK_H2DEF="$PYTHON `$PKG_CONFIG --variable=codegendir pygtk-2.0`/h2def.py"
- AC_MSG_RESULT([$PYGTK_H2DEF])
-
- AC_SUBST([PYGTK_DEFSDIR])
- AC_SUBST([PYGOBJECT_DEFSDIR])
- AC_SUBST([PYGTK_CODEGEN])
- AC_SUBST([PYGTK_H2DEF])
-
- dnl Check for -fno-strict-aliasing
- FLAGS="-fno-strict-aliasing"
- save_CFLAGS="$CFLAGS"
- CFLAGS="$CFLAGS $FLAGS"
- AC_MSG_CHECKING([whether [$]CC understands $FLAGS])
- AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[]])],[compiler_has_option=yes],[compiler_has_option=no])
- CFLAGS="$save_CFLAGS"
- AC_MSG_RESULT($compiler_has_option)
- if test $compiler_has_option = yes; then
- NO_STRICT_ALIASING_CFLAGS="$FLAGS"
- fi
- AC_SUBST([NO_STRICT_ALIASING_CFLAGS])
-fi
-
-if test "x$have_python" != "xno" -a "x$enable_python" != "xno"; then
- enable_python=yes
- AC_DEFINE([ENABLE_PYTHON],[1],[Define to compile with python support])
-fi
-
-AM_CONDITIONAL([ENABLE_PYTHON],[test "x$enable_python" = "xyes"])
-
-dnl This allows the bug-report script to know whether python has been enabled
-AC_SUBST(enable_python)
-
-dnl ================================================================
dnl Misc
dnl ================================================================
AC_PATH_PROG(GLIB_GENMARSHAL, glib-genmarshal)
@@ -380,26 +263,12 @@ help/Makefile
pixmaps/Makefile
plugin-loaders/Makefile
plugin-loaders/c/Makefile
-plugin-loaders/python/Makefile
-plugin-loaders/python/bindings/Makefile
plugins/Makefile
plugins/changecase/Makefile
plugins/docinfo/Makefile
-plugins/externaltools/data/Makefile
-plugins/externaltools/Makefile
-plugins/externaltools/scripts/Makefile
-plugins/externaltools/tools/Makefile
plugins/filebrowser/Makefile
plugins/filebrowser/org.mate.pluma.plugins.filebrowser.gschema.xml
plugins/modelines/Makefile
-plugins/pythonconsole/Makefile
-plugins/pythonconsole/pythonconsole/Makefile
-plugins/quickopen/Makefile
-plugins/quickopen/quickopen/Makefile
-plugins/snippets/data/lang/Makefile
-plugins/snippets/data/Makefile
-plugins/snippets/Makefile
-plugins/snippets/snippets/Makefile
plugins/sort/Makefile
plugins/spell/Makefile
plugins/spell/org.mate.pluma.plugins.spell.gschema.xml
@@ -420,7 +289,6 @@ Configuration:
Source code location: ${srcdir}
Compiler: ${CC}
GTK API version: $GTK_API_VERSION
- Python Plugins Support: $enable_python
Spell Plugin enabled: $enable_enchant
Gvfs metadata enabled: $enable_gvfs_metadata
Tests enabled: $enable_tests
diff --git a/data/pluma-bugreport.sh.in b/data/pluma-bugreport.sh.in
index 5aa2178e..4d97a6ae 100644
--- a/data/pluma-bugreport.sh.in
+++ b/data/pluma-bugreport.sh.in
@@ -1,10 +1,7 @@
#!/bin/sh
-ENABLE_PYTHON=@enable_python@
-
PKG_CONFIG_MODULES="glib-2.0 gtk+-2.0 gtksourceview-2.0 \
- pygobject-2.0 pygtk-2.0 \
- pygtksourceview-2.0 enchant iso-codes"
+ enchant iso-codes"
echo_padded ()
{
@@ -54,20 +51,3 @@ else
fi
echo
-echo "Python module versions:"
-if test "$ENABLE_PYTHON" = "yes"
-then
- echo_padded "python"
- python -V 2>&1 | cut -c8-
-
- echo_padded "pygtk"
- python -c "import gtk, sys; \
- sys.stdout.write('%d.%d.%d ' % gtk.pygtk_version); \
- sys.stdout.write('(GTK+ %d.%d.%d)' % gtk.gtk_version)" \
- 2>/dev/null
- echo
-else
- echo " Python support was not enabled at compile time."
-fi
-echo
-
diff --git a/docs/reference/Makefile.am b/docs/reference/Makefile.am
index 0af28ea6..f52aba90 100644
--- a/docs/reference/Makefile.am
+++ b/docs/reference/Makefile.am
@@ -96,16 +96,6 @@ GTKDOC_LIBS= \
$(top_builddir)/pluma/libpluma.la \
$(PLUMA_LIBS)
-if ENABLE_PYTHON
-GTKDOC_CFLAGS += \
- $(NO_STRICT_ALIASING_CFLAGS) \
- $(PYGTK_CFLAGS) \
- $(PYTHON_CFLAGS) \
- $(AM_CFLAGS)
-GTKDOC_LIBS += \
- $(top_builddir)/plugin-loaders/python/bindings/pluma.la
-endif
-
# This includes the standard gtk-doc make rules, copied by gtkdocize.
include $(top_srcdir)/gtk-doc.make
diff --git a/m4/python.m4 b/m4/python.m4
deleted file mode 100644
index e1c5266d..00000000
--- a/m4/python.m4
+++ /dev/null
@@ -1,62 +0,0 @@
-## this one is commonly used with AM_PATH_PYTHONDIR ...
-dnl AM_CHECK_PYMOD(MODNAME [,SYMBOL [,ACTION-IF-FOUND [,ACTION-IF-NOT-FOUND]]])
-dnl Check if a module containing a given symbol is visible to python.
-AC_DEFUN([AM_CHECK_PYMOD],
-[AC_REQUIRE([AM_PATH_PYTHON])
-py_mod_var=`echo $1['_']$2 | sed 'y%./+-%__p_%'`
-AC_MSG_CHECKING(for ifelse([$2],[],,[$2 in ])python module $1)
-AC_CACHE_VAL(py_cv_mod_$py_mod_var, [
-ifelse([$2],[], [prog="
-import sys
-try:
- import $1
-except ImportError:
- sys.exit(1)
-except:
- sys.exit(0)
-sys.exit(0)"], [prog="
-import $1
-$1.$2"])
-if $PYTHON -c "$prog" 1>&AC_FD_CC 2>&AC_FD_CC
- then
- eval "py_cv_mod_$py_mod_var=yes"
- else
- eval "py_cv_mod_$py_mod_var=no"
- fi
-])
-py_val=`eval "echo \`echo '$py_cv_mod_'$py_mod_var\`"`
-if test "x$py_val" != xno; then
- AC_MSG_RESULT(yes)
- ifelse([$3], [],, [$3
-])dnl
-else
- AC_MSG_RESULT(no)
- ifelse([$4], [],, [$4
-])dnl
-fi
-])
-
-dnl a macro to check for ability to create python extensions
-dnl AM_CHECK_PYTHON_HEADERS([ACTION-IF-POSSIBLE], [ACTION-IF-NOT-POSSIBLE])
-dnl function also defines PYTHON_INCLUDES
-AC_DEFUN([AM_CHECK_PYTHON_HEADERS],
-[AC_REQUIRE([AM_PATH_PYTHON])
-AC_MSG_CHECKING(for headers required to compile python extensions)
-dnl deduce PYTHON_INCLUDES
-py_prefix=`$PYTHON -c "import sys; print sys.prefix"`
-py_exec_prefix=`$PYTHON -c "import sys; print sys.exec_prefix"`
-PYTHON_INCLUDES="-I${py_prefix}/include/python${PYTHON_VERSION}"
-if test "$py_prefix" != "$py_exec_prefix"; then
- PYTHON_INCLUDES="$PYTHON_INCLUDES -I${py_exec_prefix}/include/python${PYTHON_VERSION}"
-fi
-AC_SUBST(PYTHON_INCLUDES)
-dnl check if the headers exist:
-save_CPPFLAGS="$CPPFLAGS"
-CPPFLAGS="$CPPFLAGS $PYTHON_INCLUDES"
-AC_TRY_CPP([#include <Python.h>],dnl
-[AC_MSG_RESULT(found)
-$1],dnl
-[AC_MSG_RESULT(not found)
-$2])
-CPPFLAGS="$save_CPPFLAGS"
-])
diff --git a/plugin-loaders/Makefile.am b/plugin-loaders/Makefile.am
index bf1e9647..2573ec31 100644
--- a/plugin-loaders/Makefile.am
+++ b/plugin-loaders/Makefile.am
@@ -1,7 +1,3 @@
SUBDIRS = c
-if ENABLE_PYTHON
-SUBDIRS += python
-endif
-
-include $(top_srcdir)/git.mk
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__ */
-
diff --git a/plugins/Makefile.am b/plugins/Makefile.am
index 74aa8d83..abe3213a 100644
--- a/plugins/Makefile.am
+++ b/plugins/Makefile.am
@@ -23,9 +23,8 @@ SUBDIRS = \
time \
trailsave
-if ENABLE_PYTHON
-SUBDIRS += externaltools pythonconsole snippets quickopen
-endif
+# python plugins are disabled for now
+#SUBDIRS += externaltools pythonconsole snippets quickopen
if ENABLE_ENCHANT
SUBDIRS += spell
diff --git a/pluma/pluma-plugin-info-priv.h b/pluma/pluma-plugin-info-priv.h
index 2f7c76bc..f69e2334 100644
--- a/pluma/pluma-plugin-info-priv.h
+++ b/pluma/pluma-plugin-info-priv.h
@@ -55,8 +55,7 @@ struct _PlumaPluginInfo
gchar *version;
/* A plugin is unavailable if it is not possible to activate it
- due to an error loading the plugin module (e.g. for Python plugins
- when the interpreter has not been correctly initializated) */
+ due to an error loading the plugin module */
gint available : 1;
};
diff --git a/tools/plugin_template/pluma-plugin.desktop.in b/tools/plugin_template/pluma-plugin.desktop.in
index c12b91b9..e9066ef3 100644
--- a/tools/plugin_template/pluma-plugin.desktop.in
+++ b/tools/plugin_template/pluma-plugin.desktop.in
@@ -1,7 +1,4 @@
[Pluma Plugin]
-##ifdef WITH_PYTHON
-Loader=python
-##endif
Module=##(PLUGIN_MODULE)
IAge=2
_Name=##(PLUGIN_NAME)