lirc


Namelirc JSON
Version 3.0.0 PyPI version JSON
download
home_pagehttps://github.com/eugenetriguba/lirc
SummaryInteract with the daemon in the Linux Infrared Remote Control package
upload_time2024-10-20 19:44:40
maintainerNone
docs_urlNone
authorEugene Triguba
requires_python<4.0,>=3.9
licenseMIT
keywords lirc ir
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            LIRC Python Package
===================

.. image:: https://img.shields.io/pypi/pyversions/lirc
   :target: https://www.python.org/downloads/
   :alt: Python Version
.. image:: https://img.shields.io/pypi/v/lirc
   :target: https://pypi.org/project/lirc/
   :alt: Project Version
.. image:: https://readthedocs.org/projects/lirc/badge/?version=latest
  :target: https://lirc.readthedocs.io/en/latest/?badge=latest
  :alt: Documentation Status
.. image:: https://github.com/eugenetriguba/lirc/actions/workflows/test.yml/badge.svg?branch=main
  :target: https://github.com/eugenetriguba/lirc/actions/
  :alt: Build Status
.. image:: https://codecov.io/gh/eugenetriguba/lirc/graph/badge.svg
  :target: https://codecov.io/gh/eugenetriguba/lirc
  :alt: Code Coverage
.. image:: https://api.codeclimate.com/v1/badges/62b96571ae84f2895531/maintainability
   :target: https://codeclimate.com/github/eugenetriguba/lirc/maintainability
   :alt: Maintainability
.. image:: https://img.shields.io/badge/code%20style-black-000000.svg
    :target: https://github.com/psf/black
    :alt: Code Formatter
.. image:: https://img.shields.io/badge/contributions-welcome-brightgreen.svg
    :target: https://github.com/eugenetriguba/lirc/issues
    :alt: Contributing
.. image:: https://img.shields.io/pypi/l/lirc
   :target: https://pypi.python.org/pypi/lirc/
   :alt: License
.. image:: https://img.shields.io/badge/platform-linux%20%7C%20macos%20%7C%20windows-%23F9F9F9
   :target: https://lirc.readthedocs.io/en/latest/installation.html
   :alt: Platform Support

This is a python package that allows you to interact with the daemon in the
`Linux Infrared Remote Control <https://lirc.org>`_ package. By interacting
with this daemon, it allows you to programmatically send IR signals from a
computer.

This package is for emitting IR signals, but it does not support listening to
IR codes. If you'd like to monitor the IR signals you recieve on
Linux, which has built-in support in the kernel for recieving IR signals, you
can try using `python-evdev <https://python-evdev.readthedocs.io/en/latest/>`_.
They have a `tutorial on reading the events <https://python-evdev.readthedocs.io/en/latest/tutorial.html#reading-events>`_.

More information on the lircd daemon, socket interface,
reply packet format, etc. can be found at https://www.lirc.org/html/lircd.html

Maintainance Status
-------------------

This project is maintained, but it is not actively developed.
It is feature complete for my purposes.

Installation
------------

This package is hosted on PyPI and can be installed
through pip.

.. code-block:: bash

  $ pip install lirc

However since this is a wrapper around the LIRC daemon, it
is expected that LIRC is installed and setup on the given
system as well.

More information on that can be found in the `installation <https://lirc.readthedocs.io/en/latest/installation.html>`_
portion of the full documentation.

Quick Start
-----------

Using the Client
^^^^^^^^^^^^^^^^

.. code-block:: python

  import lirc

  client = lirc.Client()

  print(client.version())
  >>> '0.10.1'

To use this package, we instantiate a ``Client``. By initializing it
with no arguments, the ``Client`` will attempt to connect to the lirc
daemon with the default connection parameters for your operating system.

These defaults depend on your operating system and can be looked up in the
full documentation if you need different parameters.

However, if you've instantiated the ``Client`` without any arguments,
you don't get any errors, and you recieve a response from the ``version()``
command, you are connected to the daemon. Most people should not need to
change the default parameters.

Customizing the Client
^^^^^^^^^^^^^^^^^^^^^^

As previously stated, we can customize these defaults if needed.

.. code-block:: python

  import socket
  import lirc

  client = lirc.Client(
    connection=lirc.LircdConnection(
      address="/var/run/lirc/lircd",
      socket=socket.socket(socket.AF_UNIX, socket.SOCK_STREAM),
      timeout = 5.0
    )
  )

For the client in the example above, we set it up using the defaults for a Linux machine.
While this example illustrates what is customizable, it is not a practical example since
you could call ``Client()`` with no arguments if you're on Linux and achieve the same outcome.

See `Overriding LIRC Defaults on Initialization <https://lirc.readthedocs.io/en/stable/usage.html#overriding-lirc-defaults-on-initialization>`_
for more information.

Sending IR
^^^^^^^^^^

.. code-block:: python

  import lirc

  client = lirc.Client()
  client.send_once("my-remote-name", "KEY_POWER")

  # Go to channel "33"
  client.send_once("my-remote-name", "KEY_3", repeat_count=1)


With sending IR, we can use the `send_once` method and optionally,
send multiple by using the `repeat_count` keyword argument.

Handling Errors
^^^^^^^^^^^^^^^

.. code-block:: python

  import lirc

  client = lirc.Client()

  try:
      client.send_once('some-remote', 'key_power')
  except lirc.exceptions.LircdCommandFailureError as error:
      print('Unable to send the power key!')
      print(error)  # Error has more info on what lircd sent back.

If the command was not successful, a ``LircdCommandFailureError``
exception will be thrown.

Further Documentation
---------------------

More information on how to setup the system installed LIRC, how to use
this python library, and a full API specification can be found at
https://lirc.readthedocs.io/

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/eugenetriguba/lirc",
    "name": "lirc",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.9",
    "maintainer_email": null,
    "keywords": "LIRC, IR",
    "author": "Eugene Triguba",
    "author_email": "eugenetriguba@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/c2/ef/32c24039d117ef888a01f10fda981a386092a3c867f4edde3411510a41c5/lirc-3.0.0.tar.gz",
    "platform": null,
    "description": "LIRC Python Package\n===================\n\n.. image:: https://img.shields.io/pypi/pyversions/lirc\n   :target: https://www.python.org/downloads/\n   :alt: Python Version\n.. image:: https://img.shields.io/pypi/v/lirc\n   :target: https://pypi.org/project/lirc/\n   :alt: Project Version\n.. image:: https://readthedocs.org/projects/lirc/badge/?version=latest\n  :target: https://lirc.readthedocs.io/en/latest/?badge=latest\n  :alt: Documentation Status\n.. image:: https://github.com/eugenetriguba/lirc/actions/workflows/test.yml/badge.svg?branch=main\n  :target: https://github.com/eugenetriguba/lirc/actions/\n  :alt: Build Status\n.. image:: https://codecov.io/gh/eugenetriguba/lirc/graph/badge.svg\n  :target: https://codecov.io/gh/eugenetriguba/lirc\n  :alt: Code Coverage\n.. image:: https://api.codeclimate.com/v1/badges/62b96571ae84f2895531/maintainability\n   :target: https://codeclimate.com/github/eugenetriguba/lirc/maintainability\n   :alt: Maintainability\n.. image:: https://img.shields.io/badge/code%20style-black-000000.svg\n    :target: https://github.com/psf/black\n    :alt: Code Formatter\n.. image:: https://img.shields.io/badge/contributions-welcome-brightgreen.svg\n    :target: https://github.com/eugenetriguba/lirc/issues\n    :alt: Contributing\n.. image:: https://img.shields.io/pypi/l/lirc\n   :target: https://pypi.python.org/pypi/lirc/\n   :alt: License\n.. image:: https://img.shields.io/badge/platform-linux%20%7C%20macos%20%7C%20windows-%23F9F9F9\n   :target: https://lirc.readthedocs.io/en/latest/installation.html\n   :alt: Platform Support\n\nThis is a python package that allows you to interact with the daemon in the\n`Linux Infrared Remote Control <https://lirc.org>`_ package. By interacting\nwith this daemon, it allows you to programmatically send IR signals from a\ncomputer.\n\nThis package is for emitting IR signals, but it does not support listening to\nIR codes. If you'd like to monitor the IR signals you recieve on\nLinux, which has built-in support in the kernel for recieving IR signals, you\ncan try using `python-evdev <https://python-evdev.readthedocs.io/en/latest/>`_.\nThey have a `tutorial on reading the events <https://python-evdev.readthedocs.io/en/latest/tutorial.html#reading-events>`_.\n\nMore information on the lircd daemon, socket interface,\nreply packet format, etc. can be found at https://www.lirc.org/html/lircd.html\n\nMaintainance Status\n-------------------\n\nThis project is maintained, but it is not actively developed.\nIt is feature complete for my purposes.\n\nInstallation\n------------\n\nThis package is hosted on PyPI and can be installed\nthrough pip.\n\n.. code-block:: bash\n\n  $ pip install lirc\n\nHowever since this is a wrapper around the LIRC daemon, it\nis expected that LIRC is installed and setup on the given\nsystem as well.\n\nMore information on that can be found in the `installation <https://lirc.readthedocs.io/en/latest/installation.html>`_\nportion of the full documentation.\n\nQuick Start\n-----------\n\nUsing the Client\n^^^^^^^^^^^^^^^^\n\n.. code-block:: python\n\n  import lirc\n\n  client = lirc.Client()\n\n  print(client.version())\n  >>> '0.10.1'\n\nTo use this package, we instantiate a ``Client``. By initializing it\nwith no arguments, the ``Client`` will attempt to connect to the lirc\ndaemon with the default connection parameters for your operating system.\n\nThese defaults depend on your operating system and can be looked up in the\nfull documentation if you need different parameters.\n\nHowever, if you've instantiated the ``Client`` without any arguments,\nyou don't get any errors, and you recieve a response from the ``version()``\ncommand, you are connected to the daemon. Most people should not need to\nchange the default parameters.\n\nCustomizing the Client\n^^^^^^^^^^^^^^^^^^^^^^\n\nAs previously stated, we can customize these defaults if needed.\n\n.. code-block:: python\n\n  import socket\n  import lirc\n\n  client = lirc.Client(\n    connection=lirc.LircdConnection(\n      address=\"/var/run/lirc/lircd\",\n      socket=socket.socket(socket.AF_UNIX, socket.SOCK_STREAM),\n      timeout = 5.0\n    )\n  )\n\nFor the client in the example above, we set it up using the defaults for a Linux machine.\nWhile this example illustrates what is customizable, it is not a practical example since\nyou could call ``Client()`` with no arguments if you're on Linux and achieve the same outcome.\n\nSee `Overriding LIRC Defaults on Initialization <https://lirc.readthedocs.io/en/stable/usage.html#overriding-lirc-defaults-on-initialization>`_\nfor more information.\n\nSending IR\n^^^^^^^^^^\n\n.. code-block:: python\n\n  import lirc\n\n  client = lirc.Client()\n  client.send_once(\"my-remote-name\", \"KEY_POWER\")\n\n  # Go to channel \"33\"\n  client.send_once(\"my-remote-name\", \"KEY_3\", repeat_count=1)\n\n\nWith sending IR, we can use the `send_once` method and optionally,\nsend multiple by using the `repeat_count` keyword argument.\n\nHandling Errors\n^^^^^^^^^^^^^^^\n\n.. code-block:: python\n\n  import lirc\n\n  client = lirc.Client()\n\n  try:\n      client.send_once('some-remote', 'key_power')\n  except lirc.exceptions.LircdCommandFailureError as error:\n      print('Unable to send the power key!')\n      print(error)  # Error has more info on what lircd sent back.\n\nIf the command was not successful, a ``LircdCommandFailureError``\nexception will be thrown.\n\nFurther Documentation\n---------------------\n\nMore information on how to setup the system installed LIRC, how to use\nthis python library, and a full API specification can be found at\nhttps://lirc.readthedocs.io/\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Interact with the daemon in the Linux Infrared Remote Control package",
    "version": "3.0.0",
    "project_urls": {
        "Homepage": "https://github.com/eugenetriguba/lirc",
        "Repository": "https://github.com/eugenetriguba/lirc"
    },
    "split_keywords": [
        "lirc",
        " ir"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "7d812e7e81f6e789f586c95ab2fa3e2a72e489b420d67354fc5295a4916d0e29",
                "md5": "8cfa53ee67097e7303e8c7d67be4c08d",
                "sha256": "0725e8cf41739dbd58e348787bb49cce783181ce2469c640e2cfea2afc58cb67"
            },
            "downloads": -1,
            "filename": "lirc-3.0.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "8cfa53ee67097e7303e8c7d67be4c08d",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.9",
            "size": 12927,
            "upload_time": "2024-10-20T19:44:39",
            "upload_time_iso_8601": "2024-10-20T19:44:39.062633Z",
            "url": "https://files.pythonhosted.org/packages/7d/81/2e7e81f6e789f586c95ab2fa3e2a72e489b420d67354fc5295a4916d0e29/lirc-3.0.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "c2ef32c24039d117ef888a01f10fda981a386092a3c867f4edde3411510a41c5",
                "md5": "2580779aa094a71dad4bc259f36b6f8f",
                "sha256": "67d993610d1e13fa0ca488845add6877f1a7f6e97c13976e531898231afc35d7"
            },
            "downloads": -1,
            "filename": "lirc-3.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "2580779aa094a71dad4bc259f36b6f8f",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.9",
            "size": 12511,
            "upload_time": "2024-10-20T19:44:40",
            "upload_time_iso_8601": "2024-10-20T19:44:40.516303Z",
            "url": "https://files.pythonhosted.org/packages/c2/ef/32c24039d117ef888a01f10fda981a386092a3c867f4edde3411510a41c5/lirc-3.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-20 19:44:40",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "eugenetriguba",
    "github_project": "lirc",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "lcname": "lirc"
}
        
Elapsed time: 0.41895s