Skip to content

Instantly share code, notes, and snippets.

Embed
What would you like to do?
var https = require('https'),
user = process.argv[2],
opts = parseOpts(process.argv.slice(3))
request('/users/' + user, function (res) {
if (!res.public_repos) {
console.log(res.message)
return
}
var pages = Math.ceil(res.public_repos / 100),
i = pages,
repos = []
while (i--) {
request('/users/' + user + '/repos?per_page=100&page=' + (i + 1), check)
}
function check (res) {
repos = repos.concat(res)
pages--
if (!pages) output(repos)
}
})
function request (url, cb) {
https.request({
hostname: 'api.github.com',
path: url,
headers: {'User-Agent': 'GitHub StarCounter'}
}, function (res) {
var body = ''
res
.on('data', function (buf) {
body += buf.toString()
})
.on('end', function () {
cb(JSON.parse(body))
})
}).end()
}
function output (repos) {
var total = 0,
longest = 0,
list = repos
.filter(function (r) {
total += r.stargazers_count
if (r.stargazers_count >= opts.thresh) {
if (r.name.length > longest) {
longest = r.name.length
}
return true
}
})
.sort(function (a, b) {
return b.stargazers_count - a.stargazers_count
})
if (list.length > opts.limit) {
list = list.slice(0, opts.limit)
}
console.log('\nTotal: ' + total + '\n')
console.log(list.map(function (r) {
return r.name +
new Array(longest - r.name.length + 4).join(' ') +
'\u2605 ' +
r.stargazers_count
}).join('\n'))
}
function parseOpts (args) {
var opts = {
thresh: 1,
limit: Infinity
}
args.forEach(function (a, i) {
var next = args[i + 1]
if (a === '-t') {
opts.thresh = parseInt(next, 10) || 1
} else if (a === '-l') {
opts.limit = parseInt(next, 10) || Infinity
}
})
return opts
}
@philipperemy

This comment has been minimized.

Copy link
Owner Author

philipperemy commented May 24, 2017

node count_stars.js philipperemy -t 10

Total: 431

Reuters-full-data-set                 ★  51
tensorflow-phased-lstm                ★  46
Deep-Learning-Tinder                  ★  45
Stanford-OpenIE-Python                ★  36
Order-Book-Matching-Engine            ★  28
financial-news-dataset                ★  20
yolo-9000                             ★  18
tensorflow-maxout                     ★  16
Market-Data                           ★  12
wavenet                               ★  11
tensorflow-class-activation-mapping   ★  9
Statistical-Arbitrage                 ★  8
Data-Mining-Automaton                 ★  8
philipperemy.github.io                ★  8
keras-visualize-activations           ★  8
Sentiment-Analysis-NLP                ★  7
Leboncoin                             ★  7
tensorflow-ctc-speech-recognition     ★  6
Peer-Group-Analysis-Clustering        ★  5
Ogame-API                             ★  4
japanese-words-to-vectors             ★  4
tensorflow-cnn-time-series            ★  4
HFT-FIX-Parser                        ★  4
google-news-scraper                   ★  4
Facebook-Profile-Deep-Learning        ★  4
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.