factor/extra/webapps/planet/planet.factor

135 lines
4.1 KiB
Factor
Raw Normal View History

2007-10-15 16:44:40 -04:00
USING: sequences rss arrays concurrency kernel sorting
html.elements io assocs namespaces math threads vocabs html
2007-10-16 01:35:32 -04:00
furnace http.server.templating calendar math.parser splitting
2007-12-05 23:16:20 -05:00
continuations debugger system http.server.responders
xml.writer ;
2007-10-15 16:44:40 -04:00
IN: webapps.planet
: print-posting-summary ( posting -- )
<p "news" =class p>
2007-12-05 23:16:20 -05:00
<b> dup entry-title write </b> <br/>
<a entry-link =href "more" =class a>
2007-10-15 16:44:40 -04:00
"Read More..." write
</a>
</p> ;
: print-posting-summaries ( postings -- )
[ print-posting-summary ] each ;
: print-blogroll ( blogroll -- )
<ul "description" =class ul>
[
<li> <a dup third =href a> first write </a> </li>
] each
</ul> ;
: format-date ( date -- string )
2007-12-08 17:18:34 -05:00
rfc3339>timestamp timestamp>string ;
2007-10-15 16:44:40 -04:00
: print-posting ( posting -- )
<h2 "posting-title" =class h2>
2007-12-05 23:16:20 -05:00
<a dup entry-link =href a>
dup entry-title write-html
2007-10-15 16:44:40 -04:00
</a>
</h2>
2007-12-05 23:16:20 -05:00
<p "posting-body" =class p>
dup entry-description write-html
</p>
<p "posting-date" =class p>
entry-pub-date format-date write
</p> ;
2007-10-15 16:44:40 -04:00
: print-postings ( postings -- )
[ print-posting ] each ;
SYMBOL: default-blogroll
SYMBOL: cached-postings
2007-12-08 17:18:34 -05:00
: safe-head ( seq n -- seq' )
over length min head ;
2007-10-15 16:44:40 -04:00
: mini-planet-factor ( -- )
2007-12-08 17:18:34 -05:00
cached-postings get 4 safe-head print-posting-summaries ;
2007-10-15 16:44:40 -04:00
: planet-factor ( -- )
2007-12-05 23:16:20 -05:00
serving-html [ "planet" render-template ] with-html-stream ;
2007-10-15 16:44:40 -04:00
\ planet-factor { } define-action
2007-12-05 23:16:20 -05:00
: planet-feed ( -- feed )
"[ planet-factor ]"
"http://planet.factorcode.org"
2007-12-08 17:18:34 -05:00
cached-postings get 30 safe-head <feed> ;
2007-12-05 23:16:20 -05:00
2007-12-06 01:03:10 -05:00
: feed.xml ( -- )
2007-12-05 23:16:20 -05:00
"text/xml" serving-content
planet-feed feed>xml write-xml ;
\ feed.xml { } define-action
2007-10-15 16:44:40 -04:00
2007-12-06 01:03:10 -05:00
: style.css ( -- )
"text/css" serving-content
"style.css" send-resource ;
\ style.css { } define-action
2007-10-24 02:24:26 -04:00
SYMBOL: last-update
2007-12-05 23:16:20 -05:00
: diagnostic write print flush ;
: fetch-feed ( triple -- feed )
second
dup "Fetching " diagnostic
dup download-feed feed-entries
swap "Done fetching " diagnostic ;
: <posting> ( author entry -- entry' )
clone
[ ": " swap entry-title 3append ] keep
[ set-entry-title ] keep ;
: ?fetch-feed ( triple -- feed/f )
2008-02-01 00:03:54 -05:00
[ fetch-feed ] [ swap . error. f ] recover ;
2007-12-05 23:16:20 -05:00
: fetch-blogroll ( blogroll -- entries )
dup 0 <column>
swap [ ?fetch-feed ] parallel-map
2008-01-09 17:36:30 -05:00
[ [ <posting> ] with map ] 2map concat ;
2007-12-05 23:16:20 -05:00
: sort-entries ( entries -- entries' )
[ [ entry-pub-date ] compare ] sort <reversed> ;
: update-cached-postings ( -- )
default-blogroll get
fetch-blogroll sort-entries
cached-postings set-global ;
2007-10-15 16:44:40 -04:00
: update-thread ( -- )
2007-10-24 02:24:26 -04:00
millis last-update set-global
[ update-cached-postings ] in-thread
2007-10-15 16:44:40 -04:00
10 60 * 1000 * sleep
update-thread ;
: start-update-thread ( -- )
[ update-thread ] in-thread ;
"planet" "planet-factor" "extra/webapps/planet" web-app
2007-11-21 04:19:32 -05:00
2007-12-05 23:16:20 -05:00
{
{ "Berlin Brown" "http://factorlang-fornovices.blogspot.com/feeds/posts/default" "http://factorlang-fornovices.blogspot.com" }
2007-12-06 00:06:34 -05:00
{ "Chris Double" "http://www.blogger.com/feeds/18561009/posts/full/-/factor" "http://www.bluishcoder.co.nz/" }
2007-12-05 23:16:20 -05:00
{ "Elie Chaftari" "http://fun-factor.blogspot.com/feeds/posts/default" "http://fun-factor.blogspot.com/" }
{ "Doug Coleman" "http://code-factor.blogspot.com/feeds/posts/default" "http://code-factor.blogspot.com/" }
{ "Daniel Ehrenberg" "http://useless-factor.blogspot.com/feeds/posts/default" "http://useless-factor.blogspot.com/" }
2007-12-08 03:22:08 -05:00
{ "Gavin Harrison" "http://gmh33.blogspot.com/feeds/posts/default" "http://gmh33.blogspot.com/" }
2008-01-10 22:04:05 -05:00
{ "Kevin Marshall"
"http://blog.botfu.com/?cat=9&feed=atom"
"http://blog.botfu.com/" }
2007-12-05 23:16:20 -05:00
{ "Kio M. Smallwood"
"http://sekenre.wordpress.com/feed/atom/"
"http://sekenre.wordpress.com/" }
2007-12-08 17:18:34 -05:00
{ "Phil Dawes" "http://www.phildawes.net/blog/category/factor/feed/atom" "http://www.phildawes.net/blog/" }
2007-12-05 23:16:20 -05:00
{ "Samuel Tardieu" "http://www.rfc1149.net/blog/tag/factor/feed/atom/" "http://www.rfc1149.net/blog/tag/factor/" }
{ "Slava Pestov" "http://factor-language.blogspot.com/atom.xml" "http://factor-language.blogspot.com/" }
} default-blogroll set-global