commit 03249b262d16539685ce3575552932e178836fd1 Author: Ryan Graham Date: Thu Nov 19 22:21:11 2015 -0800 Initial commit Based off of strongloop/changelog Created for strongloop-internal/scrum-nodeops#1040 diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..0dbc0cee --- /dev/null +++ b/.gitignore @@ -0,0 +1,5 @@ +_site/ +.bundle/ +vendor +.sass-cache +feed.xml diff --git a/Gemfile b/Gemfile new file mode 100644 index 00000000..6b461c11 --- /dev/null +++ b/Gemfile @@ -0,0 +1,9 @@ +# A sample Gemfile +source "https://rubygems.org" + +gem 'activesupport', require: 'active_support' +gem 'octokit' +gem 'faraday-http-cache', '~> 1.0.1' +gem 'typhoeus' + +gem 'github-pages' diff --git a/Gemfile.lock b/Gemfile.lock new file mode 100644 index 00000000..72a2dbbb --- /dev/null +++ b/Gemfile.lock @@ -0,0 +1,145 @@ +GEM + remote: https://rubygems.org/ + specs: + RedCloth (4.2.9) + activesupport (4.2.0) + i18n (~> 0.7) + json (~> 1.7, >= 1.7.7) + minitest (~> 5.1) + thread_safe (~> 0.3, >= 0.3.4) + tzinfo (~> 1.1) + addressable (2.3.6) + blankslate (2.1.2.4) + celluloid (0.16.0) + timers (~> 4.0.0) + classifier-reborn (2.0.3) + fast-stemmer (~> 1.0) + coffee-script (2.3.0) + coffee-script-source + execjs + coffee-script-source (1.9.0) + colorator (0.1) + ethon (0.7.2) + ffi (>= 1.3.0) + execjs (2.2.2) + faraday (0.9.1) + multipart-post (>= 1.2, < 3) + faraday-http-cache (1.0.1) + faraday (~> 0.8) + fast-stemmer (1.0.2) + ffi (1.9.6) + gemoji (2.1.0) + github-pages (33) + RedCloth (= 4.2.9) + github-pages-health-check (~> 0.2) + jekyll (= 2.4.0) + jekyll-coffeescript (= 1.0.1) + jekyll-mentions (= 0.2.1) + jekyll-redirect-from (= 0.6.2) + jekyll-sass-converter (= 1.2.0) + jekyll-sitemap (= 0.6.3) + jemoji (= 0.4.0) + kramdown (= 1.5.0) + liquid (= 2.6.1) + maruku (= 0.7.0) + mercenary (~> 0.3) + pygments.rb (= 0.6.1) + rdiscount (= 2.1.7) + redcarpet (= 3.1.2) + terminal-table (~> 1.4) + github-pages-health-check (0.2.1) + net-dns (~> 0.6) + public_suffix (~> 1.4) + hitimes (1.2.2) + html-pipeline (1.9.0) + activesupport (>= 2) + nokogiri (~> 1.4) + i18n (0.7.0) + jekyll (2.4.0) + classifier-reborn (~> 2.0) + colorator (~> 0.1) + jekyll-coffeescript (~> 1.0) + jekyll-gist (~> 1.0) + jekyll-paginate (~> 1.0) + jekyll-sass-converter (~> 1.0) + jekyll-watch (~> 1.1) + kramdown (~> 1.3) + liquid (~> 2.6.1) + mercenary (~> 0.3.3) + pygments.rb (~> 0.6.0) + redcarpet (~> 3.1) + safe_yaml (~> 1.0) + toml (~> 0.1.0) + jekyll-coffeescript (1.0.1) + coffee-script (~> 2.2) + jekyll-gist (1.1.0) + jekyll-mentions (0.2.1) + html-pipeline (~> 1.9.0) + jekyll (~> 2.0) + jekyll-paginate (1.1.0) + jekyll-redirect-from (0.6.2) + jekyll (~> 2.0) + jekyll-sass-converter (1.2.0) + sass (~> 3.2) + jekyll-sitemap (0.6.3) + jekyll-watch (1.2.1) + listen (~> 2.7) + jemoji (0.4.0) + gemoji (~> 2.0) + html-pipeline (~> 1.9) + jekyll (~> 2.0) + json (1.8.2) + kramdown (1.5.0) + liquid (2.6.1) + listen (2.8.5) + celluloid (>= 0.15.2) + rb-fsevent (>= 0.9.3) + rb-inotify (>= 0.9) + maruku (0.7.0) + mercenary (0.3.5) + mini_portile (0.6.2) + minitest (5.5.1) + multipart-post (2.0.0) + net-dns (0.8.0) + nokogiri (1.6.6.2) + mini_portile (~> 0.6.0) + octokit (3.7.0) + sawyer (~> 0.6.0, >= 0.5.3) + parslet (1.5.0) + blankslate (~> 2.0) + posix-spawn (0.3.9) + public_suffix (1.4.6) + pygments.rb (0.6.1) + posix-spawn (~> 0.3.6) + yajl-ruby (~> 1.2.0) + rb-fsevent (0.9.4) + rb-inotify (0.9.5) + ffi (>= 0.5.0) + rdiscount (2.1.7) + redcarpet (3.1.2) + safe_yaml (1.0.4) + sass (3.4.10) + sawyer (0.6.0) + addressable (~> 2.3.5) + faraday (~> 0.8, < 0.10) + terminal-table (1.4.5) + thread_safe (0.3.4) + timers (4.0.1) + hitimes + toml (0.1.2) + parslet (~> 1.5.0) + typhoeus (0.7.1) + ethon (>= 0.7.1) + tzinfo (1.2.2) + thread_safe (~> 0.1) + yajl-ruby (1.2.1) + +PLATFORMS + ruby + +DEPENDENCIES + activesupport + faraday-http-cache (~> 1.0.1) + github-pages + octokit + typhoeus diff --git a/_config.yml b/_config.yml new file mode 100644 index 00000000..045f8110 --- /dev/null +++ b/_config.yml @@ -0,0 +1,9 @@ +# Site settings +title: "Previously, on LoopBack..." +description: "Generated summary of changes made in LoopBack." +baseurl: "/loopback" # the subpath of your site, e.g. /blog/ +twitter_username: strongloop +github_username: strongloop +exclude: ["*.rb", "Gemfile*", ".gitignore", ".bundle", "vendor"] +# Build settings +#markdown: kramdown diff --git a/_includes/footer.html b/_includes/footer.html new file mode 100644 index 00000000..be3976f7 --- /dev/null +++ b/_includes/footer.html @@ -0,0 +1,55 @@ + diff --git a/_includes/head.html b/_includes/head.html new file mode 100644 index 00000000..4d7e8f00 --- /dev/null +++ b/_includes/head.html @@ -0,0 +1,11 @@ + + + + + + {% if page.title %}{{ page.title }}{% else %}{{ site.title }}{% endif %} + + + + + diff --git a/_includes/header.html b/_includes/header.html new file mode 100644 index 00000000..cfe381f7 --- /dev/null +++ b/_includes/header.html @@ -0,0 +1,27 @@ + diff --git a/_layouts/default.html b/_layouts/default.html new file mode 100644 index 00000000..e4ab96fb --- /dev/null +++ b/_layouts/default.html @@ -0,0 +1,20 @@ + + + + {% include head.html %} + + + + {% include header.html %} + +
+
+ {{ content }} +
+
+ + {% include footer.html %} + + + + diff --git a/_layouts/page.html b/_layouts/page.html new file mode 100644 index 00000000..74c1a118 --- /dev/null +++ b/_layouts/page.html @@ -0,0 +1,14 @@ +--- +layout: default +--- +
+ +
+

{{ page.title }}

+
+ +
+ {{ content }} +
+ +
diff --git a/_layouts/post.html b/_layouts/post.html new file mode 100644 index 00000000..a2b4e52f --- /dev/null +++ b/_layouts/post.html @@ -0,0 +1,15 @@ +--- +layout: default +--- +
+ +
+

{{ page.title }}

+ +
+ +
+ {{ content }} +
+ +
diff --git a/_sass/_base.scss b/_sass/_base.scss new file mode 100644 index 00000000..518bf2b0 --- /dev/null +++ b/_sass/_base.scss @@ -0,0 +1,204 @@ +/** + * Reset some basic elements + */ +body, h1, h2, h3, h4, h5, h6, +p, blockquote, pre, hr, +dl, dd, ol, ul, figure { + margin: 0; + padding: 0; +} + + + +/** + * Basic styling + */ +body { + font-family: $base-font-family; + font-size: $base-font-size; + line-height: $base-line-height; + font-weight: 300; + color: $text-color; + background-color: $background-color; + -webkit-text-size-adjust: 100%; +} + + + +/** + * Set `margin-bottom` to maintain vertical rhythm + */ +h1, h2, h3, h4, h5, h6, +p, blockquote, pre, +ul, ol, dl, figure, +%vertical-rhythm { + margin-bottom: $spacing-unit / 2; +} + + + +/** + * Images + */ +img { + max-width: 100%; + vertical-align: middle; +} + + + +/** + * Figures + */ +figure > img { + display: block; +} + +figcaption { + font-size: $small-font-size; +} + + + +/** + * Lists + */ +ul, ol { + margin-left: $spacing-unit; +} + +li { + > ul, + > ol { + margin-bottom: 0; + } +} + + + +/** + * Headings + */ +h1, h2, h3, h4, h5, h6 { + font-weight: 300; +} + + + +/** + * Links + */ +a { + color: $brand-color; + text-decoration: none; + + &:visited { + color: darken($brand-color, 15%); + } + + &:hover { + color: $text-color; + text-decoration: underline; + } +} + + + +/** + * Blockquotes + */ +blockquote { + color: $grey-color; + border-left: 4px solid $grey-color-light; + padding-left: $spacing-unit / 2; + font-size: 18px; + letter-spacing: -1px; + font-style: italic; + + > :last-child { + margin-bottom: 0; + } +} + + + +/** + * Code formatting + */ +pre, +code { + font-size: 15px; + border: 1px solid $grey-color-light; + border-radius: 3px; + background-color: #eef; +} + +code { + padding: 1px 5px; +} + +pre { + padding: 8px 12px; + overflow-x: scroll; + + > code { + border: 0; + padding-right: 0; + padding-left: 0; + } +} + + + +/** + * Wrapper + */ +.wrapper { + max-width: -webkit-calc(800px - (#{$spacing-unit} * 2)); + max-width: calc(800px - (#{$spacing-unit} * 2)); + margin-right: auto; + margin-left: auto; + padding-right: $spacing-unit; + padding-left: $spacing-unit; + @extend %clearfix; + + @include media-query($on-laptop) { + max-width: -webkit-calc(800px - (#{$spacing-unit})); + max-width: calc(800px - (#{$spacing-unit})); + padding-right: $spacing-unit / 2; + padding-left: $spacing-unit / 2; + } +} + + + +/** + * Clearfix + */ +%clearfix { + + &:after { + content: ""; + display: table; + clear: both; + } +} + + + +/** + * Icons + */ +.icon { + + > svg { + display: inline-block; + width: 16px; + height: 16px; + vertical-align: middle; + + path { + fill: $grey-color; + } + } +} diff --git a/_sass/_layout.scss b/_sass/_layout.scss new file mode 100644 index 00000000..def56f89 --- /dev/null +++ b/_sass/_layout.scss @@ -0,0 +1,236 @@ +/** + * Site header + */ +.site-header { + border-top: 5px solid $grey-color-dark; + border-bottom: 1px solid $grey-color-light; + min-height: 56px; + + // Positioning context for the mobile navigation icon + position: relative; +} + +.site-title { + font-size: 26px; + line-height: 56px; + letter-spacing: -1px; + margin-bottom: 0; + float: left; + + &, + &:visited { + color: $grey-color-dark; + } +} + +.site-nav { + float: right; + line-height: 56px; + + .menu-icon { + display: none; + } + + .page-link { + color: $text-color; + line-height: $base-line-height; + + // Gaps between nav items, but not on the first one + &:not(:first-child) { + margin-left: 20px; + } + } + + @include media-query($on-palm) { + position: absolute; + top: 9px; + right: 30px; + background-color: $background-color; + border: 1px solid $grey-color-light; + border-radius: 5px; + text-align: right; + + .menu-icon { + display: block; + float: right; + width: 36px; + height: 26px; + line-height: 0; + padding-top: 10px; + text-align: center; + + > svg { + width: 18px; + height: 15px; + + path { + fill: $grey-color-dark; + } + } + } + + .trigger { + clear: both; + display: none; + } + + &:hover .trigger { + display: block; + padding-bottom: 5px; + } + + .page-link { + display: block; + padding: 5px 10px; + } + } +} + + + +/** + * Site footer + */ +.site-footer { + border-top: 1px solid $grey-color-light; + padding: $spacing-unit 0; +} + +.footer-heading { + font-size: 18px; + margin-bottom: $spacing-unit / 2; +} + +.contact-list, +.social-media-list { + list-style: none; + margin-left: 0; +} + +.footer-col-wrapper { + font-size: 15px; + color: $grey-color; + margin-left: -$spacing-unit / 2; + @extend %clearfix; +} + +.footer-col { + float: left; + margin-bottom: $spacing-unit / 2; + padding-left: $spacing-unit / 2; +} + +.footer-col-1 { + width: -webkit-calc(35% - (#{$spacing-unit} / 2)); + width: calc(35% - (#{$spacing-unit} / 2)); +} + +.footer-col-2 { + width: -webkit-calc(20% - (#{$spacing-unit} / 2)); + width: calc(20% - (#{$spacing-unit} / 2)); +} + +.footer-col-3 { + width: -webkit-calc(45% - (#{$spacing-unit} / 2)); + width: calc(45% - (#{$spacing-unit} / 2)); +} + +@include media-query($on-laptop) { + .footer-col-1, + .footer-col-2 { + width: -webkit-calc(50% - (#{$spacing-unit} / 2)); + width: calc(50% - (#{$spacing-unit} / 2)); + } + + .footer-col-3 { + width: -webkit-calc(100% - (#{$spacing-unit} / 2)); + width: calc(100% - (#{$spacing-unit} / 2)); + } +} + +@include media-query($on-palm) { + .footer-col { + float: none; + width: -webkit-calc(100% - (#{$spacing-unit} / 2)); + width: calc(100% - (#{$spacing-unit} / 2)); + } +} + + + +/** + * Page content + */ +.page-content { + padding: $spacing-unit 0; +} + +.page-heading { + font-size: 20px; +} + +.post-list { + margin-left: 0; + list-style: none; + + > li { + margin-bottom: $spacing-unit; + } +} + +.post-meta { + font-size: $small-font-size; + color: $grey-color; +} + +.post-link { + display: block; + font-size: 24px; +} + + + +/** + * Posts + */ +.post-header { + margin-bottom: $spacing-unit; +} + +.post-title { + font-size: 42px; + letter-spacing: -1px; + line-height: 1; + + @include media-query($on-laptop) { + font-size: 36px; + } +} + +.post-content { + margin-bottom: $spacing-unit; + + h2 { + font-size: 32px; + + @include media-query($on-laptop) { + font-size: 28px; + } + } + + h3 { + font-size: 26px; + + @include media-query($on-laptop) { + font-size: 22px; + } + } + + h4 { + font-size: 20px; + + @include media-query($on-laptop) { + font-size: 18px; + } + } +} diff --git a/_sass/_syntax-highlighting.scss b/_sass/_syntax-highlighting.scss new file mode 100644 index 00000000..e36627da --- /dev/null +++ b/_sass/_syntax-highlighting.scss @@ -0,0 +1,67 @@ +/** + * Syntax highlighting styles + */ +.highlight { + background: #fff; + @extend %vertical-rhythm; + + .c { color: #998; font-style: italic } // Comment + .err { color: #a61717; background-color: #e3d2d2 } // Error + .k { font-weight: bold } // Keyword + .o { font-weight: bold } // Operator + .cm { color: #998; font-style: italic } // Comment.Multiline + .cp { color: #999; font-weight: bold } // Comment.Preproc + .c1 { color: #998; font-style: italic } // Comment.Single + .cs { color: #999; font-weight: bold; font-style: italic } // Comment.Special + .gd { color: #000; background-color: #fdd } // Generic.Deleted + .gd .x { color: #000; background-color: #faa } // Generic.Deleted.Specific + .ge { font-style: italic } // Generic.Emph + .gr { color: #a00 } // Generic.Error + .gh { color: #999 } // Generic.Heading + .gi { color: #000; background-color: #dfd } // Generic.Inserted + .gi .x { color: #000; background-color: #afa } // Generic.Inserted.Specific + .go { color: #888 } // Generic.Output + .gp { color: #555 } // Generic.Prompt + .gs { font-weight: bold } // Generic.Strong + .gu { color: #aaa } // Generic.Subheading + .gt { color: #a00 } // Generic.Traceback + .kc { font-weight: bold } // Keyword.Constant + .kd { font-weight: bold } // Keyword.Declaration + .kp { font-weight: bold } // Keyword.Pseudo + .kr { font-weight: bold } // Keyword.Reserved + .kt { color: #458; font-weight: bold } // Keyword.Type + .m { color: #099 } // Literal.Number + .s { color: #d14 } // Literal.String + .na { color: #008080 } // Name.Attribute + .nb { color: #0086B3 } // Name.Builtin + .nc { color: #458; font-weight: bold } // Name.Class + .no { color: #008080 } // Name.Constant + .ni { color: #800080 } // Name.Entity + .ne { color: #900; font-weight: bold } // Name.Exception + .nf { color: #900; font-weight: bold } // Name.Function + .nn { color: #555 } // Name.Namespace + .nt { color: #000080 } // Name.Tag + .nv { color: #008080 } // Name.Variable + .ow { font-weight: bold } // Operator.Word + .w { color: #bbb } // Text.Whitespace + .mf { color: #099 } // Literal.Number.Float + .mh { color: #099 } // Literal.Number.Hex + .mi { color: #099 } // Literal.Number.Integer + .mo { color: #099 } // Literal.Number.Oct + .sb { color: #d14 } // Literal.String.Backtick + .sc { color: #d14 } // Literal.String.Char + .sd { color: #d14 } // Literal.String.Doc + .s2 { color: #d14 } // Literal.String.Double + .se { color: #d14 } // Literal.String.Escape + .sh { color: #d14 } // Literal.String.Heredoc + .si { color: #d14 } // Literal.String.Interpol + .sx { color: #d14 } // Literal.String.Other + .sr { color: #009926 } // Literal.String.Regex + .s1 { color: #d14 } // Literal.String.Single + .ss { color: #990073 } // Literal.String.Symbol + .bp { color: #999 } // Name.Builtin.Pseudo + .vc { color: #008080 } // Name.Variable.Class + .vg { color: #008080 } // Name.Variable.Global + .vi { color: #008080 } // Name.Variable.Instance + .il { color: #099 } // Literal.Number.Integer.Long +} diff --git a/changelog.rb b/changelog.rb new file mode 100755 index 00000000..1076d6ad --- /dev/null +++ b/changelog.rb @@ -0,0 +1,234 @@ +#!/usr/bin/env ruby + +require 'active_support' +require 'active_support/core_ext' +require 'octokit' +require 'faraday-http-cache' +require 'typhoeus/adapters/faraday' +require 'base64' +require 'yaml' + +repo_types = (ARGV[0] || 'public').split(',') +span = ARGV[1] || 'week' + +today = Date.current +last_week = today.last_week + +sprints = [ + [Date.parse('May 5, 2015'), Date.parse('May 18, 2015'), 70] +] +while sprints.last[1] < today do + prev = sprints.last + sprints << [prev[0] + 14.days, prev[1] + 14.days, prev[2] + 1] +end +weeks = sprints.last(4).reverse + +token = ENV['GITHUB_TOKEN'] +if token.nil? or token.empty? + token = `git config github.token`.strip +end + +if token.empty? + STDERR.puts 'Please visit https://github.com/settings/tokens/new to generate a token' + STDERR.puts "Once you have your token, run 'git config github.token '" + exit 1 +end + +# Response middleware that overrides the max-age. +# This allows the caching middleware to store things for up to a week +class MoarCacheable < Faraday::Middleware + def call(request_env) + @app.call(request_env).on_complete do |response_env| + if response_env[:response_headers]["cache-control"] == "private, max-age=60, s-maxage=60" + response_env[:response_headers]["cache-control"] = "private, max-age=604800, s-maxage=604800" + end + end + end +end + +class SimpleLogger + def initialize(stream) + @stream = stream + end + def debug(*a) + # @stream.puts *a + end +end + +store = ActiveSupport::Cache.lookup_store(:file_store, "/tmp/gh_cache") + +stack = Faraday::RackBuilder.new do |builder| + builder.use Faraday::HttpCache, shared_cache: false, store: store, serializer: Marshal, logger: SimpleLogger.new(STDERR) + builder.use Octokit::Response::RaiseError + builder.adapter Faraday.default_adapter +end +#npm = Faraday.new(url: 'https://registry.npmjs.org', builder: stack) + +gh = Octokit::Client.new(access_token: token, auto_paginate: true, middleware: stack) +if not gh.user_authenticated? + STDERR.puts "Unauthenticated connection to GitHub, private repos will be invisible" +end + +starting = gh.rate_limit!.remaining +STDERR.puts "GitHub API: #{gh.rate_limit}" + +$commitsToSkip = Hash.new {|h,k| h[k] = []} + +def maybe_pr(gh, path, number) + gh.pull_request(path, number) rescue false +end + +def pp_commit(gh, r, commit) + msg = commit.commit.message.lines.first.strip + if $commitsToSkip[r.full_name].include? commit.sha + nil + elsif msg =~ /\AMerge pull request #(\d+) from/ and pr = maybe_pr(gh, r.full_name, $~[1]) + gh.pull_request_commits(r.full_name, pr.number).each do |c| + $commitsToSkip[r.full_name] << c.sha + end + "[PR##{pr.number}](#{pr.html_url}) #{pr.title} ([#{pr.user.login}](#{pr.user.html_url}))" + elsif msg =~ /\Av?\d+\.\d+\.\d+\Z/ + c = commit + gc = commit.commit # lower level git info + author = gc.author.name + if c.author + author = "[#{author}](#{c.author.html_url})" + end + "**Released #{msg}** (#{author})" + else + c = commit + gc = commit.commit # lower level git info + author = gc.author.name + if c.author + author = "[#{author}](#{c.author.html_url})" + end + "[@#{c.sha[0..6]}](#{c.html_url}) #{msg} (#{author})" + end +end + +def badge(alt, img, url) + "[![#{alt}](#{img})](#{url})" +end + +def issues_badge(repo) + badge('GitHub Issues', + "https://img.shields.io/github/issues/#{repo.full_name}.svg", + "#{repo.html_url}/issues") +end + +def downloads_badge(repo) + badge('Downloads', + "https://img.shields.io/npm/dm/#{repo.npm_name}.svg", + "https://npmjs.com/package/#{repo.npm_name}") +end + +def pp_week(gh, week, repos) + repos.group_by { |r| + if r.name =~ /connector/ + 'Connectors' + elsif r.name =~ /component/ + 'Components' + elsif r.name =~ /-sdk-/ + 'SDKs' + else + 'Core' + end + }.each do |group, repos| + puts "\n### #{group}\n" + repos.each do |repo| + commits = repo.commits.reject { |c| + c.commit.message =~ /\AMerge (branch|tag)/ + }.reject { |c| + c.commit.committer.date <= week[0] or + c.commit.committer.date >= week[1] + }.map {|c| + pp_commit(gh, repo, c) + }.compact + next if commits.empty? + heading = repo.npm_name || repo.name + #heading << " #{issues_badge(repo)}" + #if repo.npm_json.nil? + # heading << ' *package not available on npm*' + #else + # heading << " #{downloads_badge(repo)}" + #end + puts " * #{heading}" + # puts "#### v.Next" + commits.each do |c| + if c =~ /\A#+/ + puts + puts c + else + puts " * #{c}" + end + end + end + puts + end +end + +REPOS = [ + 'loopback', + 'loopback-boot', + 'loopback-datasource-juggler', + 'loopback-sdk-angular', + 'loopback-sdk-ios', + 'loopback-sdk-angular', + 'loopback-sdk-xamarin', + 'generator-loopback', + 'loopback-connector-*', + 'loopback-swagger', + 'loopback-component-*', + 'loopback-phase', + 'loopback-filters', +] + +repos = repo_types + .flat_map {|t| gh.org_repos('strongloop', type: t) } + .select { |r| REPOS.any? {|pat| File.fnmatch?(pat, r.name) } } + .map { |r| + r.tap { |r| + r.pkg_json_c = gh.contents(r.full_name, path: 'package.json') rescue nil + if r.pkg_json_c and r.pkg_json_c.type == 'file' and r.pkg_json_c.encoding == 'base64' + r.pkg_json = Base64.decode64(r.pkg_json_c.content) + r.pkg = YAML.load(r.pkg_json) + r.npm_name = r.pkg['name'] + r.npm_json = npm.get("/#{r.npm_name}") rescue false + r.npm_info = YAML.load(r.npm_json.body) rescue {} + r.npm_releases = {} + (r.npm_info['time'] || []).each do |ev, at| + at = Time.parse(at) + if ev != 'modified' and ev != 'created' and at >= weeks.last[0] and at <= weeks.first[1] + r.npm_releases[ev] = at + end + end + else + r.pkg_json = nil + r.npm_releases = {} + r.npm_info = {} + end + r.commits = gh.commits_between(r.full_name, weeks.last[0], weeks.first[1]) rescue [] + r.shas = r.commits.map(&:sha) + } + } +STDERR.puts "gathering repos used: #{starting - gh.rate_limit!.remaining} requests (#{gh.rate_limit})" + +# Frontmatter for Jekyll +puts '---' +puts 'layout: page' +puts '---' + + +weeks.each do |week| + heading = "Sprint #{week[2]} (#{week[0]} to #{week[1]})" + if week[1].future? + heading << ' so far' + end + puts "## #{heading}" + pp_week(gh, week, repos) + STDERR.puts "post pp_week(#{week[0]}) used: #{starting - gh.rate_limit!.remaining} requests (#{gh.rate_limit})" + puts '----' + puts +end + +STDERR.puts "Used #{starting - gh.rate_limit!.remaining} requests (#{gh.rate_limit})" diff --git a/css/main.scss b/css/main.scss new file mode 100755 index 00000000..f03d1c3d --- /dev/null +++ b/css/main.scss @@ -0,0 +1,49 @@ +--- +# Only the main Sass file needs front matter (the dashes are enough) +--- +@charset "utf-8"; + + + +// Our variables +$base-font-family: Helvetica, Arial, sans-serif; +$base-font-size: 16px; +$small-font-size: $base-font-size * 0.875; +$base-line-height: 1.5; + +$spacing-unit: 30px; + +$text-color: #111; +$background-color: #fdfdfd; +$brand-color: #2a7ae2; + +$grey-color: #828282; +$grey-color-light: lighten($grey-color, 40%); +$grey-color-dark: darken($grey-color, 25%); + +$on-palm: 600px; +$on-laptop: 800px; + + + +// Using media queries with like this: +// @include media-query($palm) { +// .wrapper { +// padding-right: $spacing-unit / 2; +// padding-left: $spacing-unit / 2; +// } +// } +@mixin media-query($device) { + @media screen and (max-width: $device) { + @content; + } +} + + + +// Import partials from `sass_dir` (defaults to `_sass`) +@import + "base", + "layout", + "syntax-highlighting" +; diff --git a/index.md b/index.md new file mode 100644 index 00000000..a7befb55 --- /dev/null +++ b/index.md @@ -0,0 +1,3 @@ +--- +layout: page +--- diff --git a/robots.txt b/robots.txt new file mode 100644 index 00000000..1f53798b --- /dev/null +++ b/robots.txt @@ -0,0 +1,2 @@ +User-agent: * +Disallow: /