| 
									
										
										
										
											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 )
 | 
					
						
							|  |  |  |     [ fetch-feed ] [ error. drop f ] recover ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : 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/" } | 
					
						
							| 
									
										
										
										
											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
 |