diff --git a/cnn_market.go b/cnn_market.go index e10eeb7..1bfc3c4 100644 --- a/cnn_market.go +++ b/cnn_market.go @@ -57,22 +57,23 @@ func NewMarket() *Market { market.errors = `` const any = `\s*(?:.+?)` - const price = `>([\d\.,]+)` + const change = `>([\+\-]?[\d\.,]+)<\/span>` + const price = `>([\d\.,]+)<\/span>` const percent = `>([\+\-]?[\d\.,]+%?)<` rules := []string{ - `>Dow<`, any, percent, any, price, any, percent, any, - `>Nasdaq<`, any, percent, any, price, any, percent, any, - `">S&P<`, any, percent, any, price, any, percent, any, - `>Nikkei 225<`, any, percent, any, price, any, percent, any, - `>Hang Seng<`, any, percent, any, price, any, percent, any, - `>FTSE 100<`, any, percent, any, price, any, percent, any, - `>DAX<`, any, percent, any, price, any, percent, any, - `>10-year yield<`, any, price, any, percent, any, + `>Dow<`, any, percent, any, price, any, change, any, + `>Nasdaq<`, any, percent, any, price, any, change, any, + `">S&P<`, any, percent, any, price, any, change, any, + `>10\-year yield<`, any, price, any, percent, any, `>Oil<`, any, price, any, percent, any, `>Yen<`, any, price, any, percent, any, `>Euro<`, any, price, any, percent, any, `>Gold<`, any, price, any, percent, any, + `>Nikkei 225<`, any, percent, any, price, any, change, any, + `>Hang Seng<`, any, percent, any, price, any, change, any, + `>FTSE 100<`, any, percent, any, price, any, change, any, + `>DAX<`, any, percent, any, price, any, change, any, } market.regex = regexp.MustCompile(strings.Join(rules, ``)) @@ -147,37 +148,38 @@ func (market *Market) extract(snippet []byte) *Market { market.Sp500[`latest`] = matches[8] market.Sp500[`percent`] = matches[9] - market.Tokyo[`change`] = matches[10] - market.Tokyo[`latest`] = matches[11] - market.Tokyo[`percent`] = matches[12] - market.HongKong[`change`] = matches[13] - market.HongKong[`latest`] = matches[14] - market.HongKong[`percent`] = matches[15] + market.Yield[`name`] = `10-year Yield` + market.Yield[`latest`] = matches[10] + market.Yield[`change`] = matches[11] - market.London[`change`] = matches[16] - market.London[`latest`] = matches[17] - market.London[`percent`] = matches[18] + market.Oil[`latest`] = matches[12] + market.Oil[`change`] = matches[13] - market.Frankfurt[`change`] = matches[19] - market.Frankfurt[`latest`] = matches[20] - market.Frankfurt[`percent`] = matches[21] + market.Yen[`latest`] = matches[14] + market.Yen[`change`] = matches[15] - market.Yield[`name`] = `10-year Yield` - market.Yield[`latest`] = matches[22] - market.Yield[`change`] = matches[23] + market.Euro[`latest`] = matches[16] + market.Euro[`change`] = matches[17] + + market.Gold[`latest`] = matches[18] + market.Gold[`change`] = matches[19] - market.Oil[`latest`] = matches[24] - market.Oil[`change`] = matches[25] + market.Tokyo[`change`] = matches[20] + market.Tokyo[`latest`] = matches[21] + market.Tokyo[`percent`] = matches[22] - market.Yen[`latest`] = matches[26] - market.Yen[`change`] = matches[27] + market.HongKong[`change`] = matches[23] + market.HongKong[`latest`] = matches[24] + market.HongKong[`percent`] = matches[25] - market.Euro[`latest`] = matches[28] - market.Euro[`change`] = matches[29] + market.London[`change`] = matches[26] + market.London[`latest`] = matches[27] + market.London[`percent`] = matches[28] - market.Gold[`latest`] = matches[30] - market.Gold[`change`] = matches[31] + market.Frankfurt[`change`] = matches[29] + market.Frankfurt[`latest`] = matches[30] + market.Frankfurt[`percent`] = matches[31] return market } diff --git a/screen.go b/screen.go index ce38cc9..da69dbc 100644 --- a/screen.go +++ b/screen.go @@ -86,8 +86,9 @@ func (screen *Screen) ClearLine(x int, y int) *Screen { // Draw accepts variable number of arguments and knows how to display the // market data, stock quotes, current time, and an arbitrary string. func (screen *Screen) Draw(objects ...interface{}) *Screen { + zonename, _ := time.Now().In(time.Local).Zone() if screen.pausedAt != nil { - defer screen.DrawLine(0, 0, ``+screen.pausedAt.Format(`3:04:05pm PST`)+``) + defer screen.DrawLine(0, 0, ``+screen.pausedAt.Format(`3:04:05pm ` + zonename)+``) } for _, ptr := range objects { switch ptr.(type) { @@ -98,7 +99,7 @@ func (screen *Screen) Draw(objects ...interface{}) *Screen { object := ptr.(*Quotes) screen.draw(screen.layout.Quotes(object.Fetch())) case time.Time: - timestamp := ptr.(time.Time).Format(`3:04:05pm PST`) + timestamp := ptr.(time.Time).Format(`3:04:05pm ` + zonename) screen.DrawLine(0, 0, ``+timestamp+``) default: screen.draw(ptr.(string))