feat: change output to echo via pager

This commit is contained in:
Dave Gallant
2020-08-03 15:37:39 -04:00
parent ad4a072325
commit ee6939aafe
5 changed files with 48 additions and 37 deletions

View File

@@ -35,6 +35,15 @@ lint:
test: tmp/.tests-passed.sentinel test: tmp/.tests-passed.sentinel
.PHONY: test .PHONY: test
## examples: Run basic commands
examples: tmp/.tests-passed.sentinel
> rfd --version
> rfd threads >/dev/null
> rfd threads --sort-by score >/dev/null
> rfd search 'pizza' >/dev/null
> rfd search '(coffee|starbucks)' >/dev/null
.PHONY: examples
# Tests - re-ran if any file under src has been changed since tmp/.tests-passed.sentinel was last touched # Tests - re-ran if any file under src has been changed since tmp/.tests-passed.sentinel was last touched
tmp/.tests-passed.sentinel: $(shell find ${SRC} -type f) tmp/.tests-passed.sentinel: $(shell find ${SRC} -type f)
> mkdir -p $(@D) > mkdir -p $(@D)
@@ -45,7 +54,7 @@ tmp/.tests-passed.sentinel: $(shell find ${SRC} -type f)
pr: precommit lint test pr: precommit lint test
.PHONY: pr .PHONY: pr
ci: lint test ci: lint test examples
.PHONY: ci .PHONY: ci
## help: Print this help message ## help: Print this help message

View File

@@ -7,10 +7,8 @@ Hot deals on the command line.
[![Dependabot](https://badgen.net/badge/Dependabot/enabled/green?icon=dependabot)](https://dependabot.com/) [![Dependabot](https://badgen.net/badge/Dependabot/enabled/green?icon=dependabot)](https://dependabot.com/)
[![Language grade: Python](https://img.shields.io/lgtm/grade/python/g/davegallant/rfd.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/davegallant/rfd/context:python) [![Language grade: Python](https://img.shields.io/lgtm/grade/python/g/davegallant/rfd.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/davegallant/rfd/context:python)
![screenshot](https://user-images.githubusercontent.com/4519234/85969861-e10a4100-b996-11ea-9a31-6203322c60ee.png) ![screenshot](https://user-images.githubusercontent.com/4519234/85969861-e10a4100-b996-11ea-9a31-6203322c60ee.png)
## Install ## Install
```bash ```bash
@@ -37,6 +35,7 @@ Commands:
## Examples ## Examples
### View Hot Deals ### View Hot Deals
```console ```console
$ rfd threads $ rfd threads
``` ```
@@ -52,6 +51,7 @@ $ rfd threads --sort-by views --limit 40
``` ```
### Simple Search ### Simple Search
```console ```console
$ rfd search 'pizza' $ rfd search 'pizza'
``` ```
@@ -61,7 +61,7 @@ $ rfd search 'pizza'
Regular expressions can be used for search. Regular expressions can be used for search.
```console ```console
$ rfd search '(coffee|starbucks)' --num-pages 100 $ rfd search '(coffee|starbucks)' --pages 10 --sort-by views
``` ```
## Shell Completion ## Shell Completion

View File

@@ -1 +1 @@
0.4.1 0.5.0

View File

@@ -42,13 +42,15 @@ def print_version(ctx, value):
ctx.exit() ctx.exit()
def display_thread(click, thread, count): # pylint: disable=redefined-outer-name def generate_thread_output(_threads):
for count, thread in enumerate(_threads, 1):
output = ""
dealer = thread.dealer_name dealer = thread.dealer_name
if dealer and dealer is not None: if dealer and dealer is not None:
dealer = "[" + dealer + "] " dealer = "[" + dealer + "] "
else: else:
dealer = "" dealer = ""
click.echo( output += (
" " " "
+ str(count) + str(count)
+ "." + "."
@@ -59,8 +61,10 @@ def display_thread(click, thread, count): # pylint: disable=redefined-outer-nam
+ " (%d views)" % thread.views + " (%d views)" % thread.views
+ Fore.RESET + Fore.RESET
) )
click.echo(Fore.BLUE + " {}".format(thread.url)) output += Fore.BLUE + " {}".format(thread.url)
click.echo(Style.RESET_ALL) output += Style.RESET_ALL
output += "\n\n"
yield output
@click.group(invoke_without_command=True) @click.group(invoke_without_command=True)
@@ -137,17 +141,17 @@ def threads(limit, forum_id, sort_by):
_threads = sort_threads( _threads = sort_threads(
parse_threads(get_threads(forum_id, limit), limit), sort_by=sort_by parse_threads(get_threads(forum_id, limit), limit), sort_by=sort_by
) )
for count, thread in enumerate(_threads, 1): click.echo_via_pager(generate_thread_output(_threads))
display_thread(click, thread, count)
@cli.command(short_help="Search deals based on a regular expression.") @cli.command(short_help="Search deals based on a regular expression.")
@click.option("--num-pages", default=5, help="Number of pages to search.") @click.option("--pages", default=5, help="Number of pages to search.")
@click.option( @click.option(
"--forum-id", default=9, help="The forum id number. Defaults to 9 (hot deals)." "--forum-id", default=9, help="The forum id number. Defaults to 9 (hot deals)."
) )
@click.option("--sort-by", default=None, help="Sort threads by")
@click.argument("regex") @click.argument("regex")
def search(num_pages, forum_id, regex): def search(pages, forum_id, sort_by, regex):
"""Search deals based on regex. """Search deals based on regex.
Popular forum ids: Popular forum ids:
@@ -165,9 +169,12 @@ def search(num_pages, forum_id, regex):
88 \t cell phones 88 \t cell phones
""" """
count = 0 matched_threads = []
for page in range(1, num_pages):
for page in range(1, pages):
_threads = parse_threads(get_threads(forum_id, 100, page=page), limit=100) _threads = parse_threads(get_threads(forum_id, 100, page=page), limit=100)
for thread in search_threads(threads=_threads, regex=regex): for thread in search_threads(threads=_threads, regex=regex):
count += 1 matched_threads.append(thread)
display_thread(click, thread, count) click.echo_via_pager(
generate_thread_output(sort_threads(matched_threads, sort_by=sort_by))
)

View File

@@ -9,8 +9,3 @@ envlist = py{27,
passenv = SSH_AUTH_SOCK passenv = SSH_AUTH_SOCK
commands = commands =
make ci make ci
rfd --version
rfd threads
rfd threads --sort-by score
rfd search 'pizza'
rfd search '(coffee|starbucks)'