More ordering options
continuous-integration/drone/push Build was killed
Details
continuous-integration/drone/push Build was killed
Details
parent
4d6d3c9239
commit
a01258700d
16
README.md
16
README.md
|
@ -392,10 +392,11 @@ The list of arguments can be obtained by running `morss --help`
|
|||
```
|
||||
usage: morss [-h] [--post STRING] [--xpath XPATH]
|
||||
[--format {rss,json,html,csv}] [--search STRING] [--clip]
|
||||
[--indent] [--cache] [--force] [--proxy] [--newest] [--firstlink]
|
||||
[--resolve] [--items XPATH] [--item_link XPATH]
|
||||
[--item_title XPATH] [--item_content XPATH] [--item_time XPATH]
|
||||
[--nolink] [--noref] [--silent]
|
||||
[--indent] [--cache] [--force] [--proxy]
|
||||
[--order {first,last,newest,oldest}] [--firstlink] [--resolve]
|
||||
[--items XPATH] [--item_link XPATH] [--item_title XPATH]
|
||||
[--item_content XPATH] [--item_time XPATH] [--nolink] [--noref]
|
||||
[--silent]
|
||||
url
|
||||
|
||||
Get full-text RSS feeds
|
||||
|
@ -403,7 +404,7 @@ Get full-text RSS feeds
|
|||
positional arguments:
|
||||
url feed url
|
||||
|
||||
optional arguments:
|
||||
options:
|
||||
-h, --help show this help message and exit
|
||||
--post STRING POST request
|
||||
--xpath XPATH xpath rule to manually detect the article
|
||||
|
@ -422,8 +423,9 @@ action:
|
|||
articles' content), so as to save time
|
||||
--force force refetch the rss feed and articles
|
||||
--proxy doesn't fill the articles
|
||||
--newest return the feed items in chronological order (morss
|
||||
ohterwise shows the items by appearing order)
|
||||
--order {first,last,newest,oldest}
|
||||
order in which to process items (which are however NOT
|
||||
sorted in the output)
|
||||
--firstlink pull the first article mentioned in the description
|
||||
instead of the default link
|
||||
--resolve replace tracking links with direct links to articles
|
||||
|
|
|
@ -328,15 +328,21 @@ def FeedGather(rss, url, options):
|
|||
if options.cache:
|
||||
max_time = 0
|
||||
|
||||
if options.newest:
|
||||
# :newest take the newest items (instead of appearing order)
|
||||
now = datetime.now(tz.tzutc())
|
||||
sorted_items = sorted(rss.items, key=lambda x:x.updated or x.time or now, reverse=True)
|
||||
|
||||
else:
|
||||
# default behavior, take the first items (in appearing order)
|
||||
# sort
|
||||
sorted_items = list(rss.items)
|
||||
|
||||
if options.order == 'last':
|
||||
# `first` does nothing from a practical standpoint, so only `last` needs
|
||||
# to be addressed
|
||||
sorted_items = reversed(sorted_items)
|
||||
|
||||
elif options.order in ['newest', 'oldest']:
|
||||
now = datetime.now(tz.tzutc())
|
||||
sorted_items = sorted(sorted_items, key=lambda x:x.updated or x.time or now) # oldest to newest
|
||||
|
||||
if options.order == 'newest':
|
||||
sorted_items = reversed(sorted_items)
|
||||
|
||||
for i, item in enumerate(sorted_items):
|
||||
# hard cap
|
||||
if time.time() - start_time > lim_time >= 0 or i + 1 > lim_item >= 0:
|
||||
|
|
|
@ -204,7 +204,9 @@
|
|||
link of the
|
||||
<select>
|
||||
<option value="">first</option>
|
||||
<option value=":newest" title="Select feed items by publication date (instead of appearing order)">newest (?)</option>
|
||||
<option value=":order=newest" title="Select feed items by publication date (instead of appearing order)">newest (?)</option>
|
||||
<option value=":order=last">last</option>
|
||||
<option value=":order=oldest">oldest</option>
|
||||
</select>
|
||||
items and
|
||||
<select>
|
||||
|
|
Loading…
Reference in New Issue