diff --git a/.themes/classic/source/_includes/asides/github.html b/.themes/classic/source/_includes/asides/github.html
new file mode 100644
index 0000000..07b37aa
--- /dev/null
+++ b/.themes/classic/source/_includes/asides/github.html
@@ -0,0 +1,21 @@
+{% if site.github_user %}
+
+{% endif %}
diff --git a/.themes/classic/source/javascripts/github.js b/.themes/classic/source/javascripts/github.js
new file mode 100644
index 0000000..56ebe96
--- /dev/null
+++ b/.themes/classic/source/javascripts/github.js
@@ -0,0 +1,38 @@
+github = (function(){
+ function render(target, repos){
+ var i = 0, fragment = '', t = $(target)[0];
+
+ for(i = 0; i < repos.length; i++)
+ fragment += '
'+repos[i].name+''+repos[i].description+'
';
+
+ t.innerHTML = fragment;
+ }
+ return {
+ showRepos: function(user, target){
+ var feed = new jXHR();
+ feed.onerror = function (msg,url) {
+ $(target + ' li.loading').addClass('error').text("Error loading feed");
+ }
+ feed.onreadystatechange = function(data){
+ if (feed.readyState === 4) {
+ var repos = [];
+ var i;
+ for (i = 0; i < data.repositories.length; i++){
+ if (!data.repositories[i].fork)
+ repos.push(data.repositories[i]);
+ }
+ repos.sort(function(a, b){
+ var a = new Date(a.pushed_at),
+ b = new Date(b.pushed_at);
+
+ if (a.valueOf() == b.valueOf()) return 0;
+ return a.valueOf() > b.valueOf() ? -1 : 1;
+ })
+ render(target, repos)
+ }
+ };
+ feed.open("GET","http://github.com/api/v2/json/repos/show/"+user+"?callback=?");
+ feed.send();
+ }
+ };
+})();
\ No newline at end of file
diff --git a/_config.yml b/_config.yml
index 9a48c01..30adf81 100644
--- a/_config.yml
+++ b/_config.yml
@@ -55,6 +55,9 @@ twitter_follow_button: true
twitter_show_follower_count: false
twitter_tweet_button: true
+# github repositories
+github_user:
+
# Google Plus
google_plus_one: true
google_plus_one_size: medium