Improve scripting and its experience in Scribus

Introduction
The potential of the scripting interface seems highly underestimated. You can
 * add features without knowing C++ and without recompiling
 * make something which directly fits your own needs
 * automate repetitive tasks to improve usability and to save time
 * test ideas - Python is great for prototyping and sometimes it makes more sense to improve the prototype instead of rewriting everything in C++

I actually have written prototypes (among others) of
 * new-document-wizards
 * spell checkers
 * importers for exotic file formats
 * connectors to databases and content management systems
 * GUI hacks (full screen mode, tear-off menus etc.)

Current problems
As you see in the current state scripter is already powerful but it lacks
 * full integration into the GUI and the core: Scripts cannot easily add menu entries or toolbar icons, save settings into the Scribus configuration file, etc. [CR: This will probably need a decently designed public C++ API for Scribus, plus a SIP wrapper for it]
 * completeness: While writing scripts you sometimes find things which are still missing. For example there is a function to zoom the document view. But there lacks a function to get the current zoom factor. [CR: Again, need a real public API in C++ to make any kind of completeness effort viable and maintainable]
 * ease of use: The script console is really minimalistic and needs improvement. Also there is no standard way to distribute and install scripts.
 * security: Scripter should warn you if a script wants to import a module which can access the file system. The user should be asked if he trusts a script. [CR: unfortunately the first part of this is not viable, though the second is - see Scripter Security ]

How to make scripting situation better
'' So what is needed? ''

For the user

 * a standard way to find and to install extensions and scripts from the web, preferably from a trusted repository [CR: Great idea, especially if combined with signing of scripts for integrity etc]
 * scripts look and behave as native parts of Scribus

For the developer

 * specifications on how scripts can be integrated with Scribus
 * more example scripts / extensions to see what is possible and how to make use of Scribus' features
 * completed missing functionally

My idea
So I propose writing an extension manager for Scribus together with some example scripts and extensions.

This will probably help to find missing functionally and integration issues. Currently it is very easy to write scripts and this should not become harder by adding this new layer.

Mozilla Firefox shows what is possible with easily installable extensions. People without knowledge of C-programming can realize crazy ideas and useful features. A lot of the popularity of Firefox comes from its add-ons.

[CR: discussion moved to The talk page for this article.]

Implementation details
The GUI part will use the PyQt library which can directly integrate with the Scribus GUI. PyQt is available on all platforms where Qt is available and also supports Qt4 which Scribus will soon use. Nearly all Linux distributions contain PyQt and some like Kubuntu install it by default.

Most parts of the extension manager can be implemented in pure Python and rely on the already available hooks in scripter. Besides some stuff has to be added:
 * functions to get the configuration directory and the program directory
 * some widgets need to have a name so PyQt can find and access them
 * Bindings for the preferences manager [CR]
 * Bindings for the menu manager [CR]
 * (more to come soon)

See the links below to see that I already have experience in this area.

Links

 * Screenshot of an extension manager prototype
 * Screenshot of an OpenClipArt importer prototype
 * Example for a repository
 * I once wrote a patch which added the importSVG-function to scripter