Skip to content

Sacul0457/meanings

Repository files navigation

🤖 Meanings Bot

License Last Commit Top Language Repo Size Code Size Commit Activity

A sleek Discord bot to manage and explore slang meanings, built with Python. Offers public commands for all and admin tools for whitelisted users. Runs on Linux with systemd support!

✨ Features

  • Public Commands: ?meaning, ?list, ?stats, ?ping
  • Admin Commands: ?addmeaning, ?deletemeaning, ?yes, ?no (whitelisted only)
  • DND Status: Watches servers with a "Do Not Disturb" flair
  • Scalable: Handles multiple servers effortlessly
  • Commands Check this for all commands
  • Async file handling with aiofiles
  • Fully Poetry-managed project with isolated dependencies

Requirements

  • Python 3.12+
  • Poetry 2.x
  • Discord bot token (.env file)
  • Curl 8.15.x
  • Git

🚀 Getting Started

  1. Clone the repo:
    git clone https://github.com/xFanexx/meanings.git

Install Poetry (if not installed)

  1. From offical site:
  • Linux, macOS, Windows (WSL)
    curl -sSL https://install.python-poetry.org | python3 -
  • Windows (Powershell)
    (Invoke-WebRequest -Uri https://install.python-poetry.org -UseBasicParsing).Content | py -

Note

If you have installed Python through the Microsoft Store, replace py with python in the command above.

Check their offical Documentation for more information. Python-Poerty

  1. With PIP:
pip install poetry

Important

When you are installing Poetry via pip, always check if Rust is installed in your system because one of its dependencies (maturin) needs Rust to build and top of that do not forget to update pip or its prebuilt wheels. So, you don't get any errors.

Install dependencies

poetry install

Note

This installs all dependencies listed in pyproject.toml inside a virtual environment.

For Non-Poetry Users

If you don’t have Poetry installed, you can still run this project using only pip and requirements.txt.

Installation

pip install -r requirements.txt

Updating Dependencies (PIP)

  1. Upgrade a single dependency:
pip install --upgrade <package-name>

Example:

pip install --upgrade discord.py

Then regenerate requirements.txt:

pip freeze > requirements.txt
  1. Upgrade all dependencies:
pip install --upgrade -r requirements.txt

Warning

This respects the pinned versions in requirements.txt. If you want latest versions, remove version numbers from the file before running.

Regenerate requirements.txt

After any upgrade:

pip freeze > requirements.txt

Tip

Using pyproject.toml with Poetry is recommended for consistent, reproducible environments — but requirements.txt works for quick installs and deployment.

Environment Variables

Create a .env file in the project root:

DISCORD_TOKEN=your_discord_token_here

Important

Do not commit .env to version control.

Updating Dependencies

  • To update a single dependency:
poetry update discord-py
  • To update all dependencies:
poetry update
  • Regenerate requirements.txt after updates:
source $(poetry env info --path)/bin/activate
pip freeze > requirements.txt
deactivate

Contributing

  • Fork the Repo.

  • Make sure .env and .venv/ are ignored in Git (.gitignore is included).

  • Commit pyproject.toml and poetry.lock to track dependencies.

  • PR should be clean, concise and descriptive.

  • Use Poetry for adding new packages in your project:

poetry add <package-name>      # normal dependency
poetry add --dev <package-name> # dev dependency

Warning

THIS MIGHT BE PRODUCTION READY, BUT YOU MIGHT CONSIDER RE-WRITING THE CODE AND SWITCHING TO A SQLITE OR POSTGRESQL DB.

Note

THIS IS A PURE HOBBY BOT INTENDED TO HAVE SOME FUN IN DISCORD CHANNELS.

👥 Contributors

Sacul0457
Sacul0457
xFanexx
xFanexx
Chandramauli
Chandramauli

About

A Discord bot to manage and share slang meanings, featuring public commands.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages