2015-11-02 01:32:14 +05:30
# MarkIt
2015-11-10 12:45:35 +05:30
![Screenshot ](markit.png )
`markit` is a cmdline bookmark management utility written using Python3 and SQLite3. `markit` exists because of my monumental dependency on < a href = "http://historio.us/" > historious</ a > . I wanted the same database on my local system. However, I couldn't find any equally flexible solution. Hence, `MarkIt` !
2015-11-09 03:53:36 +05:30
2015-11-10 10:34:34 +05:30
The SQLite3 database file is stored in `$HOME/.cache/markit/bookmarks.db` for each user.
2015-11-09 03:53:36 +05:30
2015-11-09 03:34:49 +05:30
`markit` is GPLv3 licensed.
If you find `markit` useful, please consider donating via PayPal.
< a href = "https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=RMLTQ76JSXJ4Q" > < img src = "https://www.paypal.com/en_US/i/btn/btn_donateCC_LG.gif" alt = "Donate Button with Credit Cards" / > < / a >
# Features
- Add, update or remove a bookmark
- Add tags to bookmarks
2015-11-10 16:50:30 +05:30
- Optionally fetch page title data from the web (default: disabled)
2015-11-09 03:34:49 +05:30
- Use (partial) tags or keywords to search bookmarks
2015-11-09 21:08:44 +05:30
- Unique URLs to avoid duplicates, show index if URL already exists
2015-11-10 16:50:30 +05:30
- Open bookmark in browser using index
2015-11-09 03:34:49 +05:30
- Open search results in browser
- Browser (Chromium and Firefox based) errors and warnings suppression
2015-11-10 10:53:35 +05:30
- Show single bookmark by ID or all bookmarks in a go
2015-11-09 03:34:49 +05:30
- Delete all bookmarks
2015-11-10 16:50:30 +05:30
- Add a bookmark at N< sup > th</ sup > index, to fill deleted bookmark indices
2015-11-09 03:34:49 +05:30
- Secure SQLite3 queries to access database
- Handle first level of redirections (reports IP blocking)
- Unicode in URL works
2015-11-09 21:08:44 +05:30
- UTF-8 request and response, page character set detection
2015-11-09 03:34:49 +05:30
- Works with Python 3.x
- Coloured output for clarity
- Manpage for quick reference
- Optional debug information
- Fast and clean (no ads or clutter)
- Minimal dependencies
- Open source and free
# Installation
`markit` requires Python 3.x to work.
1. If you have git installed (the steps are tested on Ubuntu 14.04.3 x64_64):
< pre > $ git clone https://github.com/jarun/markit/
$ cd markit
$ sudo make install< / pre >
To remove, run:
< pre > $ sudo make uninstall< / pre >
2. If you do not have git installed:
2015-11-10 12:25:54 +05:30
Download the < a href = "https://github.com/jarun/markit/releases/latest" > latest stable release< / a > or < a href = "https://github.com/jarun/markit/archive/master.zip" > development version< / a > source code. Extract, cd into the directory and run:
2015-11-09 03:34:49 +05:30
< pre > $ sudo make install< / pre >
If you do not want to install, `markit` is standalone:
< pre > $ chmod +x markit
$ ./markit ...< / pre >
2015-11-09 03:59:17 +05:30
# Usage
2015-11-10 12:45:35 +05:30
< b > Operational notes:< / b >
- It's advisable to copy URLs directly from the browser address bar, i.e., along with the leading `http://` or `https://` token. `markit` looks up title data (found within < title ></ title > tags of HTML) from the web ONLY for fully-formed HTTP(S) URLs.
- If the URL contains characters like `;` , `&` or brackets they may be interpreted specially by the shell. To avoid it, add the URL within single `'` or double `"` qoutes.
- The same URL cannot be added twice. You can update tags and re-fetch title data. You can also delete it and insert at the same index.
- You can either add or update or delete record(s) in one instance. A combination of these operations is not supported in a single run.
- Search works in mysterious ways:
- Substrings match (`match` matches `rematched` ) for URL, tags and title data.
2015-11-10 13:28:37 +05:30
- All the keywords are treated together as a `single` tag in the same order. Bookmarks with partial or complete tag matches are shown in results.
- The same keywords are treated `separately` as unique tokens. Hence, entries with matching URL or title data are also shown in the results. Order is irrelevant in this case.
2015-11-10 16:50:30 +05:30
- Search results are indexed serially. The index is different from actual database index of a bookmark record. Use `-P` option to get DB index.
2015-11-10 12:45:35 +05:30
< b > Cmdline help:< / b >
2015-11-09 03:59:17 +05:30
< pre > Usage: markit [OPTIONS] KEYWORDS...
Bookmark manager. Your private Google.
Options
2015-11-09 05:21:25 +05:30
-a URL tag 1, tag 2, ... add URL as bookmark with comma separated tags
2015-11-10 16:50:30 +05:30
-d N delete entry at DB index N (from -P output)
2015-11-09 03:59:17 +05:30
-D delete ALL bookmarks
2015-11-10 16:50:30 +05:30
-i N insert entry at DB index N, useful to fill deleted index
-o N open URL at DB index N in browser
-p N show details of bookmark record at DB index N
-P show all bookmarks along with index from DB
2015-11-10 13:03:11 +05:30
-s keyword(s) search all bookmarks for a (partial) tag or each keyword
2015-11-10 16:50:30 +05:30
-u N update entry at DB index N
2015-11-10 14:41:05 +05:30
-w fetch title info from web, works with -a, -i, -u
2015-11-09 03:59:17 +05:30
-z show debug information
you can either add or update or delete in one instance
any other option shows help and exits markit
Keys
1-N open Nth search result in browser. Enter exits markit.< / pre >
2015-11-02 01:32:14 +05:30
2015-11-09 04:02:12 +05:30
# Examples
2015-11-10 12:04:37 +05:30
1. Add a new bookmark with tags `linux news` and `open source` :
< pre > $ markit -a http://tuxdiary.com linux news, open source
Added at index 15012014< / pre >
The assigned automatic index 15012014 is unique, one greater than highest index already in use in database.
2015-11-10 16:50:30 +05:30
2. Add a bookmark, fetch page title information from web:
2015-11-10 14:01:35 +05:30
< pre > $ markit -a -w http://tuxdiary.com linux news, open source
2015-11-10 12:04:37 +05:30
Title: [TuxDiary | Linux, open source and a pinch of leisure.]
Added at index 15012014< / pre >
3. Update existing bookmark at index 15012014 with a new tag:
2015-11-10 14:01:35 +05:30
< pre > $ markit -u 15012014 -w http://tuxdiary.com linux news, open source, magazine
2015-11-10 12:04:37 +05:30
Title: [TuxDiary | Linux, open source and a pinch of leisure.]
Updated< / pre >
4. Delete bookmark at index 15012014:
< pre > $ markit -d 15012014< / pre >
5. Delete all bookmarks:
< pre > $ markit -D< / pre >
6. Insert a bookmark at deleted index 15012014 (fails if index or URL exists in database):
2015-11-10 14:41:05 +05:30
< pre > $ markit -i 15012014 -w http://tuxdiary.com/about linux news, open source
2015-11-10 12:04:37 +05:30
Title: [A journey with WordPress | TuxDiary]
Added at index 15012014< / pre >
This option is useful in filling deleted indices from database manually.
7. Show info on bookmark at index 15012014:
< pre > $ markit -p 15012014< / pre >
8. Show all bookmarks with real index from database:
< pre > $ markit -P< / pre >
2015-11-10 16:50:30 +05:30
9. Open URL at index 15012014 in browser:
< pre > $ markit -o 15012014< / pre >
10. Search bookmarks:
2015-11-10 12:04:37 +05:30
< pre > $ markit -s kernel debugging< / pre >
2015-11-10 16:50:30 +05:30
11. Show debug info:
2015-11-10 12:04:37 +05:30
< pre > $ markit -z< / pre >
2015-11-10 16:50:30 +05:30
12. Show help:
2015-11-10 12:04:37 +05:30
< pre > $ markit< / pre >
2015-11-10 16:50:30 +05:30
or,
2015-11-10 12:04:37 +05:30
< pre > $ man markit< / pre >
2015-11-09 03:34:49 +05:30
#License
GPL v3
Copyright (C) 2015 by Arun Prakash Jana < engineerarun@gmail .com>
2015-11-02 01:32:14 +05:30
2015-11-10 12:04:37 +05:30
# Contributions
I would love to see pull requests with the following features:
- Exact word match (against substring in a word as it works currently. Hint: REGEXP)
- Parse full page data??? Might end up writing a search engine like Google. ;)
- Optional password protection
2015-11-02 01:32:14 +05:30
# Developer(s)
2015-11-10 12:04:37 +05:30
Arun Prakash Jana < engineerarun@gmail .com>