Create your own Shit Happens playing cards!
Project description
Customized Shit Happens
Create your own Shit Happens playing cards!
Explore the docs »
Report Bug
·
Request Feature
Table of Contents
About The Project
Ever wanted to play with your own Shit Happens playing cards? Now you can. Write down the most miserable situations you can think of and rank them. This project automatically outputs playing cards in pdf format.
This project is not related to the original card game. Open an issue in case of any objections.
Built With
Getting Started
Prerequisites
A virtual environment with python 3.11 or higher.
Installation
Run
pip install shithappens
from within the target environment.
To allow for pdf merging, run pip install shithappens[merge]
.
To show a progressbar, run pip install shithappens[pbar]
.
To install all dependencies, run pip install shithappens[all]
.
Installing for developers
Retrieve the latest version of the code
Developers should fork this repository and run
git clone https://github.com/<your-username>/shit-happens.git
This will place the sources in a directory shit-happens
below your current working directory, set up the origin
remote to point to your own fork, and set up the upstream
remote to point to the shit-happens
main repository.
Change into this directory before continuing:
cd shit-happens
Create a dedicated environment
You should set up a dedicated environment to decouple your shithappens development from other Python and shithappens installations on your system.
The simplest way to do this is to use either Python's virtual environment venv or conda. Here, instructions for conda are shown. If mamba is installed, replace conda with mamba in the commands below.
conda env create -f environment.yml
Activate the environment using
conda activate shithappens-dev
Remember to activate the environment whenever you start working on shithappens.
Installing shithappens in editable mode
Install shithappens in editable mode from the shithappens directory using the command
python -m pip install -e .
The 'editable/develop mode', builds everything and places links in your Python environment so that Python will be able to import shithappens from your development source directory. This allows you to import your modified version of shithappens without re-installing after every change.
Usage
CLI
The tool is available as a command line interface (CLI). It requires an Excel file in the input directory (default current working directory). The excel files must have two columns with any header. The first column must contain the miserable situations. The second column must contain the corresponding misery indices. See the examples directory for an example.
usage: shithappens [-h] [-n NAME] [-m | --merge | --no-merge] [-s {front,back,both}] [-l {en,nl}] [-f {pdf,png}] [-r | --rank | --no-rank] [-w WORKERS] [-c CHUNKS] [input_dir]
help:
-h, --help show this help message and exit
input:
input_dir Input directory. Defaults to current working directory.
options:
-n NAME, --name NAME Expansion name. If no name is specified, infers name from input_dir.
-m, --merge, --no-merge
Merge output. Defaults to --no-merge
-s {front,back,both}, --side {front,back,both}
Side(s) to generate. Defaults to both.
-f {pdf,png}, --format {pdf,png}
Output format. 'pdf' and 'png' supported. Defaults to 'pdf'.
-r, --rank, --no-rank
Rank situations and output in new file. Does not guarantee a linear ranking, i.e. situations can have equal misery index. Ignores all other options. Defaults to --no-rank.
multiprocessing:
-w WORKERS, --workers WORKERS
Number of workers. Defaults to 4.
-c CHUNKS, --chunks CHUNKS
Number of chunks for the workers to process. Defaults to 30.
The input directory must be structured as follows:
expansion
├───images
│ └───expansion-logo.*
├───outputs
│ ├───back
│ └───front
└───*.xlsx
If the output folder does not exist, it will be created. The format of the expansion logo must be on this list.
Contributing
Any contributions you make are greatly appreciated.
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/AmazingFeature
) - Commit your Changes (
git commit -m 'Add some AmazingFeature'
) - Push to the Branch (
git push origin feature/AmazingFeature
) - Open a Pull Request
License
Distributed under the GPL-3.0 license. See LICENSE
for more information.
Contact
Project Link: https://github.com/siemdejong/shit-happens
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file shithappens-4.0.1.tar.gz
.
File metadata
- Download URL: shithappens-4.0.1.tar.gz
- Upload date:
- Size: 58.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d4bc76f7ece6d0b3dcd05097704ddee0cb9c943bc90e045ac12a28ea16783095 |
|
MD5 | f0b9862d3775e6dcd9e9eb197bbd6905 |
|
BLAKE2b-256 | 15033d2faf00375e6d7fc075eaf98bc561c75caf7564c129cc0bb6c0ad1529e5 |
File details
Details for the file shithappens-4.0.1-py3-none-any.whl
.
File metadata
- Download URL: shithappens-4.0.1-py3-none-any.whl
- Upload date:
- Size: 44.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6fd9051f774f88717a8261f331fb0e6643f73d671cb9dc9e5b1579381e9a1838 |
|
MD5 | 46ecb28ecc9da601fc96e183c197670e |
|
BLAKE2b-256 | b08705c8b3ccbf01b14e04a883df9afb5b03b73c7644f574067e346f5a608bc3 |