forked from eggheads/eggdrop
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Patch by: Geo, thommey PYTHON! - Adds the .python partyline command to run a python command, similar to .tcl - Adds the pysource Tcl command to load a python file, similar to the source Tcl command - Imports the existing Tcl API (run via the eggdrop.tcl module)
- Loading branch information
Showing
27 changed files
with
4,506 additions
and
25 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -39,3 +39,4 @@ config.cache | |
eggdrop | ||
EGGMOD.stamp | ||
mod.xlibs | ||
__pycache__ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,149 @@ | ||
Last revised: November 03, 2023 | ||
|
||
.. _python: | ||
|
||
============ | ||
Python Module | ||
============ | ||
|
||
This module adds a Python interpreter to Eggdrop, allowing you to run Python scripts. | ||
|
||
-------------- | ||
Loading Python | ||
-------------- | ||
|
||
Put this line into your Eggdrop configuration file to load the python module:: | ||
|
||
loadmodule python | ||
|
||
To load a python script from your config file, place the .py file in the scripts/ folder and add the following line to your config:: | ||
|
||
pysource scripts/myscript.py | ||
|
||
------------------ | ||
Partyline Commands | ||
------------------ | ||
|
||
^^^^^^^^^^^^^^^^^^^ | ||
python <expression> | ||
^^^^^^^^^^^^^^^^^^^ | ||
|
||
You can run a python command from the partyline with the .python command, such as:: | ||
|
||
.python 1 + 1 | ||
Python: 2 | ||
.python from eggdrop.tcl import putmsg; putmsg('#chan', 'Hello world!') | ||
Python: None | ||
|
||
^^^^^^^^^^^^^ | ||
.binds python | ||
^^^^^^^^^^^^^ | ||
|
||
The python module extends the core ``.binds`` partyline command by adding a ``python`` mask. This command will list all binds for python scripts. | ||
|
||
------------ | ||
Tcl Commands | ||
------------ | ||
|
||
^^^^^^^^^^^^^^^^^^^^^^^ | ||
pysource <path/to/file> | ||
^^^^^^^^^^^^^^^^^^^^^^^ | ||
|
||
The ``pysource`` command is analgous to the Tcl ``source`` command, except that it loads a Python script into Eggdrop instead of a Tcl script. | ||
|
||
----------------------- | ||
Eggdrop Python Commands | ||
----------------------- | ||
|
||
The Python module is built to use the existing core Tcl commands integrated into Eggdrop via the ``eggdrop.tcl`` module. To call an existing Tcl command from Python, you can either load the entire catalog by running ``import eggdrop.tcl``, or be more specific by ``from eggdrop.tcl import putserv, putlog, chanlist``, etc. | ||
|
||
Arguments to the Tcl functions are automatically converted as follows: | ||
|
||
* ``None`` is converted to an empty Tcl object (the empty string, ``""``) | ||
* ``List`` and ``Tuple`` is converted to a ``Tcl list`` | ||
* ``Dict`` is converted to a ``Tcl dictionary`` | ||
* Everything else is converted to a string using the str() method | ||
|
||
Return values from Tcl functions must be manually converted: | ||
|
||
* ``""`` the empty string is automatically converted to None | ||
* everything else is returned as string | ||
* ``Tcl list`` as string can be converted to a Python ``List`` using ``parse_tcl_list`` | ||
* ``Tcl dictionary`` as string can be converted to a Python ``Dict`` using ``parse_tcl_list`` | ||
|
||
Additionally, a few extra python commands have been created for use without these conversions: | ||
|
||
^^^^^^^^^^^^^^^^ | ||
bind <arguments> | ||
^^^^^^^^^^^^^^^^ | ||
|
||
The python version of the bind command is used to create a bind that triggers a python function. The python bind takes the same arguments as the Tcl binds, for more information on bind argument syntax please see tcl_binds_. The eggdrop.tcl.bind command should not be used as it will attempt to call a Tcl proc. | ||
|
||
^^^^^^^^^^^^^^^^^^^^^^^ | ||
parse_tcl_list <string> | ||
^^^^^^^^^^^^^^^^^^^^^^^ | ||
|
||
When a python script calls a Tcl command that returns a list via the eggdrop.tcl module, the return value will be a Tcl-formatted list- also simply known as a string. The ``parse_tcl_list`` command will convert the Tcl-formatted list into a Python list, which can then freely be used within the Python script. | ||
|
||
^^^^^^^^^^^^^^^^^^^^^^^ | ||
parse_tcl_dict <string> | ||
^^^^^^^^^^^^^^^^^^^^^^^ | ||
|
||
When a python script calls a Tcl command that returns a dict via the eggdrop.tcl module, the return value will be a Tcl-formatted dict- also simply known as a string. The ``parse_tcl_dict`` command will c | ||
onvert the Tcl-formatted dict into a Python list, which can then freely be used within the Python script. | ||
|
||
---------------- | ||
Config variables | ||
---------------- | ||
|
||
There are also some variables you can set in your config file: | ||
|
||
set allow-resync 0 | ||
When two bots get disconnected, this setting allows them to create a | ||
resync buffer which saves all changes done to the userfile during | ||
the disconnect. When they reconnect, they will not have to transfer | ||
the complete user file, but, instead, just send the resync buffer. | ||
|
||
-------------------------------- | ||
Writing an Eggdrop Python script | ||
-------------------------------- | ||
|
||
This is how to write a python script for Eggdrop. | ||
|
||
You can view examples of Python scripts in the exampleScripts folder included with this module. | ||
|
||
.. glossary:: | ||
bestfriend.py | ||
This example script demonstrates how to use the parse_tcl_list() python command to convert a list returned by a Tcl command into a list that is usable by Python. | ||
greet.py | ||
This is a very basic script that demonstrates how a Python script with binds can be run by Eggdrop. | ||
imdb.py | ||
This script shows how to use an existing third-party module to extend a Python script, in this case retrieving information from imdb.com. | ||
listtls.py | ||
This script demonstrates how to use parse-tcl_list() and parse_tcl_dict() to convert a list of dicts provided by Tcl into something that is usuable by Python. | ||
urltitle.py | ||
This script shows how to use an existing third-party module to extend a Python script, in this case using an http parser to collect title information from a provided web page. | ||
|
||
|
||
^^^^^^^^^^^^^^ | ||
Header section | ||
^^^^^^^^^^^^^^ | ||
|
||
An Eggdrop python script requires you to import X Y and Z, in this format. | ||
|
||
^^^^^^^^^^^^ | ||
Code Section | ||
^^^^^^^^^^^^ | ||
|
||
Normal python code works here. To run a command from the Eggdrop Tcl library, use this format. | ||
|
||
Use this format all over. | ||
|
||
------------------------------------- | ||
Writing a module for use with Eggdrop | ||
------------------------------------- | ||
|
||
This is how you import a module for use with an egg python script. | ||
|
||
|
||
Copyright (C) 2000 - 2023 Eggheads Development Team |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
dnl python.m4 -- Autoconf macros to compile python.mod | ||
dnl | ||
dnl Copyright (c) 2022 - 2022 Eggheads Development Team | ||
dnl | ||
dnl This program is free software; you can redistribute it and/or | ||
dnl modify it under the terms of the GNU General Public License | ||
dnl as published by the Free Software Foundation; either version 2 | ||
dnl of the License, or (at your option) any later version. | ||
dnl | ||
dnl This program is distributed in the hope that it will be useful, | ||
dnl but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
dnl GNU General Public License for more details. | ||
dnl | ||
dnl You should have received a copy of the GNU General Public License | ||
dnl along with this program; if not, write to the Free Software | ||
dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
dnl | ||
|
||
dnl EGG_PYTHON_ENABLE | ||
dnl | ||
AC_DEFUN([EGG_PYTHON_ENABLE], | ||
[ | ||
AC_MSG_CHECKING([whether to compile the Python module]) | ||
AC_ARG_ENABLE(python, | ||
[ --enable-python enable Python support (autodetect)], | ||
[egg_enable_python="$enableval"]) | ||
AC_ARG_ENABLE(python, | ||
[ --disable-python disable Python support], [egg_enable_python="$enableval"], | ||
[egg_enable_python="autodetect"]) | ||
AC_MSG_RESULT([$egg_enable_python]) | ||
AC_SUBST(egg_enable_python) | ||
]) | ||
|
||
|
||
dnl EGG_PYTHON_WITHCONFIG | ||
dnl | ||
AC_DEFUN(EGG_PYTHON_WITHCONFIG, | ||
[ | ||
AC_ARG_WITH(python-config, [ --with-python-config=PATH Path to python-config], [ | ||
if test "x$enable_python" != "xno"; then | ||
if test -d "$withval" || test -x "$withval"; then | ||
egg_with_python_config="$withval" | ||
else | ||
egg_with_python_config="no" | ||
AC_MSG_WARN([Invalid path to python-config. $withval is not a directory and not an executable.]) | ||
fi | ||
fi | ||
]) | ||
AC_SUBST(egg_with_python_config) | ||
]) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.