pomoglorbo


Namepomoglorbo JSON
Version 2024.11.22 PyPI version JSON
download
home_pagehttps://codeberg.org/justusw/Pomoglorbo
SummaryTerminal Pomodoro timer
upload_time2024-11-22 00:27:46
maintainerJustus Perlwitz
docs_urlNone
authorBhathiya Perera
requires_python<4.0,>=3.10
licenseMIT
keywords tomato pomodoro pomoglorbo pydoro timer work
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <!--
SPDX-FileCopyrightText: 2023 Justus Perlwitz
SPDX-FileCopyrightText: 2024 Justus Perlwitz
SPDX-FileCopyrightText: 2021-2023 Bhatihya Perera

SPDX-License-Identifier: MIT
-->

Links: [PyPI](https://pypi.org/project/pomoglorbo/)
[Codeberg](https://codeberg.org/justusw/Pomoglorbo)

# Pomoglorbo

A Pomodoro Technique timer for your terminal! Runs over SSH! A bell rings
when your Pomodoro is over!

_muuuuuust haaaaaaaveeeeee_

![A screenshot of Pomoglorbo running in alacritty on
macOS](docs/pomoglorbo.png)

But what are Pomodoros? And why would I run this in my terminal? Read my [blog
post about
Pomoglorbo](https://www.justus.pw/posts/2024-06-18-try-pomoglorbo.html) for
more info.

## Installation

__Recommended__: Install using
[pipx](https://pipx.pypa.io/stable/#install-pipx):

```bash
pipx install pomoglorbo
```

Then run using

```bash
pomoglorbo
```

You can also install using `pip`, if you don't mind clobbering packages:

```bash
pip3 install --user pomoglorbo
```

### With Nix

For [NixOS](https://nixos.org/) or [Home
Manager](https://nix-community.github.io/home-manager/) users, you can also use
and install Pomoglorbo as a [Nix
Flake](https://hydra.nixos.org/build/263397466/download/1/manual/command-ref/new-cli/nix3-flake.html#description).

The easiest way is to use `nix run` with this Codeberg repository:

```bash
nix run git+https://codeberg.org/justusw/Pomoglorbo.git
```

If you want to pass additional arguments, append a `--` argument separator
first, and you are good to go:

```bash
nix run git+https://codeberg.org/justusw/Pomoglorbo.git -- --audio-check
```

It's almost a bit too magical. Reproducible builds? Poetry packages? Builds on
many different systems? _whooooosh_ Nix is the cave allegory of build systems.

This is how you can add it to your Home Manager configuration, if you use [Nix
Flakes with Home
Manager](https://nix-community.github.io/home-manager/index.xhtml#ch-usage):

```nix
{
  description = "My awesome nix home manager configuration";

  inputs = {
    nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.11";
    pomoglorbo = {
      url = "git+https://codeberg.org/justusw/Pomoglorbo.git";
      inputs.nixpkgs.follows = "nixpkgs";
    };
  };

  outputs = { self, nixpkgs, pomoglorbo }: {
    # do what you must here
  };
}
```

How to evaluate package size:

```bash
nix run github:utdemir/nix-tree -- --derivation .#pomoglorbo
```

Do you want to know more about Nix Flakes? I recommend these posts by Xe Iaso:

- [Nix Flakes: an
Introduction](https://xeiaso.net/blog/nix-flakes-1-2022-02-21/)
- [Building Go programs with Nix
Flakes](https://xeiaso.net/blog/nix-flakes-go-programs/)

## Usage

See `pomoglorbo --help` for a complete overview of available options. At the
time of writing, these are all available flags:

<!--
poetry run src/pomoglorbo/cli/__init__.py --help | sed -n -E -e 's/^  (.+)/\1/p'
-->

```
-h, --help            show this help message and exit
--no-sound            Mute alarm
--audio-check         Play alarm and exit
-v, --version         Display version and exit
--audio-file path     Custom audio file for alarm
--config-file path    Use a different config file. Overrides POMOGLORBO_CONFIG_FILE environment variable. Default is "$XDG_CONFIG_HOME/pomoglorbo/config.ini".
--work-state-cmd-suffix suffix [suffix ...]
                      Append these arguments to external command invocation when starting the next Pomodoro
```

## Configure Pomoglorbo

A configuration file is automatically created in
`$XDG_CONFIG_HOME/pomoglorbo/config.ini` when you launch Pomoglorbo. You can
customize how Pomoglorbo behaves. The default configuration can be found in
`src/pomoglorbo/core/config.py` under `DEFAULT_CONFIG`.

### Use a different audio file

Set the following in your `config.ini` file:

```ini
[General]
audio_file = path/to/your/audio/file.ogg
```

or run Pomoglorbo with the following flag:

```bash
pomoglorbo --audio-file path/to/your/audio/file.ogg
```

If you want to just check whether the sound plays correctly, add the
`--audio-check` flag as well.

```bash
pomoglorbo --audio-file path/to/your/audio/file.ogg --audio-check
```

### Change Pomodoro intervals

The duration of work and break times can be set using the following variables
in your configuration file:

```ini
[Time]
# How many tomatoes need to elapse to get to a long break
tomatoes_per_set = 4
# Duration of a single pomodoro in minutes
work_minutes = 25
# Duration of a short break between Pomodoros in minutes
small_break_minutes = 5
# Duration of a long break after a set, in minutes
long_break_minutes = 15
```

### Change key bindings

The default key bindings are:

<!-- Please update me if needed -->

- Focus previous: shift-tab, up, left, h, or k
- Focus next: tab, right, down, l, or j
- Exit: q
- Start: s
- Pause: p
- Reset: r
- Reset all: a
- Help: ? or f1

While Pomoglorbo is running, you can always review the current keybindings
by opening the help menu. You can open the help menu by pressing `?` or F1

You can customize Pomoglorbo TUI key bindings using the following configuration
variables, illustrated with some examples values:

```ini
[KeyBindings]
# Focus on previous button in TUI
focus_previous = s-tab
# Focus on next button in TUI
focus_next = tab
# Quit Pomoglorbo
exit_clicked = q
# Start the next Pomodoro or break
start = s
# Pause the current Pomodoro or break
pause = p
# Reset elapsed time of current Pomodoro or break
reset = r
# Reset elapsed time, go back to 0 elapsed Pomodoros (see tomatoes_per_set)
reset_all = a
# Show current key bindings
help = ?
```

You can find more documentation on keybindings on `prompt_toolkit`s documentation
site
[here](https://python-prompt-toolkit.readthedocs.io/en/master/pages/advanced_topics/key_bindings.html#list-of-special-keys).

### Run a command when something happens (Triggers)

You can configure Pomoglorbo to execute a command for you automatically when
one of the following things happens:

- A new Pomodoro is started
- A Pomodoro is paused
- A Pomodoro is resumed
- A long break is started
- A short break is started
- A break is over
- Pomoglorbo exits

The commands can be given as string array-like string in the configuration file
section `Trigger`. A good use case for this is automatically starting time
tracking in time tracking software like
[Timewarrior](https://timewarrior.net/). Here are some ideas on what you can
put in each command.

```ini
[Trigger]
work_state_cmd = ["curl", "https://example.com"]
work_paused_state_cmd = ["timew", "stop"]
work_resumed_state_cmd = ["timew", "start"]
long_break_state_cmd = ["i3lock"]
small_break_state_cmd = ["timew", "start", "break"]
break_over_cmd = ["timew", "stop"]
exit_cmd = ["espeak", "bye"]
```

*Note from Justus*: But that's not all! Here's something I do a lot. When I
start Pomoglorbo, I want it to start Timewarrior with a specific tag. The work
state command is `timew start`, which would start time tracking without any
tags. I can then add `--work-state-cmd-suffix` when calling Pomoglorbo like so:

```bash
pomoglorbo --work-state-cmd-suffix development pomoglorbo
```

Pomoglorbo will call `timew` for me when the next Pomodoro starts like so:

```bash
timew start development pomoglorbo
```

This could be extended to the other commands as well, if required. Patches are
very welcome here.

## Development

To start developing Pomoglorbo this, clone this repository from Codeberg:

```bash
git clone https://codeberg.org/justusw/Pomoglorbo.git
```

Use [poetry](https://python-poetry.org/docs/#installation) to install all
dependencies:

```bash
# This will install packages used for testing as well
poetry install --all-extras
```

Run Pomoglorbo inside the poetry virtual environment using the following
command:

```bash
poetry run src/pomoglorbo/cli/__init__.py
```

You can additionally specify a config file to be used like so:

```bash
poetry run src/pomoglorbo/cli/__init__.py --config-file test/config.ini
```

### Testing

Run all tests and formatters using

```bash
poetry run bin/test.sh
```

Format code using

```bash
poetry run bin/format.sh
```

### Translations

Provided you have the development requirements from the Poetry file installed,
you can translate strings like so:

__Mark a string for translation__: If you want to mark a string for
translation, you have to mark it using
[gettext](https://docs.python.org/3/library/gettext.html). For example, if you
want to print the string "Hello, World!" and automatically translate it, write
the following:

```python
# Assuming this file is called source_file.py
from pomoglorbo.cli.util import gettext_lazy as _
print(_("Hello, World!))
```

We use our own `gettext_lazy` here (similar to Django), to make sure that
strings are not translated at module import time.

__Extract strings__: Run

```bash
bin/pybabel-update.sh
```

This will populate all message catalogs for the languages in
`src/pomoglorbo/messages/`. You will see a new string added to each `.po`
file and the `.pot` file. Edit the new message and translate it. Here, we
translate it into German.

```po
#: source_file.py
msgid "Hello, World!"
msgstr "Hallo, Welt!"
```

__Compile message catalogs__: Now, you have to compile the translations into MO
files.

```bash
bin/pybabel-compile.sh
```

And you are done.

The translation uses GNU Gettext, the Python `gettext` module and
[Babel](https://babel.pocoo.org/en/latest/index.html). Refer to Babel's
[Command-Line Interface help](https://babel.pocoo.org/en/latest/cmdline.html)
to learn more about how the `bin/pybabel-*.sh` commands work.

## Contributing

Would you like to make a contribution? Your ideas are very welcome as this is
an open source project welcoming all contributors! Please read the
[CONTRIBUTING.md](CONTRIBUTING.md) file for more info. Please also refer to the
[Code of Conduct](CODE_OF_CONDUCT.md).

## Credits

Pomoglorbo is a fork of the original
[pydoro](https://github.com/JaDogg/pydoro).

- [pydoro](https://github.com/JaDogg/pydoro) - by Bhathiya Perera
- Pomodoro - Invented by Francesco Cirillo
- prompt-toolkit - Awesome TUI library
- b15.wav - [Dana](https://freesound.org/s/377639/) robinson designs,
  CC0 from freesound

See the `CONTRIBUTORS` file in the root directory for a list of contributors to
the original pydoro project.

## Copyright

See the LICENSES folder for more information.

            

Raw data

            {
    "_id": null,
    "home_page": "https://codeberg.org/justusw/Pomoglorbo",
    "name": "pomoglorbo",
    "maintainer": "Justus Perlwitz",
    "docs_url": null,
    "requires_python": "<4.0,>=3.10",
    "maintainer_email": "justus@jwpconsulting.net",
    "keywords": "tomato, pomodoro, pomoglorbo, pydoro, timer, work",
    "author": "Bhathiya Perera",
    "author_email": "jadogg.coder@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/59/12/9e590533d3f047afe2ae940e156313d76d85dea3445e6f5ffe0cf80cdfbe/pomoglorbo-2024.11.22.tar.gz",
    "platform": null,
    "description": "<!--\nSPDX-FileCopyrightText: 2023 Justus Perlwitz\nSPDX-FileCopyrightText: 2024 Justus Perlwitz\nSPDX-FileCopyrightText: 2021-2023 Bhatihya Perera\n\nSPDX-License-Identifier: MIT\n-->\n\nLinks: [PyPI](https://pypi.org/project/pomoglorbo/)\n[Codeberg](https://codeberg.org/justusw/Pomoglorbo)\n\n# Pomoglorbo\n\nA Pomodoro Technique timer for your terminal! Runs over SSH! A bell rings\nwhen your Pomodoro is over!\n\n_muuuuuust haaaaaaaveeeeee_\n\n![A screenshot of Pomoglorbo running in alacritty on\nmacOS](docs/pomoglorbo.png)\n\nBut what are Pomodoros? And why would I run this in my terminal? Read my [blog\npost about\nPomoglorbo](https://www.justus.pw/posts/2024-06-18-try-pomoglorbo.html) for\nmore info.\n\n## Installation\n\n__Recommended__: Install using\n[pipx](https://pipx.pypa.io/stable/#install-pipx):\n\n```bash\npipx install pomoglorbo\n```\n\nThen run using\n\n```bash\npomoglorbo\n```\n\nYou can also install using `pip`, if you don't mind clobbering packages:\n\n```bash\npip3 install --user pomoglorbo\n```\n\n### With Nix\n\nFor [NixOS](https://nixos.org/) or [Home\nManager](https://nix-community.github.io/home-manager/) users, you can also use\nand install Pomoglorbo as a [Nix\nFlake](https://hydra.nixos.org/build/263397466/download/1/manual/command-ref/new-cli/nix3-flake.html#description).\n\nThe easiest way is to use `nix run` with this Codeberg repository:\n\n```bash\nnix run git+https://codeberg.org/justusw/Pomoglorbo.git\n```\n\nIf you want to pass additional arguments, append a `--` argument separator\nfirst, and you are good to go:\n\n```bash\nnix run git+https://codeberg.org/justusw/Pomoglorbo.git -- --audio-check\n```\n\nIt's almost a bit too magical. Reproducible builds? Poetry packages? Builds on\nmany different systems? _whooooosh_ Nix is the cave allegory of build systems.\n\nThis is how you can add it to your Home Manager configuration, if you use [Nix\nFlakes with Home\nManager](https://nix-community.github.io/home-manager/index.xhtml#ch-usage):\n\n```nix\n{\n  description = \"My awesome nix home manager configuration\";\n\n  inputs = {\n    nixpkgs.url = \"github:NixOS/nixpkgs/nixos-23.11\";\n    pomoglorbo = {\n      url = \"git+https://codeberg.org/justusw/Pomoglorbo.git\";\n      inputs.nixpkgs.follows = \"nixpkgs\";\n    };\n  };\n\n  outputs = { self, nixpkgs, pomoglorbo }: {\n    # do what you must here\n  };\n}\n```\n\nHow to evaluate package size:\n\n```bash\nnix run github:utdemir/nix-tree -- --derivation .#pomoglorbo\n```\n\nDo you want to know more about Nix Flakes? I recommend these posts by Xe Iaso:\n\n- [Nix Flakes: an\nIntroduction](https://xeiaso.net/blog/nix-flakes-1-2022-02-21/)\n- [Building Go programs with Nix\nFlakes](https://xeiaso.net/blog/nix-flakes-go-programs/)\n\n## Usage\n\nSee `pomoglorbo --help` for a complete overview of available options. At the\ntime of writing, these are all available flags:\n\n<!--\npoetry run src/pomoglorbo/cli/__init__.py --help | sed -n -E -e 's/^  (.+)/\\1/p'\n-->\n\n```\n-h, --help            show this help message and exit\n--no-sound            Mute alarm\n--audio-check         Play alarm and exit\n-v, --version         Display version and exit\n--audio-file path     Custom audio file for alarm\n--config-file path    Use a different config file. Overrides POMOGLORBO_CONFIG_FILE environment variable. Default is \"$XDG_CONFIG_HOME/pomoglorbo/config.ini\".\n--work-state-cmd-suffix suffix [suffix ...]\n                      Append these arguments to external command invocation when starting the next Pomodoro\n```\n\n## Configure Pomoglorbo\n\nA configuration file is automatically created in\n`$XDG_CONFIG_HOME/pomoglorbo/config.ini` when you launch Pomoglorbo. You can\ncustomize how Pomoglorbo behaves. The default configuration can be found in\n`src/pomoglorbo/core/config.py` under `DEFAULT_CONFIG`.\n\n### Use a different audio file\n\nSet the following in your `config.ini` file:\n\n```ini\n[General]\naudio_file = path/to/your/audio/file.ogg\n```\n\nor run Pomoglorbo with the following flag:\n\n```bash\npomoglorbo --audio-file path/to/your/audio/file.ogg\n```\n\nIf you want to just check whether the sound plays correctly, add the\n`--audio-check` flag as well.\n\n```bash\npomoglorbo --audio-file path/to/your/audio/file.ogg --audio-check\n```\n\n### Change Pomodoro intervals\n\nThe duration of work and break times can be set using the following variables\nin your configuration file:\n\n```ini\n[Time]\n# How many tomatoes need to elapse to get to a long break\ntomatoes_per_set = 4\n# Duration of a single pomodoro in minutes\nwork_minutes = 25\n# Duration of a short break between Pomodoros in minutes\nsmall_break_minutes = 5\n# Duration of a long break after a set, in minutes\nlong_break_minutes = 15\n```\n\n### Change key bindings\n\nThe default key bindings are:\n\n<!-- Please update me if needed -->\n\n- Focus previous: shift-tab, up, left, h, or k\n- Focus next: tab, right, down, l, or j\n- Exit: q\n- Start: s\n- Pause: p\n- Reset: r\n- Reset all: a\n- Help: ? or f1\n\nWhile Pomoglorbo is running, you can always review the current keybindings\nby opening the help menu. You can open the help menu by pressing `?` or F1\n\nYou can customize Pomoglorbo TUI key bindings using the following configuration\nvariables, illustrated with some examples values:\n\n```ini\n[KeyBindings]\n# Focus on previous button in TUI\nfocus_previous = s-tab\n# Focus on next button in TUI\nfocus_next = tab\n# Quit Pomoglorbo\nexit_clicked = q\n# Start the next Pomodoro or break\nstart = s\n# Pause the current Pomodoro or break\npause = p\n# Reset elapsed time of current Pomodoro or break\nreset = r\n# Reset elapsed time, go back to 0 elapsed Pomodoros (see tomatoes_per_set)\nreset_all = a\n# Show current key bindings\nhelp = ?\n```\n\nYou can find more documentation on keybindings on `prompt_toolkit`s documentation\nsite\n[here](https://python-prompt-toolkit.readthedocs.io/en/master/pages/advanced_topics/key_bindings.html#list-of-special-keys).\n\n### Run a command when something happens (Triggers)\n\nYou can configure Pomoglorbo to execute a command for you automatically when\none of the following things happens:\n\n- A new Pomodoro is started\n- A Pomodoro is paused\n- A Pomodoro is resumed\n- A long break is started\n- A short break is started\n- A break is over\n- Pomoglorbo exits\n\nThe commands can be given as string array-like string in the configuration file\nsection `Trigger`. A good use case for this is automatically starting time\ntracking in time tracking software like\n[Timewarrior](https://timewarrior.net/). Here are some ideas on what you can\nput in each command.\n\n```ini\n[Trigger]\nwork_state_cmd = [\"curl\", \"https://example.com\"]\nwork_paused_state_cmd = [\"timew\", \"stop\"]\nwork_resumed_state_cmd = [\"timew\", \"start\"]\nlong_break_state_cmd = [\"i3lock\"]\nsmall_break_state_cmd = [\"timew\", \"start\", \"break\"]\nbreak_over_cmd = [\"timew\", \"stop\"]\nexit_cmd = [\"espeak\", \"bye\"]\n```\n\n*Note from Justus*: But that's not all! Here's something I do a lot. When I\nstart Pomoglorbo, I want it to start Timewarrior with a specific tag. The work\nstate command is `timew start`, which would start time tracking without any\ntags. I can then add `--work-state-cmd-suffix` when calling Pomoglorbo like so:\n\n```bash\npomoglorbo --work-state-cmd-suffix development pomoglorbo\n```\n\nPomoglorbo will call `timew` for me when the next Pomodoro starts like so:\n\n```bash\ntimew start development pomoglorbo\n```\n\nThis could be extended to the other commands as well, if required. Patches are\nvery welcome here.\n\n## Development\n\nTo start developing Pomoglorbo this, clone this repository from Codeberg:\n\n```bash\ngit clone https://codeberg.org/justusw/Pomoglorbo.git\n```\n\nUse [poetry](https://python-poetry.org/docs/#installation) to install all\ndependencies:\n\n```bash\n# This will install packages used for testing as well\npoetry install --all-extras\n```\n\nRun Pomoglorbo inside the poetry virtual environment using the following\ncommand:\n\n```bash\npoetry run src/pomoglorbo/cli/__init__.py\n```\n\nYou can additionally specify a config file to be used like so:\n\n```bash\npoetry run src/pomoglorbo/cli/__init__.py --config-file test/config.ini\n```\n\n### Testing\n\nRun all tests and formatters using\n\n```bash\npoetry run bin/test.sh\n```\n\nFormat code using\n\n```bash\npoetry run bin/format.sh\n```\n\n### Translations\n\nProvided you have the development requirements from the Poetry file installed,\nyou can translate strings like so:\n\n__Mark a string for translation__: If you want to mark a string for\ntranslation, you have to mark it using\n[gettext](https://docs.python.org/3/library/gettext.html). For example, if you\nwant to print the string \"Hello, World!\" and automatically translate it, write\nthe following:\n\n```python\n# Assuming this file is called source_file.py\nfrom pomoglorbo.cli.util import gettext_lazy as _\nprint(_(\"Hello, World!))\n```\n\nWe use our own `gettext_lazy` here (similar to Django), to make sure that\nstrings are not translated at module import time.\n\n__Extract strings__: Run\n\n```bash\nbin/pybabel-update.sh\n```\n\nThis will populate all message catalogs for the languages in\n`src/pomoglorbo/messages/`. You will see a new string added to each `.po`\nfile and the `.pot` file. Edit the new message and translate it. Here, we\ntranslate it into German.\n\n```po\n#: source_file.py\nmsgid \"Hello, World!\"\nmsgstr \"Hallo, Welt!\"\n```\n\n__Compile message catalogs__: Now, you have to compile the translations into MO\nfiles.\n\n```bash\nbin/pybabel-compile.sh\n```\n\nAnd you are done.\n\nThe translation uses GNU Gettext, the Python `gettext` module and\n[Babel](https://babel.pocoo.org/en/latest/index.html). Refer to Babel's\n[Command-Line Interface help](https://babel.pocoo.org/en/latest/cmdline.html)\nto learn more about how the `bin/pybabel-*.sh` commands work.\n\n## Contributing\n\nWould you like to make a contribution? Your ideas are very welcome as this is\nan open source project welcoming all contributors! Please read the\n[CONTRIBUTING.md](CONTRIBUTING.md) file for more info. Please also refer to the\n[Code of Conduct](CODE_OF_CONDUCT.md).\n\n## Credits\n\nPomoglorbo is a fork of the original\n[pydoro](https://github.com/JaDogg/pydoro).\n\n- [pydoro](https://github.com/JaDogg/pydoro) - by Bhathiya Perera\n- Pomodoro - Invented by Francesco Cirillo\n- prompt-toolkit - Awesome TUI library\n- b15.wav - [Dana](https://freesound.org/s/377639/) robinson designs,\n  CC0 from freesound\n\nSee the `CONTRIBUTORS` file in the root directory for a list of contributors to\nthe original pydoro project.\n\n## Copyright\n\nSee the LICENSES folder for more information.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Terminal Pomodoro timer",
    "version": "2024.11.22",
    "project_urls": {
        "Homepage": "https://codeberg.org/justusw/Pomoglorbo",
        "Repository": "https://codeberg.org/justusw/Pomoglorbo"
    },
    "split_keywords": [
        "tomato",
        " pomodoro",
        " pomoglorbo",
        " pydoro",
        " timer",
        " work"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "836ff296b92997b537abfbd39fe37a238d66d5812d0438e74deddafd049a6615",
                "md5": "11a1d79017d8fba694fe0f0d3803bde1",
                "sha256": "f49df8dd184f54080022d38b25bc5d8d54c3adadcb34d9576874b4fc6ce4ffbd"
            },
            "downloads": -1,
            "filename": "pomoglorbo-2024.11.22-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "11a1d79017d8fba694fe0f0d3803bde1",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.10",
            "size": 502433,
            "upload_time": "2024-11-22T00:27:44",
            "upload_time_iso_8601": "2024-11-22T00:27:44.900350Z",
            "url": "https://files.pythonhosted.org/packages/83/6f/f296b92997b537abfbd39fe37a238d66d5812d0438e74deddafd049a6615/pomoglorbo-2024.11.22-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "59129e590533d3f047afe2ae940e156313d76d85dea3445e6f5ffe0cf80cdfbe",
                "md5": "238a321563706d020629494da9e43788",
                "sha256": "c3e2a86acca4190289314809b54602f531682cb64a35b716de8e8055935af758"
            },
            "downloads": -1,
            "filename": "pomoglorbo-2024.11.22.tar.gz",
            "has_sig": false,
            "md5_digest": "238a321563706d020629494da9e43788",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.10",
            "size": 496376,
            "upload_time": "2024-11-22T00:27:46",
            "upload_time_iso_8601": "2024-11-22T00:27:46.526638Z",
            "url": "https://files.pythonhosted.org/packages/59/12/9e590533d3f047afe2ae940e156313d76d85dea3445e6f5ffe0cf80cdfbe/pomoglorbo-2024.11.22.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-22 00:27:46",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": true,
    "codeberg_user": "justusw",
    "codeberg_project": "Pomoglorbo",
    "lcname": "pomoglorbo"
}
        
Elapsed time: 2.65118s