Revised README and added example.go with a small idiomatic example on how to use this package.

This commit is contained in:
jim teeuwen 2011-05-21 19:12:43 +02:00
parent 09a1cbe77d
commit 9957923226
2 changed files with 59 additions and 2 deletions

19
README
View File

@ -1,5 +1,6 @@
Author: jim teeuwen <jimteeuwen@gmail.com>
Dependencies: go-pkg-xmlx ( http://github.com/jteeuwen/go-pkg-xmlx )
================================================================================
RSS
================================================================================
This package allows us to fetch Rss and Atom feeds from the internet.
They are parsed into an object tree which is a hybrid of both the RSS and Atom
@ -29,3 +30,17 @@ either a new channel or a new item is found that previously did not exist.
This allows you to easily monitor a feed for changes. See src/feed_test.go for
an example of how this works.
================================================================================
DEPENDENCIES
================================================================================
goinstall github.com/jteeuwen/go-pkg-xmlx
================================================================================
USAGE
================================================================================
$ goinstall github.com/jteeuwen/go-pkg-rss
An idiomatic example program can be found in example.go.

42
example.go Normal file
View File

@ -0,0 +1,42 @@
package main
/*
This is a minimal sample application, demonstrating how to set up an RSS feed
for regular polling of new channels/items.
*/
import (
"fmt"
"os"
"time"
rss "github.com/jteeuwen/go-pkg-rss"
)
func main() {
// This sets up a new feed and polls it for new channels/items in
// a separate goroutine. Invoke it with 'go PollFeed(..)' to have the
// polling performed in a separate goroutine, so you can continue with
// the rest of your program.
PollFeed("http://cyber.law.harvard.edu/rss/examples/sampleRss091.xml", 5)
}
func PollFeed(uri string, timeout int) {
feed := rss.New(timeout, true, chanHandler, itemHandler)
for {
if err := feed.Fetch(uri); err != nil {
fmt.Fprintf(os.Stderr, "[e] %s: %s", uri, err)
return
}
<-time.After(feed.SecondsTillUpdate() * 1e9)
}
}
func chanHandler(feed *rss.Feed, newchannels []*rss.Channel) {
fmt.Printf("%d new channel(s) in %s\n", len(newchannels), feed.Url)
}
func itemHandler(feed *rss.Feed, ch *rss.Channel, newitems []*rss.Item) {
fmt.Printf("%d new item(s) in %s\n", len(newitems), feed.Url)
}