PluginHelpers is a set of tools to be used with Source.Python plugins.
These tools allow you to do the following:
- Create a new Source.Python plugin.
- Check your plugins for any standards issues.
- Link Source.Python to your test servers and games.
- Link your plugins to Source.Python (which also links them to your servers and games).
- Create a release .zip file for your plugins.
## Pre-Setup Before you get started, there are a few things you will need installed and a few guidelines you need to follow. * Git * Obviously, since this is a git repository, this is going to be necessary. * On Windows, install either Git Bash or TortoiseGit (or both). * On Linux, use yum or apt-get to install 'git'. * Python3.4 or newer * Python3.4 is required, as [contextlib.suppress](https://docs.python.org/3.4/library/contextlib.html#contextlib.suppress) is used. * If you will be using this on a Linux system, most distros come with some version of Python2. When you install Python3.4, make sure you do not make it the system's default, as that can and will cause you issues. * I have found the following to be a good guide to installing Python3.4 on Linux: * http://www.unixmen.com/howto-install-python-3-x-in-ubuntu-debian-fedora-centos/ * Though, the wget and tar lines should look more like:
```
wget https://www.python.org/ftp/python/3.4.2/Python-3.4.2.tgz tar -xjf Python-3.4.2.tgz cd Python-3.4.2 ```
-
Supported Source-engine servers and games
- Currently the following servers are supported:
- Black Mesa server
- Blade Symphony server
- CS:GO server
- CS:S server
- DOD:S server
- Garry's Mod server
- HL2:DM server
- Left4Dead 2 server
- TF2 server
- Currently the following games are supported:
- Black Mesa
- CS:GO
- CS:S
- DOD:S
- HL2
- HL2: DM
- HL2: Ep1
- HL2: Ep2
- Left4Dead 2
- Portal
- TF2
- Currently the following servers are supported:
-
Source.Python clone
- Simply use git to clone Source.Python.
## Setup The first thing you need to do after cloning the repository is to execute the setup file (.bat for Windows or .sh for Linux). After you have done this, several new files will be created in the main directory. Those files include the config.ini, which holds configuration values you need to set, and a .pylintrc file which can be used for different pylint settings when running the **plugin_checker** script. A few platform-specific (.bat for Windows or .sh for Linux) files are also created: * plugin_checker * plugin_creater * plugin_linker * plugin_releaser * prerequisites * sp_linker
## Configuration The next step is to set up your configuration values. Open the config.ini and set the values appropriately. The following are the settings
- AUTHOR
- used by plugin_creater to know what value to put as info.author for the plugin.
- SOURCE_PYTHON_DIRECTORY
- used by plugin_linker and sp_linker to know where the Source.Python repository is located.
- Defaults:
- Windows: C:\Projects\Source.Python
- Linux: /media/Source.Python
- SERVER_DIRECTORIES
- used by sp_linker to know where your servers are located.
- If there are servers in multiple base directories, separate each with a semi-colon (;).
- Defaults:
- Windows: C:\Servers
- Linux: /media/Servers
- STEAM_DIRECTORIES
- used by sp_linker to know where your games are located.
- If there are multiple base directories, separate each with a semi-colon (;).
- Defaults:
- Windows: C:\Program Files\Steam
- Linux: /media/Steam
- RELEASE_DIRECTORY
- used by plugin_releaser to know where to copy your plugin releases to.
- Defaults:
- Windows: C:\Releases
- Linux: /media/Releases
- PYTHON_EXECUTABLE
- used by all of the executables (including prerequisites) to know where the Python executable is located.
- This needs to be set to the executable file itself and not just its directory.
- Defaults:
- Windows: C:\Python34\python
- Linux: /opt/python3/bin/python3.4
## Prerequisite packages After you have your configuration set, execute the prerequisite script to install the required Python packages.
The required packages for this toolset include:
- configobj
- used by the Python scripts to get your configuration values.
- path.py
- used by the Python scripts to more easily navigate directories and files on your system.
- pep8
- used by the plugin_checker script to check for any PEP8 violations in your plugins.
- pep257
- used by the plugin_checker script to check for any PEP257 violations in your plugins.
- pyflakes
- used by the plugin_checker script to check your plugins for a few different issues.
- pylint
- used by the plugin_checker script to check your plugins for a lot of different issues.
## Linking Source.Python Once you have finished installing the prerequisites, the next item on the list is to link Source.Python's repository to your servers and games.
As long as you have correctly set your config.ini SERVER_DIRECTORIES, STEAM_DIRECTORIES, SOURCE_PYTHON_DIRECTORY, and PYTHON_EXECUTABLE values, simply execute the sp_linker script and select the server or game you wish to link (or ALL for all servers and games).
## Installing plugins If you already have some plugins started, you can copy them into the PluginHelpers repository directory. Though, they **must** adhere to some guidelines: * The directory name needs to be the name of the plugin (the **sp plugin load** name). * The internal directories need to match that of Source.Python's internal directory structure. * There must be a directory within the main directory that is named **addons** and contains the following directory structure **../addons/source-python/plugins/<plugin_name>/**. * Within the above directory, there must be at least a **<plugin_name>.py** file and an **\_\_init\_\_.py** file. * It is recommended that you have a public or private repository to host your plugin, but that is not necessary.
## Creating plugins PluginHelpers comes with a script that helps to start the creation of new plugins. Execute the **plugin_creater** script and answer the questions that follow.
Once you have answered all the necessary questions, the appropriate directories/files will be created.
3 files will always be created:
- __init__.py
- mandatory for the plugin_checker to work.
- useful for verifying implementation on a server or game prior to loading your plugin.
- info.py
- holds the PluginInfo instance for your plugin.
- If you supplied an AUTHOR value in the config.ini, that value will be used as info.author.
- <plugin_name>.py
- mandatory file when using the sp plugin load command on a server or game.
## Linking plugins Now that you have one or more plugins inside the PluginHelpers repository directory, you will want to link them to the Source.Python repository.
Linking your plugins to the Source.Python repository instead of each server/game individually allows you to only have to link them once and have them available on all of your test servers and games.
Execute the plugin_linker script and choose which plugin (or ALL plugins) to link. If you have already linked a plugin, but have added new directories, running the linker again will link those directories.
## Checking plugins At some point, or many different points, you might want to check your plugins to see if they match a set of standards (like PEP8 or PEP257).
Execute the plugin_checker script and choose which plugin (or ALL plugins) to check and all of the issues/errors/warnings will be shown.
## Creating a release Once you get to a point where you think a plugin is ready to be released, execute the **plugin_releaser** script.
Select which plugin to release, or ALL plugins, if you wish to create a release for all of them.
The release .zip file location will be shown, and uses the RELEASEDIR value from the config.ini.
The plugin_releaser script does use the info.version value that needs to be set somewhere in your Python code for that script.
Each release is saved as <RELEASEDIR>/<plugin_name>/<plugin_name>_v<version>.zip, so that if you have a plugin named my_plugin and its version is 1.0, the file would be <RELEASEDIR>/my_plugin/my_plugin_v1.0.zip.