No description
Find a file
2023-06-28 02:57:54 +02:00
.github/workflows Update workflows to Python 3.11 2023-05-04 20:25:42 +02:00
docs Deleted accidental backup that got pushed 2021-03-29 14:06:30 +00:00
fonts/alternian Add alternian text 2023-02-23 02:17:32 +01:00
img Don't include example images with builds 2023-03-21 16:44:23 +01:00
pnc Remove AttrDict and enable pylint typecheck message category. 2023-02-15 16:34:48 +01:00
quirks Use <em> instead of <span> for alternian text. 2023-02-23 20:50:49 +01:00
scripts Move services functionality to services.py 2023-03-18 01:49:56 +01:00
smilies incorrect sRGB profile fix attempt 2021-03-23 23:23:34 +01:00
themes implemented theme loading with QFontDatabase by themes with the main/fonts key 2023-06-25 00:51:23 +02:00
.gitignore Add GitHub's Python.gitignore template to .gitignore 2023-04-29 15:33:14 +02:00
.pylintrc Add Qt to pylint extension-pkg-allow-list & simplify action 2023-02-25 02:33:36 +01:00
CHANGELOG.md Update changelog (v2.5.3) 2022-12-27 03:06:59 +01:00
convo.py Remove section causing issues with pylint 2023-05-03 19:22:15 +02:00
dataobjs.py Add alternian text 2023-02-23 02:17:32 +01:00
generic.py Only use QtMultimedia.QSoundEffect for audio. 2023-03-14 17:52:11 +01:00
irc.py Move services functionality to services.py 2023-03-18 01:49:56 +01:00
LICENSE Update GPLv3 2023-01-29 17:43:17 +01:00
logviewer.py fix filename handling 2023-05-30 01:56:02 +02:00
memos.py Move services functionality to services.py 2023-03-18 01:49:56 +01:00
menus.py fix: accessing text when no quirks selected 2023-04-28 18:17:11 -04:00
mispeller.py Updated black run 2023-02-09 20:52:26 +01:00
mood.py IRC rewrite continued 2023-02-12 00:36:36 +01:00
ostools.py Enforce select pylint messages 2023-02-13 20:26:05 +01:00
parsetools.py did git just donk up my commits 2023-06-25 01:00:44 +02:00
pesterchum __init__ & wrapper scripts for wheel 2022-03-20 04:37:04 +01:00
pesterchum.py fix pylint/black 2023-06-28 02:54:33 +02:00
pyinst.py Don't include example images with builds 2023-03-21 16:44:23 +01:00
pyquirks.py Enforce select pylint messages 2023-02-13 20:26:05 +01:00
pytwmn.py Remove most unnecessary str() typecasts. 2023-02-19 21:10:35 +01:00
quirks.py Enforce select pylint messages 2023-02-13 20:26:05 +01:00
randomer.py Remove most unnecessary str() typecasts. 2023-02-19 21:10:35 +01:00
README.md Don't include example images with builds 2023-03-21 16:44:23 +01:00
requirements-qt5.txt Update requirements 2023-04-20 22:19:12 +02:00
requirements.txt Update requirements 2023-04-20 22:19:12 +02:00
toast.py Replace deprecated inspect.getargspec with inspect.getfullargspec 2023-05-04 20:21:35 +02:00
TODO.md Remove console, not a lot of people used this. 2023-03-14 15:23:53 +01:00
user_profile.py did git just donk up my commits 2023-06-25 01:00:44 +02:00
version.py Version to Alt. v2.6rc1 2023-01-26 22:01:48 +01:00

PESTERCHUM GitHub all releases Community Discord Support Discord
GitHub commit activity Lines of code Code style: black

PESTERCHUM

Pesterchum is an instant messaging client copying the look and feel of clients from Andrew Hussie's webcomic Homestuck.

Contributions in any form are very welcome!! Including for extra themes, bug fixes, features, etc. Just hmu in the support server or make a pull request :3

There's a Russian translation of this repository available, it's somewhat outdated though.

This repository is a maintained version of ghostDunk's Pesterchum, originally forked from pesterchum-karxi + Hydrothermal's fix of the "YOUR NICK IS BEING CHANGED TO X" msgbox-spam exploit.

MAIN CHANGES

INSTALLATION

  1. Download the appropriate release for your platform and architecture from releases.

  2. Extract the zip file.

  3. Run the executable:

    • For Windows, run pesterchum.exe, this may show up as just "pesterchum" if you have file extensions set to hidden.

      • Newer releases won't run on Windows XP/Vista since Python stopped supporting it.
    • For Linux, run Pesterchum.

      • Linux releases are not backwards compatible with glibc versions older than the one it was build against. The glibc version the release was build against will be included in the filename, like: PesterchumAlt.-2.2-linux64-glibc2.27.tar.gz. This really shouldn't be an issue unless your distro is absolutely ancient, if it is, run from source.
    • For macOS, run the Pesterchum.app app file, this may show up as just "Pesterchum" if you have file extensions set to hidden. Alternatively, run the binary directly from Pesterchum\Pesterchum.app\Contents\MacOS\Pesterchum.

      • macOS releases require at least 10.14 (Mojave) or older and a 64 bit processor.
      • My releases are unsigned, so you'll probably have to click "Open Anyway".

DOCUMENTATION

The old documentation can be found in docs, these have aged pretty well:

I've been adding some info to the wiki, the available pages as of me updating this readme are:

Some useful off-repo guides:

The old READMEs are also preserved in the docs folder:

RUNNING FROM SOURCE

Pesterchum is a Python script. This means that as long as you have Python installed you can run it without requiring a build/executable, this is useful if there's no compatible build for your system.

DEPENDENCIES

  • Python 3
    • Ideally 3.8 or later, though older versions may still work, I don't test them.
  • PyQt6 (prefered) or PyQt5 (legacy)
  • (Optional) certifi can provide alternative root certificates for TLS certificate validation.
    • Useful for MacOS, as Python doesn't use the system-provided certificates because of MacOS' outdated SSL library. Also miscellaneous systems without usable root certificates.

WALKTHROUGH

  1. Verify you have Python 3 and pip installed by running python --version and python -m pip --version on your system's console/terminal. If not, install Python, make sure to check to include pip and "Add to path" in the installer. If you have Python 3 but not pip, you could use get-pip.
    • On Windows, depending on your installation, Python 3 might be available with the py -3 command instead of python.
    • Some platforms, mostly Linux and macOS, might require you to run python3 instead of python. Some old installations still have Python 2 available under python.
    • On Linux it's better to install Python & pip via your package manager.
    • On macOS it's also possible to install (a more recent version of) Python via Brew.
  2. Install Pesterchum's dependencies with pip, run: python -m pip install -r requirements.txt
    • If this fails, try running python -m pip install -U pip setuptools wheel to update pip, setuptools & wheel and then trying again.
    • Alternatively, many linux distros also have packages for PyQt6.
  3. Download this repository's source, or choose the "Source Code" option on any release, and extract the archive to a folder of your choice.
    • Alternatively, clone the repository with git.
  4. Navigate your terminal to the folder you chose with cd /folder/you/chose.
    • For example, if you extracted it to your documents on Windows, run cd C:\Users\user\Documents\pesterchum-alt-servers-main.
      • Windows's cd command requires the /d flag to navigate to a different drive. (cd D:\pesterchum-alt-servers-main)
  5. Run Pesterchum by running python pesterchum.py or python3 pesterchum.py.

FREEZE / BUILD

Here's a quick guide on how to freeze Pesterchum, (that is, packaging it with python as an executable). :3

Ideally, you'll want to create and activate a virtual environment before anything else, this is not 100% required though.

PYINSTALLER

  1. python3 -m pip install pyinstaller
  2. python3 pyinst.py

SMILIES pesterchum what did you do smilie

Text Smilie
:rancorous: :rancorous: pesterchum smilie/emote
:apple: :apple: pesterchum smilie/emote
:bathearst: :bathearst: pesterchum smilie/emote
:cathearst: :cathearst: pesterchum smilie/emote
:woeful: :woeful: pesterchum smilie/emote
:sorrow: :sorrow: pesterchum smilie/emote
:pleasant: :pleasant: pesterchum smilie/emote
:blueghost: :blueghost: pesterchum smilie/emote
:slimer: :slimer: pesterchum smilie/emote
:candycorn: :candycorn: pesterchum smilie/emote
:cheer: :cheer: pesterchum smilie/emote
:duhjohn: :duhjohn: pesterchum smilie/emote
:datrump: :datrump: pesterchum smilie/emote
:facepalm: :facepalm: pesterchum smilie/emote
:bonk: :bonk: pesterchum smilie/emote
:mspa: :mspa: pesterchum smilie/emote
:gun: :gun: pesterchum smilie/emote
:cal: :cal: pesterchum smilie/emote
:amazedfirman: :amazedfirman: pesterchum smilie/emote
:amazed: :amazed: pesterchum smilie/emote
:chummy: :chummy: pesterchum smilie/emote
:cool: :cool: pesterchum smilie/emote
:smooth: :smooth: pesterchum smilie/emote
:distraughtfirman: :distraughtfirman: pesterchum smilie/emote
:distraught: :distraught: pesterchum smilie/emote
:insolent: :insolent: pesterchum smilie/emote
:bemused: :bemused: pesterchum smilie/emote
:3: :3: pesterchum smilie/emote
:mystified: :mystified: pesterchum smilie/emote
:pranky: :pranky: pesterchum smilie/emote
:tense: :tense: pesterchum smilie/emote
:record: :record: pesterchum smilie/emote
:squiddle: :squiddle: pesterchum smilie/emote
:tab: :tab: pesterchum smilie/emote
:beetip: :beetip: pesterchum smilie/emote
:flipout: :flipout: pesterchum smilie/emote
:befuddled: :befuddled: pesterchum smilie/emote
:pumpkin: :pumpkin: pesterchum smilie/emote
:trollcool: :trollcool: pesterchum smilie/emote
:jadecry: :jadecry: pesterchum smilie/emote
:ecstatic: :ecstatic: pesterchum smilie/emote
:relaxed: :relaxed: pesterchum smilie/emote
:discontent: :discontent: pesterchum smilie/emote
:devious: :devious: pesterchum smilie/emote
:sleek: :sleek: pesterchum smilie/emote
:detestful: :detestful: pesterchum smilie/emote
:mirthful: :mirthful: pesterchum smilie/emote
:manipulative: :manipulative: pesterchum smilie/emote
:vigorous: :vigorous: pesterchum smilie/emote
:perky: :perky: pesterchum smilie/emote
:acceptant: :acceptant: pesterchum smilie/emote
:olliesouty: :olliesouty: pesterchum smilie/emote
:billiards: :billiards: pesterchum smilie/emote
:billiardslarge: :billiardslarge: pesterchum smilie/emote
:whatdidyoudo: :whatdidyoudo: pesterchum smilie/emote
:brocool: :brocool: pesterchum smilie/emote
:trollbro: :trollbro: pesterchum smilie/emote
:playagame: :playagame: pesterchum smilie/emote
:trollc00l: :trollc00l: pesterchum smilie/emote
:suckers: :suckers: pesterchum smilie/emote
:scorpio: :scorpio: pesterchum smilie/emote
:shades: :shades: pesterchum smilie/emote
:honk: :honk: pesterchum smilie/emote