Skip to content

Commit

Permalink
tweet counts!
Browse files Browse the repository at this point in the history
  • Loading branch information
rvagg committed Apr 24, 2012
1 parent 6f7e050 commit 2a18ef9
Show file tree
Hide file tree
Showing 11 changed files with 101 additions and 69 deletions.
17 changes: 10 additions & 7 deletions index.html
Expand Up @@ -382,26 +382,29 @@
line-height: 56px;
font-size: 40px;
}
.title .gh {
.title .stat {
margin-top: -14px;
text-align: left;
font-size: 11px;
font-weight: bold;
height: 19px;
opacity: 0.5;
}
.title .gh span {
background-image: url("");
.title .stat span {
background-image: url("");
background-repeat: no-repeat;
display: inline-block;
padding: 1px 8px 0 24px;
}
.title .gh .w {
.title .stat .w {
background-position: 4px -24px;
}
.title .gh .f {
.title .stat .f {
background-position: 4px -50px;
}
.title .stat .t {
background-position: 4px -75px;
}
li div.size {
float: right;
margin: 0 0 0 30px;
Expand Down Expand Up @@ -620,8 +623,8 @@ <h1 class="overlay">
function render(results){
var html=[], i=results.length;
while(i--) {
results[i].gh = results[i].ghwatchers ? t('<div class="gh"><span class="w">{ghwatchers}</span><span class="f">{ghforks}</span></div>', results[i]) : ''
html.push(t('<li><a href="{url}"><div class="size">{size}</div><div class="title"><h3>{name}</h3>{gh}</div>{description}</a></li>', results[i]))
results[i].stat = results[i].ghwatchers ? t('<div class="stat"><span class="w">{ghwatchers}</span><span class="f">{ghforks}</span><span class="t">{tweets}</span></div>', results[i]) : ''
html.push(t('<li><a href="{url}"><div class="size">{size}</div><div class="title"><h3>{name}</h3>{stat}</div>{description}</a></li>', results[i]))
}
$('results').innerHTML = html.join('');
}
Expand Down
4 changes: 2 additions & 2 deletions lib/fetcher.js
@@ -1,11 +1,11 @@
var zip = require('zip')
, request = require('request')

, requestPool = { maxSockets: 10 }
, requestPool = { maxSockets: 20 }

, unzip = function (zipEntry, buffer) {
var reader = zip.Reader(buffer)
data = null
, data = null
// iterate through zipfile entries looking for the right name
reader.forEach(function(entry) {
if (zipEntry === entry._header.file_name) {
Expand Down
7 changes: 3 additions & 4 deletions lib/gitstats.js
@@ -1,6 +1,6 @@
var request = require('request')
, githubSpecRegex = /^([^\/]+)\/(.*)$/
, repoRegex = /github.com\/([\.\-\w]+)\/([^$/]+)/
, repoRegex = /github.com\/([\.\-\w]+)\/([^$\/]+)/
, GIT_API_REPO_URL = 'https://api.github.com/repos/{user}/{project}'

var GitStats = {
Expand Down Expand Up @@ -29,14 +29,14 @@ var GitStats = {

var data = JSON.parse(body)
if (!!data.forks && !!data.watchers) {
this.success(lib, {
callback(null, {
forks: data.forks
, watchers: data.watchers
, url: data.html_url
, lastPush: data.pushed_at
//, user: user
//, project: project
}, callback)
})
} else {
this.warn(lib, 'Looks like a GitHub project but can\'t get data from GitHub API')
callback()
Expand All @@ -48,7 +48,6 @@ var GitStats = {

module.exports.create = function (main, config) {
var gitStats = Object.create(GitStats)
gitStats.success = main.gitSuccess.bind(main)
gitStats.warn = main.warn.bind(main)
gitStats.error = main.error.bind(main)
return gitStats
Expand Down
86 changes: 43 additions & 43 deletions lib/main.js
Expand Up @@ -33,55 +33,48 @@ var Main = {
return console.log(err.red)

this.data = data
this.expectedTicks = data.length// * 2 // 2 ticks each lib, one for `process`, one for `gitstats`
this.expectedTicks = data.length

async.forEach(
data
, this.tickWrap(this.processor.processLibrary, this.processor)
, this.processLibrary.bind(this)
, this.finish.bind(this)
)
}

// wrap the function in another function that will increment 'ticks' and call progress() for us
, tickWrap: function (fn, ctx) {
return function (lib, callback) {
fn.call(ctx, lib, function () {
this.ticks++
this.progress()
callback()
}.bind(this))
}.bind(this)
}

// called when a library won't be included in the output, for whatever reason
, error: function (lib, err, callback) {
this.logger.log(ERROR, lib.name || 'UNKNOWN LIBRARY', err, lib.source ? lib.source : null)
this.errorCount++
callback()
}

// called when the library will be included but there is something odd
, warn: function (lib, warning) {
this.logger.log(WARNING, lib.name, warning)
this.progress() // need to call this to redraw the progress bar after printing the warning
}

// called when the library is checked and sized and ready to pack into the output
, success: function (lib, sizes, callback) {
this.gitstats.processLibrary(lib, this.complete.bind(this, lib, sizes, callback))
, processLibrary: function (lib, callback) {
async.parallel(
{
sizes: this.processor.processLibrary.bind(this.processor, lib)
, ghstats: this.gitstats.processLibrary.bind(this.gitstats, lib)
, twstats: this.twitterstats.processLibrary.bind(this.twitterstats, lib)
}
, function (err, data) {
this.ticks++
if (err)
return callback(err)
this.complete(lib, data.sizes, data.ghstats, data.twstats, callback)
}.bind(this)
)
}

, complete: function (lib, sizes, callback) {
, complete: function (lib, sizes, ghstats, twstats, callback) {
if (ghstats) {
lib.ghwatchers = strings.prettyLong(ghstats.watchers)
lib.ghforks = strings.prettyLong(ghstats.forks)
lib.ghlastpush = ghstats.lastPush
}
if (lib.ghlastpush && new Date(lib.ghlastpush).isBefore(this.ghLastPushCutoff)) {
this.warn(lib,'Too old! Last pushed to GitHub @ ' + new Date(lib.ghlastpush).toFormat('DD/MMM/YY') + ', ignoring')
callback()
} else {
// cleanup so we don't waste space
delete lib.ghlastpush
delete lib.source
delete lib.github
;delete lib.source
;delete lib.github
// overwrite the original size estimate with actual size
lib.size = strings.sizeToString(sizes.gzipped)
lib.tweets = strings.prettyLong(twstats.count)

this.atom.processLibrary(lib, function (err) {
if (err) {
Expand All @@ -93,21 +86,28 @@ var Main = {
SUCCESS
, lib.name
, ( 'raw: ' + strings.lpad(strings.sizeToString(sizes.raw), 8)
+ ', minified: ' + strings.lpad(strings.sizeToString(sizes.minified), 8)
+ ', gzipped: ' + strings.lpad(strings.sizeToString(sizes.gzipped), 8)
+ ', minified: ' + strings.lpad(strings.sizeToString(sizes.minified), 7)
+ ', gzipped: ' + strings.lpad(strings.sizeToString(sizes.gzipped), 6)
+ ', watchers: ' + strings.lpad(ghstats ? lib.ghwatchers : '-', 4)
+ ', forks: ' + strings.lpad(ghstats ? lib.ghforks : '-', 3)
+ ', tweets: ' + strings.lpad(lib.tweets, 4)
))
callback()
}.bind(this))
}
}

, gitSuccess: function (lib, ghData, callback) {
if (ghData) {
lib.ghwatchers = strings.prettyLong(ghData.watchers)
lib.ghforks = strings.prettyLong(ghData.forks)
lib.ghlastpush = ghData.lastPush
}
callback()
// called when a library won't be included in the output, for whatever reason
, error: function (lib, err, callback) {
this.logger.log(ERROR, lib.name || 'UNKNOWN LIBRARY', err, lib.source ? lib.source : null)
this.errorCount++
callback(err)
}

// called when the library will be included but there is something odd
, warn: function (lib, warning) {
this.logger.log(WARNING, lib.name, warning)
this.progress() // need to call this to redraw the progress bar after printing the warning
}

// called on error or success, to iterate our counter and write the output if we're all done
Expand Down Expand Up @@ -137,18 +137,18 @@ var Main = {
}.bind(this))
}

// shortcut
, progress: function () {
this.logger.progress(this.ticks, this.expectedTicks)
}
}
}

module.exports.create = function (config) {
var main = Object.create(Main)
main.input = require('./input').create(config.inFile)
main.output = require('./output').create(config.outFile)
main.processor = require('./processor').create(main, config)
main.gitstats = require('./gitstats').create(main, config)
main.twitterstats = require('./twitterstats').create(main, config)
main.atom = require('./atom')
main.logger = require('./logger').create(config)
main.ghLastPushCutoff = new Date().addMonths(-(config.githubLastPushCutoffMonths))
Expand Down
7 changes: 3 additions & 4 deletions lib/processor.js
Expand Up @@ -36,7 +36,7 @@ var Processor = {
if (!/^(http|ftp)/.test(source) && /function/.test(source)) {
lib.novalidate = true
data += source
callback()
return callback()
} else {
// source is a zip with a bang-path to the file within the zip?
if (match = source.match(/^(.*\.zip)!\/(.*$)/)) {
Expand Down Expand Up @@ -76,15 +76,14 @@ var Processor = {
return this.error(lib, insane + ', ignoring', callback)

// holy moly! we got here?
this.success(lib, sizes, callback)
callback(null, sizes)
}
}

module.exports.create = function (main, config) {
var processor = Object.create(Processor)
processor.error = main.error.bind(main)
processor.success = main.success.bind(main)
processor.warn = main.warn.bind(main)
processor.validator = require('./validator').create(config)
return processor
}
}
16 changes: 7 additions & 9 deletions lib/sizer.js
Expand Up @@ -12,16 +12,14 @@ module.exports = function(source, callback) {
uglifyParser.parse(source))))

gzip(minified, function(err, data) {
if (err) callback(err)
else {
callback(null, {
raw: source.length
, minified: minified.length
, gzipped: data.length
})
}
if (err) return callback(err)
callback(null, {
raw: source.length
, minified: minified.length
, gzipped: data.length
})
})
} catch (ex) {
callback && callback(ex)
callback(ex)
}
}
33 changes: 33 additions & 0 deletions lib/twitterstats.js
@@ -0,0 +1,33 @@
var request = require('request')
, TWITTER_API_URL = 'http://urls.api.twitter.com/1/urls/count.json?url={url}'

var TwitterStats = {
processLibrary: function (lib, callback) {
request(
TWITTER_API_URL.replace('{url}', encodeURIComponent(lib.url))
, function (err, response, body) {
if (err)
return this.error(
lib
, 'Error requesting tweet count from Twitter for ' + lib.url + ': ' + err
, callback
)
var data = JSON.parse(body)

if (typeof data.count == 'number') {
callback(null, data)
} else {
this.warn(lib, 'Couldn\'t get tweet count from Twitter API')
callback()
}
}.bind(this)
)
}
}

module.exports.create = function (main, config) {
var twitterStats = Object.create(TwitterStats)
twitterStats.warn = main.warn.bind(main)
twitterStats.error = main.error.bind(main)
return twitterStats
}
Binary file removed resources/github.png
Binary file not shown.
Binary file removed resources/github.psd
Binary file not shown.
Binary file added resources/icons.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added resources/icons.psd
Binary file not shown.

0 comments on commit 2a18ef9

Please sign in to comment.