Skip to main content

Python bindings to libgetargv, a library to correctly and quickly get other process's args

Project description

getargv

Python package

This module uses libgetargv to obtain binary string representations of the arguments of other processes on macOS.

Motivation

On macOS you must use the KERN_PROCARGS2 sysctl to obtain other proc's args, however the returned representation is badly documented and a naive approach doesn't deal with leading empty args. libgetargv parses the results of the sysctl correctly, and this module provides Python bindings to libgetargv.

Installation

Install the module with pip by executing:

$ pip install getargv

Usage

import os
import getargv
getargv.as_bytes(os.getpid()) #=> b'arg0\x00arg1\x00'
getargv.as_list(os.getpid()) #=> [b'arg0',b'arg1']

Development

After checking out the repo, run python setup.py build. Then run python setup.py install. Then, run python test.py to run the tests. You can also run python -i load.py for an interactive prompt that will allow you to experiment. Python code goes in the file src/getargv/__init__.py, C code goes in the file src/getargv/getargvmodule.c.

To install this module onto your local machine, run python setup.py build && python setup.py install. To release a new version, update the version number in pyproject.toml, and then run make upload-production, which will create a git tag for the version, push git commits and the created tag, and push the .whl file to pypi.org.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/getargv/getargv.py.

License

The module is available as open source under the terms of the BSD 3-clause License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

getargv-0.13.tar.gz (11.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

getargv-0.13-cp313-cp313-macosx_14_0_universal2.whl (14.6 kB view details)

Uploaded CPython 3.13macOS 14.0+ universal2 (ARM64, x86-64)

File details

Details for the file getargv-0.13.tar.gz.

File metadata

  • Download URL: getargv-0.13.tar.gz
  • Upload date:
  • Size: 11.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for getargv-0.13.tar.gz
Algorithm Hash digest
SHA256 0a97cbcf5a7fa3f61a74b4ec1effefbdd44cb277b1af266c819eaa35b90c2fde
MD5 6fc6158f6e7a554abbbdb9e8decdca6f
BLAKE2b-256 ea9743f9e8d93b7ddfea66ce0297f1bf374880269dccd94a630c96c975cb0570

See more details on using hashes here.

File details

Details for the file getargv-0.13-cp313-cp313-macosx_14_0_universal2.whl.

File metadata

File hashes

Hashes for getargv-0.13-cp313-cp313-macosx_14_0_universal2.whl
Algorithm Hash digest
SHA256 0008afb8e91adaf67d465b90de7fbf53fd3099b4421c124a8bac57141259d6b3
MD5 6c3c2cad01c2948573364ffa471f5916
BLAKE2b-256 c19a7ac9a0f96f2f23a6d4ec87d5e339eebf6765138ae2b42fe7f8d9311ed239

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page