1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00
v/examples/news_fetcher.v

82 lines
1.5 KiB
V
Raw Normal View History

2019-06-23 05:21:30 +03:00
// Copyright (c) 2019 Alexander Medvednikov. All rights reserved.
// Use of this source code is governed by an MIT license
// that can be found in the LICENSE file.
2019-12-30 07:42:23 +03:00
import net.http
2019-06-22 22:51:07 +03:00
import json
import sync
const (
2019-07-30 16:06:16 +03:00
NR_THREADS = 4
2019-06-22 22:51:07 +03:00
)
struct Story {
title string
2019-12-22 01:41:42 +03:00
url string
2019-06-22 22:51:07 +03:00
}
struct Fetcher {
mut:
2019-12-22 01:41:42 +03:00
mu &sync.Mutex
ids []int
cursor int
wg &sync.WaitGroup
2019-06-22 22:51:07 +03:00
}
fn (f mut Fetcher) fetch() {
for {
if f.cursor >= f.ids.len {
return
}
id := f.ids[f.cursor]
f.mu.lock()
2019-06-22 22:51:07 +03:00
f.cursor++
f.mu.unlock()
cursor := f.cursor
2019-07-29 20:18:26 +03:00
resp := http.get('https://hacker-news.firebaseio.com/v0/item/${id}.json') or {
println('failed to fetch data from /v0/item/${id}.json')
exit(1)
}
2019-12-22 01:41:42 +03:00
story := json.decode(Story,resp.text) or {
2019-06-23 11:41:42 +03:00
println('failed to decode a story')
exit(1)
2019-06-22 22:51:07 +03:00
}
println('#$cursor) $story.title | $story.url')
f.wg.done()
2019-06-22 22:51:07 +03:00
}
}
2019-07-30 16:06:16 +03:00
// Fetches top HN stories in 4 coroutines
2019-06-22 22:51:07 +03:00
fn main() {
2019-07-29 20:18:26 +03:00
resp := http.get('https://hacker-news.firebaseio.com/v0/topstories.json') or {
println('failed to fetch data from /v0/topstories.json')
return
}
2019-12-22 01:41:42 +03:00
mut ids := json.decode([]int,resp.text) or {
2019-07-29 20:18:26 +03:00
println('failed to decode topstories.json')
2019-06-22 22:51:07 +03:00
return
}
2019-07-30 16:06:16 +03:00
if ids.len > 10 {
// ids = ids[:10]
mut tmp := [0].repeat(10)
2019-12-22 01:41:42 +03:00
for i := 0; i < 10; i++ {
2019-07-30 16:06:16 +03:00
tmp[i] = ids[i]
}
ids = tmp
}
2019-10-25 17:24:40 +03:00
wg := sync.new_waitgroup()
mtx := sync.new_mutex()
2019-12-22 01:41:42 +03:00
mut fetcher := &Fetcher{
ids: ids
mu: 0
wg: 0
}
2019-10-25 17:24:40 +03:00
fetcher.mu = &mtx
fetcher.wg = &wg
fetcher.wg.add(ids.len)
2019-06-22 22:51:07 +03:00
for i := 0; i < NR_THREADS; i++ {
go fetcher.fetch()
}
2019-10-25 17:24:40 +03:00
fetcher.wg.wait()
2019-06-22 22:51:07 +03:00
}