Skip to main content

open text in a browser contextually

Project description

smartopen
=========

smartopen is a command line program that will transform text according
to handlers to URLs and open them


Usage
-----

``smartopen --help`` displays the program usage:

"""
Usage: smartopen [options]

Options:
-h, --help show this help message and exit
-c CONFIG, --config=CONFIG
config file to read
-u, --url print the first url handled
-a, --all print all handlers that match the query
-H HANDLERS, --handler=HANDLERS
name of the handler to use, in order
--print-handlers print all handlers in order they would be tried
"""

smartopen reads text from standard input or command line arguments.
The handlers are then iterated through in a configurable order and, if
the handler can transform the text into a URL, the URL is then
processed. Unless otherwise specified by command line options
(e.g. --url, --all), the first matching URL is then opened in firefox.


Handlers
--------

smartopen has a pluggable system of configurable handlers. The
setuptools entry point ``[smartopen.locations]`` is an extension point
for the handlers. Several handlers come with smartopen, or you can
write your own.

URL: a resolvable URL
Google: a google search
Wikipedia: a Wikipedia article
GoogleMaps: an address in google maps

etc.


Configuration
-------------

smartopen uses a configuration file that defines the order of the
handlers and their behavior.

A simple example is shown here:
http://k0s.org/hg/smartopen/file/tip/smartopen.ini


Interfacing With Your Environment
---------------------------------

While smartopen is useful of its own right, its utility may be
enhanced by using as part of an environment. For instance, I run the
fluxbox window manager which allows the use of hotkeys. By binding
smartopen to ``Ctrl+Alt+s`` and using ``xclip``, I can open a URL that is
mappable to a smartopen handler with a keyboard shortcut. The
relevant line from my ``~/.fluxbox/keys`` file reads:

Control Mod1 s :ExecCommand /home/jhammel/python/smartopen.py "$(xclip -o)" # smartopen


----


Posterity is gained...
----------------------

I mostly wrote smartopen to help me. That it has.
However...a few things....

- better way of setting up handlers?
- really, i want to push down to choose what i think the handler is,
but only should we I release the hand that Jesus becomes Magic
(sorry, I hate the movie too)

....and more?

Was reading about catfish....e.g.
http://www.addictivetips.com/ubuntu-linux-tips/catfish-file-searching-tool-for-ubuntu-linux/
...

"""
file search tool that support several different engines

A file search tool using different backends which is configurable via
the command line.

This program acts as a frontend for different file search engines.
The interface is intentionally lightweight and simple. But it takes
configuration options from the command line.

Currently find, locate, tracker, strigi, pinot, and beagle are
supported as backends
""".

Should smartopen....be a pluggable thing that takes text and finds
both *the handler* and *what to do with it*???

I mean, short of it being a neural network anyway....

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

smartopen-0.2.tar.gz (9.2 kB view details)

Uploaded Source

File details

Details for the file smartopen-0.2.tar.gz.

File metadata

  • Download URL: smartopen-0.2.tar.gz
  • Upload date:
  • Size: 9.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for smartopen-0.2.tar.gz
Algorithm Hash digest
SHA256 f819c29f2bdcc8fa964dcb30fb035f05fab3223f11b8099cebd21fcca26a92cf
MD5 4d603ab70a8464f09c7a621cef20deff
BLAKE2b-256 f111fd340454f31d55e111c11d8f1c758bac9c9608cac39decd3bf6cde3c7cd9

See more details on using hashes here.

Supported by

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