Metadata-Version: 2.1
Name: findx
Version: 0.10.2
Summary: ``findx``, an extended ``find`` command.
Home-page: https://github.com/drmikehenry/findx
Author: Michael Henry
Author-email: drmikehenry@drmikehenry.com
License: MIT
Keywords: extended find file search
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Topic :: Text Processing
Classifier: Topic :: Utilities
Classifier: Environment :: Console
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.6
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Requires-Python: >=2.6,!=3.0.*,!=3.1.*,!=3.2.*
Provides-Extra: dev
Requires-Dist: pytest ; extra == 'dev'
Requires-Dist: pytest-cov ; extra == 'dev'
Requires-Dist: flake8 (>=3.3.0) ; extra == 'dev'
Requires-Dist: pep8-naming (>=0.4.1) ; extra == 'dev'
Requires-Dist: flake8-quotes (>=0.8.1) ; extra == 'dev'
Requires-Dist: flake8-import-order (>=0.9.0) ; extra == 'dev'
Requires-Dist: mypy ; (python_version >= "3.5") and extra == 'dev'

findx - an extended ``find`` command.
=====================================

.. image:: https://travis-ci.org/drmikehenry/findx.svg
    :target: https://travis-ci.org/drmikehenry/findx

.. image:: https://img.shields.io/pypi/v/findx.svg
    :target: https://pypi.python.org/pypi/findx

.. image:: https://img.shields.io/pypi/status/findx.svg
    :target: https://pypi.python.org/pypi/findx

.. image:: https://img.shields.io/pypi/pyversions/findx.svg
    :target: https://pypi.python.org/pypi/findx/

Overview
--------

``findx`` is an extended version of the Unix ``find`` command written in the
Python language as a wrapper around ``find`` and other Unix tools.  ``find`` is
a very powerful tool, but by itself there are a large number of arguments
required for a typical invocation.  ``findx`` provides convenient shortcuts for
invoking ``find`` without so much typing.

As a quick example, imagine using ``find``, ``xargs`` and ``grep`` to search
through a tree of files.  A simple invocation might be::

  find -type f | xargs grep PATTERN

But the above invocation won't correctly handle file with spaces or unusual
characters; handling that grows the command to::

  find -type f -print0 | xargs -0 grep PATTERN

Filenames are handled correctly now, but the command probably searches through
some uninteresting files.  It also misses on a couple of boundary cases.  You'd
probably like to include ``xargs --no-run-if-empty`` to ensure ``grep`` isn't
invoked when no files are found; you might want to follow symbolic links as well
as files; and you might want to skip over ``.git`` directories (for example).
Adding those into the above command grows things considerably::

  find -L -name .git -prune -o -type f -print0 |
    xargs -0 --no-run-if-empty grep PATTERN

After excluding additional files and directories and perhaps adding
``--color=auto`` to the ``grep`` invocation, things are getting out of hand.
``findx`` exists to make such invocations simpler.  First, ``findx`` knows about
the need for ``-print0`` and ``xargs -0 --no-run-if-empty``; using ``:`` implies
all of the standard protocol for using ``xargs`` correctly, reducing the above
to::

  findx -L -name .git -prune -o -type f : grep PATTERN

Standard paths to ignore are requested via ``-stdx``::

  findx -L -stdx -type f : grep PATTERN

Following symlinks to files and producing only files is another common
requirement; the switch ``-ffx`` implies finding files (following symlinks)
while excluding a predefined set of directories and files::

  findx -ffx : grep PATTERN

Piping filenames into ``grep`` is such a common pattern that the ``-ffg`` switch
is the same as ``-ffx : grep``, reducing things to::

  findx -ffg PATTERN

In addition, ``ffx`` and ``ffg`` are to additional entry points into ``findx``
that reduce things even further::

  ffx = findx -ffx
  ffg = findx -ffg

In the most common case, searching a file tree thus reduces to::

  ffg PATTERN

See ``findx --help`` or read the top of ``findx.py`` for more details.

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

From PyPI, installation is the usual::

  pip install findx

From the source tree, install via::

  python setup.py install

Running the tests
-----------------

Install any development requirements::

  pip install -r dev-requirements.txt

Run tests via pytest::

  pytest

Changes
-------

See CHANGES.rst for a history of changes.

License
-------

``findx`` is distributed under the terms of the MIT license; see LICENSE.rst
for details.


