Skip to content

Instantly share code, notes, and snippets.

@subzey
Forked from 140bytes/LICENSE.txt
Created June 22, 2011 14:43
Show Gist options
  • Select an option

  • Save subzey/1040240 to your computer and use it in GitHub Desktop.

Select an option

Save subzey/1040240 to your computer and use it in GitHub Desktop.

Revisions

  1. subzey revised this gist Oct 8, 2011. 3 changed files with 5 additions and 5 deletions.
    6 changes: 3 additions & 3 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -15,8 +15,8 @@ function(
    ;
    // add the following to sum:
    s +=
    // stored value minus following expression...
    v - (
    // stored is more than following expression...
    v > (
    // ...where current value is re-assigned.
    // Here we define an array using elision
    // and right after that get its value on key that is an integer:
    @@ -30,7 +30,7 @@ function(
    // Using the subtraction check if this value is less than previous
    // (Considering the fact we're parsing string from the tail, this is not the previous but *next* char)
    // If there was no previous value, the whole subtraction gives NaN and comparation gives false
    ) > 0 ?
    ) ?
    // If yes (i.e. IX or CM) we should subtract the current value from the sum
    -v
    :
    2 changes: 1 addition & 1 deletion index.js
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v=[100,500,,,,,1,,,50,1e3,,,,,,,,,5,,10][parseInt(a.charAt(i),36)-12])>0?-v:v);return s}
    function(a){for(var v,s=0,i=a.length;i--;s+=v>(v=[100,500,,,,,1,,,50,1e3,,,,,,,,,5,,10][parseInt(a.charAt(i),36)-12])?-v:v);return s}
    2 changes: 1 addition & 1 deletion test.html
    Original file line number Diff line number Diff line change
    @@ -6,7 +6,7 @@
    // write a small example that shows off the API for your example
    // and tests it in one fell swoop.

    var myFunction = function(a){for(var v,s=0,i=a.length;i--;s+=v-(v=[100,500,,,,,1,,,50,1e3,,,,,,,,,5,,10][parseInt(a.charAt(i),36)-12])>0?-v:v);return s}
    var myFunction = function(a){for(var v,s=0,i=a.length;i--;s+=v>(v=[100,500,,,,,1,,,50,1e3,,,,,,,,,5,,10][parseInt(a.charAt(i),36)-12])?-v:v);return s}

    document.getElementById( "ret" ).innerHTML = [myFunction("mcmlxxxvi"), myFunction("MIM"), myFunction("foobarbaz")]
    </script>
  2. subzey revised this gist Jun 24, 2011. 3 changed files with 5 additions and 5 deletions.
    6 changes: 3 additions & 3 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -18,12 +18,12 @@ function(
    // stored value minus following expression...
    v - (
    // ...where current value is re-assigned.
    // Here we define an object (ExpressionStatement don't starts with `{` so this is valid syntax)
    // Here we define an array using elision
    // and right after that get its value on key that is an integer:
    v = {6:1, 19:5, 21:10, 9:50, 0:100, 1:500, 10:1e3}[
    v = [100,500,,,,,1,,,50,1e3,,,,,,,,,5,,10][
    // Get the char at the `i` offset and treat it as it was an integer in 36-based notation.
    // The good thing: we don't need to use lo-ong toUpperCase :)
    // And then decrease it by 12. This makes the object declaration slightly shorter
    // And then decrease it by 12. This makes the array declaration slightly shorter
    parseInt(a.charAt(i), 36) - 12
    ]
    // Here we get a positive value if char was one of: "IVXLCDMivxlcdm" and undefined else
    2 changes: 1 addition & 1 deletion index.js
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v={6:1,19:5,21:10,9:50,0:100,1:500,10:1e3}[parseInt(a.charAt(i),36)-12])>0?-v:v);return s}
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v=[100,500,,,,,1,,,50,1e3,,,,,,,,,5,,10][parseInt(a.charAt(i),36)-12])>0?-v:v);return s}
    2 changes: 1 addition & 1 deletion test.html
    Original file line number Diff line number Diff line change
    @@ -6,7 +6,7 @@
    // write a small example that shows off the API for your example
    // and tests it in one fell swoop.

    var myFunction = function(a){for(var v,s=0,i=a.length;i--;s+=v-(v={6:1,19:5,21:10,9:50,0:100,1:500,10:1e3}[parseInt(a.charAt(i),36)-12])>0?-v:v);return s}
    var myFunction = function(a){for(var v,s=0,i=a.length;i--;s+=v-(v=[100,500,,,,,1,,,50,1e3,,,,,,,,,5,,10][parseInt(a.charAt(i),36)-12])>0?-v:v);return s}

    document.getElementById( "ret" ).innerHTML = [myFunction("mcmlxxxvi"), myFunction("MIM"), myFunction("foobarbaz")]
    </script>
  3. subzey revised this gist Jun 22, 2011. 2 changed files with 7 additions and 10 deletions.
    15 changes: 6 additions & 9 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -18,18 +18,15 @@ function(
    // stored value minus following expression...
    v - (
    // ...where current value is re-assigned.
    // Here we define an array
    // Here we define an object (ExpressionStatement don't starts with `{` so this is valid syntax)
    // and right after that get its value on key that is an integer:
    v = [5,1,10,,50,1e3,,,,100,500][
    // Get the char at the `i` offset and treat it as it was and integer in 36-based notation.
    v = {6:1, 19:5, 21:10, 9:50, 0:100, 1:500, 10:1e3}[
    // Get the char at the `i` offset and treat it as it was an integer in 36-based notation.
    // The good thing: we don't need to use lo-ong toUpperCase :)
    // And then decrease it by 3. This makes the array declaration slightly shorter and avoids strange IE behavior
    parseInt(a.charAt(i),36) % 14 - 3

    // Thanks to @atk for pointing me to use % instead of &

    // And then decrease it by 12. This makes the object declaration slightly shorter
    parseInt(a.charAt(i), 36) - 12
    ]
    // Here we get a positive value if char was one of: "IVXLCDMivxlcdm" and NaN else
    // Here we get a positive value if char was one of: "IVXLCDMivxlcdm" and undefined else
    // Using the subtraction check if this value is less than previous
    // (Considering the fact we're parsing string from the tail, this is not the previous but *next* char)
    // If there was no previous value, the whole subtraction gives NaN and comparation gives false
    2 changes: 1 addition & 1 deletion index.js
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v=[5,1,10,,50,1e3,,,,100,500][parseInt(a.charAt(i),36)%14-3])>0?-v:v);return s}
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v={6:1,19:5,21:10,9:50,0:100,1:500,10:1e3}[parseInt(a.charAt(i),36)-12])>0?-v:v);return s}
  4. subzey revised this gist Jun 22, 2011. 2 changed files with 10 additions and 7 deletions.
    15 changes: 9 additions & 6 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -18,15 +18,18 @@ function(
    // stored value minus following expression...
    v - (
    // ...where current value is re-assigned.
    // Here we define an object (ExpressionStatement don't starts with `{` so this is valid syntax)
    // Here we define an array
    // and right after that get its value on key that is an integer:
    v = {6:1, 19:5, 21:10, 9:50, 0:100, 1:500, 10:1e3}[
    // Get the char at the `i` offset and treat it as it was an integer in 36-based notation.
    v = [5,1,10,,50,1e3,,,,100,500][
    // Get the char at the `i` offset and treat it as it was and integer in 36-based notation.
    // The good thing: we don't need to use lo-ong toUpperCase :)
    // And then decrease it by 12. This makes the object declaration slightly shorter
    parseInt(a.charAt(i), 36) - 12
    // And then decrease it by 3. This makes the array declaration slightly shorter and avoids strange IE behavior
    parseInt(a.charAt(i),36) % 14 - 3

    // Thanks to @atk for pointing me to use % instead of &

    ]
    // Here we get a positive value if char was one of: "IVXLCDMivxlcdm" and undefined else
    // Here we get a positive value if char was one of: "IVXLCDMivxlcdm" and NaN else
    // Using the subtraction check if this value is less than previous
    // (Considering the fact we're parsing string from the tail, this is not the previous but *next* char)
    // If there was no previous value, the whole subtraction gives NaN and comparation gives false
    2 changes: 1 addition & 1 deletion index.js
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v={6:1,19:5,21:10,9:50,0:100,1:500,10:1e3}[parseInt(a.charAt(i),36)-12])>0?-v:v);return s}
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v=[5,1,10,,50,1e3,,,,100,500][parseInt(a.charAt(i),36)%14-3])>0?-v:v);return s}
  5. subzey revised this gist Jun 22, 2011. 1 changed file with 9 additions and 0 deletions.
    9 changes: 9 additions & 0 deletions x-alternative.js
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,9 @@
    /*
    Alternative version
    ---
    Use this only when string consists *only* from chars:
    I, V, X, L, C, D, M,
    i, v, x, l, c, d, m
    Anything other will return complete trash
    */
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v=[1e3,,5,1,10,100,500,50][1.1*parseInt(a.charAt(i),36)&7])>0?-v:v);return s}
  6. subzey revised this gist Jun 22, 2011. 1 changed file with 2 additions and 2 deletions.
    4 changes: 2 additions & 2 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -21,12 +21,12 @@ function(
    // Here we define an object (ExpressionStatement don't starts with `{` so this is valid syntax)
    // and right after that get its value on key that is an integer:
    v = {6:1, 19:5, 21:10, 9:50, 0:100, 1:500, 10:1e3}[
    // Get the char at the `i` offset and treat it as it was and integer in 36-based notation.
    // Get the char at the `i` offset and treat it as it was an integer in 36-based notation.
    // The good thing: we don't need to use lo-ong toUpperCase :)
    // And then decrease it by 12. This makes the object declaration slightly shorter
    parseInt(a.charAt(i), 36) - 12
    ]
    // Here we get a positive value if char was one of: "IVXLCDMivxlcdm" and NaN else
    // Here we get a positive value if char was one of: "IVXLCDMivxlcdm" and undefined else
    // Using the subtraction check if this value is less than previous
    // (Considering the fact we're parsing string from the tail, this is not the previous but *next* char)
    // If there was no previous value, the whole subtraction gives NaN and comparation gives false
  7. subzey revised this gist Jun 22, 2011. 6 changed files with 62 additions and 50 deletions.
    2 changes: 1 addition & 1 deletion LICENSE.txt
    Original file line number Diff line number Diff line change
    @@ -1,7 +1,7 @@
    DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
    Version 2, December 2004

    Copyright (C) 2011 YOUR_NAME_HERE <YOUR_URL_HERE>
    Copyright (C) 2011 subzey <[email protected]>

    Everyone is permitted to copy and distribute verbatim or modified
    copies of this license document, and changing it is allowed as long
    34 changes: 6 additions & 28 deletions README.md
    Original file line number Diff line number Diff line change
    @@ -1,32 +1,10 @@
    140byt.es
    =========
    parseRoman
    ==========

    A tweet-sized, fork-to-play, community-curated collection of JavaScript.
    Parses string with roman numerals.

    How to play
    -----------

    1. Click the ![Fork](https://d3nwyuy0nl342s.cloudfront.net/images/gist/buttons/fork_button.png) button above to fork this gist.
    2. Modify all the files to according to the rules below.
    3. Save your entry and tweet it up!

    Keep in mind that thanks to the awesome sensibilities of the GitHub team, gists are just repos. So feel free to clone yours and work locally for a more comfortable environment, and to allow commit messages.

    Rules
    Usage
    -----
    All entries must exist in an `index.js` file, whose contents are

    1. an assignable, valid Javascript expression that
    2. contains no more than 140 bytes, and
    3. does not leak to the global scope.

    All entries must also be licensed under the [WTFPL](http://sam.zoy.org/wtfpl/) or equally permissive license.

    For more information
    --------------------

    The [140byt.es](http://140byt.es) site hasn't launched yet, but for now follow [@140bytes](http://twitter.com/140bytes) on Twitter.

    To learn about byte-saving hacks for your own code, or to contribute what you've learned, head to [the wiki](https://github.com/jed/140bytes/wiki/Byte-saving-techniques).
    Pass the string in any case as argument.
    This version parses and “non-well-formed” roman numerals (like `IIIII` or `MIM`) as well.

    140byt.es is brought to you by [Jed Schmidt](http://jed.is). It was inspired by work from [Thomas Fuchs](http://mir.aculo.us) and [Dustin Diaz](http://www.dustindiaz.com/).
    54 changes: 45 additions & 9 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -1,10 +1,46 @@
    function(){
    // make sure
    // to annotate
    // your code
    // so everyone
    // can learn
    // from it!
    // see jed's entries
    // for examples.
    function(
    a // string
    /* I just like when function's length property return something meaningful */
    ){
    // Processing each char of `a` starting from the end of string:
    for(
    // Define the variables:
    // v - value. To be assigned later
    // s - sum
    // i - iterator, length of the arg
    var v, s = 0, i = a.length
    ;
    // decrease iterator with post-decrement
    i--
    ;
    // add the following to sum:
    s +=
    // stored value minus following expression...
    v - (
    // ...where current value is re-assigned.
    // Here we define an object (ExpressionStatement don't starts with `{` so this is valid syntax)
    // and right after that get its value on key that is an integer:
    v = {6:1, 19:5, 21:10, 9:50, 0:100, 1:500, 10:1e3}[
    // Get the char at the `i` offset and treat it as it was and integer in 36-based notation.
    // The good thing: we don't need to use lo-ong toUpperCase :)
    // And then decrease it by 12. This makes the object declaration slightly shorter
    parseInt(a.charAt(i), 36) - 12
    ]
    // Here we get a positive value if char was one of: "IVXLCDMivxlcdm" and NaN else
    // Using the subtraction check if this value is less than previous
    // (Considering the fact we're parsing string from the tail, this is not the previous but *next* char)
    // If there was no previous value, the whole subtraction gives NaN and comparation gives false
    ) > 0 ?
    // If yes (i.e. IX or CM) we should subtract the current value from the sum
    -v
    :
    // If no (i.e. XX or L{end-of-string}) we should add the current value to the sum
    // If `v` is a NaN here, the sum will be NaN either. Garbage In Garbage Out, hehe.
    // Uncomment ~~ if you don't like this behavior, there's still bytes left.
    /* ~~ */ v
    )
    /* empty loop body */
    ;
    // return the sum
    return s
    }
    2 changes: 1 addition & 1 deletion index.js
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    function(){/* Your entry, a useful, unique, and valid JavaScript expression that packs as much functionality into 140 bytes as possible. */}
    function(a){for(var v,s=0,i=a.length;i--;s+=v-(v={6:1,19:5,21:10,9:50,0:100,1:500,10:1e3}[parseInt(a.charAt(i),36)-12])>0?-v:v);return s}
    12 changes: 5 additions & 7 deletions package.json
    Original file line number Diff line number Diff line change
    @@ -1,13 +1,11 @@
    {
    "name": "theNameOfYourLibWhichMustBeAValidCamelCasedJavaScriptIdentifier",
    "name": "parseRoman",

    "description": "This should be a short description of your entry.",
    "description": "Parses roman numerals",

    "keywords": [
    "five",
    "descriptive",
    "keywords",
    "or",
    "fewer"
    "roman",
    "numeral",
    "parse"
    ]
    }
    8 changes: 4 additions & 4 deletions test.html
    Original file line number Diff line number Diff line change
    @@ -1,12 +1,12 @@
    <!DOCTYPE html>
    <title>Foo</title>
    <div>Expected value: <b>undefined</b></div>
    <title>parseRoman</title>
    <div>Expected value: <b>1986,1999,NaN</b></div>
    <div>Actual value: <b id="ret"></b></div>
    <script>
    // write a small example that shows off the API for your example
    // and tests it in one fell swoop.

    var myFunction = function(){ /* the code here should be identical to the entry. */ }
    var myFunction = function(a){for(var v,s=0,i=a.length;i--;s+=v-(v={6:1,19:5,21:10,9:50,0:100,1:500,10:1e3}[parseInt(a.charAt(i),36)-12])>0?-v:v);return s}

    document.getElementById( "ret" ).innerHTML = myFunction()
    document.getElementById( "ret" ).innerHTML = [myFunction("mcmlxxxvi"), myFunction("MIM"), myFunction("foobarbaz")]
    </script>
  8. @140bytes 140bytes revised this gist Jun 1, 2011. 1 changed file with 5 additions and 7 deletions.
    12 changes: 5 additions & 7 deletions test.html
    Original file line number Diff line number Diff line change
    @@ -1,14 +1,12 @@
    <!DOCTYPE html>
    <body>
    <div>Expected value: <b>undefined</b></div>
    <div>Actual value: <b id="ret"></b></div>
    </body>
    <!DOCTYPE html>
    <title>Foo</title>
    <div>Expected value: <b>undefined</b></div>
    <div>Actual value: <b id="ret"></b></div>
    <script>
    // write a small example that shows off the API for your example
    // and tests it in one fell swoop.

    var myFunction = function(){ /* the code here should be identical to the entry. */ }
    var ret = myFunction()

    document.getElementById( "ret" ).innerHTML = ret
    document.getElementById( "ret" ).innerHTML = myFunction()
    </script>
  9. @140bytes 140bytes revised this gist Jun 1, 2011. 1 changed file with 1 addition and 0 deletions.
    1 change: 1 addition & 0 deletions test.html
    Original file line number Diff line number Diff line change
    @@ -1,3 +1,4 @@
    <!DOCTYPE html>
    <body>
    <div>Expected value: <b>undefined</b></div>
    <div>Actual value: <b id="ret"></b></div>
  10. @140bytes 140bytes revised this gist May 31, 2011. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion test.html
    Original file line number Diff line number Diff line change
    @@ -9,5 +9,5 @@
    var myFunction = function(){ /* the code here should be identical to the entry. */ }
    var ret = myFunction()

    document.getElementById( "ret" ) = ret
    document.getElementById( "ret" ).innerHTML = ret
    </script>
  11. @140bytes 140bytes revised this gist May 31, 2011. 1 changed file with 13 additions and 0 deletions.
    13 changes: 13 additions & 0 deletions test.html
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,13 @@
    <body>
    <div>Expected value: <b>undefined</b></div>
    <div>Actual value: <b id="ret"></b></div>
    </body>
    <script>
    // write a small example that shows off the API for your example
    // and tests it in one fell swoop.

    var myFunction = function(){ /* the code here should be identical to the entry. */ }
    var ret = myFunction()

    document.getElementById( "ret" ) = ret
    </script>
  12. @140bytes 140bytes revised this gist May 31, 2011. 3 changed files with 17 additions and 19 deletions.
    17 changes: 9 additions & 8 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -1,9 +1,10 @@
    function(){
    /* Rules:
    (1) anonymous function or IIFE // make sure
    (2) may execute immediately // to annotate
    (3) <=140 bytes // your code
    (4) no globals // so everyone
    (5) permissive license // can learn
    (6) have a good time! // from it!
    */}
    // make sure
    // to annotate
    // your code
    // so everyone
    // can learn
    // from it!
    // see jed's entries
    // for examples.
    }
    2 changes: 1 addition & 1 deletion index.js
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    function(){/******************************************************************************************************************************/}
    function(){/* Your entry, a useful, unique, and valid JavaScript expression that packs as much functionality into 140 bytes as possible. */}
    17 changes: 7 additions & 10 deletions package.json
    Original file line number Diff line number Diff line change
    @@ -1,16 +1,13 @@
    {
    // [REQUIRED] A name for your library.
    // This must match /^[a-z_]\w*$/i
    "name": "140bytes",
    "name": "theNameOfYourLibWhichMustBeAValidCamelCasedJavaScriptIdentifier",

    // [OPTIONAL] A description of your library, phrased as a verb predicate.
    // The gist description is used by default.
    "description": "Explain the 140byt.es rules.",
    "description": "This should be a short description of your entry.",

    // [OPTIONAL] Up to 5 keywords used for indexing.
    "keywords": [
    "140bytes",
    "master",
    "rules"
    "five",
    "descriptive",
    "keywords",
    "or",
    "fewer"
    ]
    }
  13. @140bytes 140bytes revised this gist May 26, 2011. 1 changed file with 6 additions and 6 deletions.
    12 changes: 6 additions & 6 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -1,9 +1,9 @@
    function(){
    /* Rules:
    (1) anonymous function // make sure
    (2) may execute immediately // to annotate
    (3) <=140 bytes // your code
    (4) no globals // so everyone
    (5) permissive license // can learn
    (6) have a good time! // from it!
    (1) anonymous function or IIFE // make sure
    (2) may execute immediately // to annotate
    (3) <=140 bytes // your code
    (4) no globals // so everyone
    (5) permissive license // can learn
    (6) have a good time! // from it!
    */}
  14. @140bytes 140bytes revised this gist May 25, 2011. 3 changed files with 8 additions and 8 deletions.
    2 changes: 1 addition & 1 deletion README.md
    Original file line number Diff line number Diff line change
    @@ -16,7 +16,7 @@ Rules
    -----
    All entries must exist in an `index.js` file, whose contents are

    1. an assignable, valid Javascript expression, that
    1. an assignable, valid Javascript expression that
    2. contains no more than 140 bytes, and
    3. does not leak to the global scope.

    12 changes: 6 additions & 6 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -1,9 +1,9 @@
    function(){
    /* Rules:
    (1) anonymous function // make sure
    (2) may be self-executing // to annotate
    (3) <=140 bytes // your code
    (4) no globals // so everyone
    (5) MIT license // can learn
    (6) have a good time! // from it!
    (1) anonymous function // make sure
    (2) may execute immediately // to annotate
    (3) <=140 bytes // your code
    (4) no globals // so everyone
    (5) permissive license // can learn
    (6) have a good time! // from it!
    */}
    2 changes: 1 addition & 1 deletion index.js
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    function(){/*Rules: (1) anonymous function (2) may be self-executing (3) <=140 bytes (4) no globals (5) MIT license (6) have a good time!*/}
    function(){/******************************************************************************************************************************/}
  15. @140bytes 140bytes revised this gist May 23, 2011. 2 changed files with 14 additions and 21 deletions.
    33 changes: 13 additions & 20 deletions LICENSE.txt
    Original file line number Diff line number Diff line change
    @@ -1,20 +1,13 @@
    Copyright (c) 2011 YOUR_NAME_HERE, YOUR_URL_HERE

    Permission is hereby granted, free of charge, to any person obtaining
    a copy of this software and associated documentation files (the
    "Software"), to deal in the Software without restriction, including
    without limitation the rights to use, copy, modify, merge, publish,
    distribute, sublicense, and/or sell copies of the Software, and to
    permit persons to whom the Software is furnished to do so, subject to
    the following conditions:

    The above copyright notice and this permission notice shall be
    included in all copies or substantial portions of the Software.

    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
    EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
    NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
    LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
    OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
    WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
    DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
    Version 2, December 2004

    Copyright (C) 2011 YOUR_NAME_HERE <YOUR_URL_HERE>

    Everyone is permitted to copy and distribute verbatim or modified
    copies of this license document, and changing it is allowed as long
    as the name is changed.

    DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION

    0. You just DO WHAT THE FUCK YOU WANT TO.
    2 changes: 1 addition & 1 deletion README.md
    Original file line number Diff line number Diff line change
    @@ -20,7 +20,7 @@ All entries must exist in an `index.js` file, whose contents are
    2. contains no more than 140 bytes, and
    3. does not leak to the global scope.

    All entries must also be licensed under a license as or more permitting than the MIT license.
    All entries must also be licensed under the [WTFPL](http://sam.zoy.org/wtfpl/) or equally permissive license.

    For more information
    --------------------
  16. @140bytes 140bytes revised this gist May 23, 2011. 1 changed file with 3 additions and 4 deletions.
    7 changes: 3 additions & 4 deletions README.md
    Original file line number Diff line number Diff line change
    @@ -16,12 +16,11 @@ Rules
    -----
    All entries must exist in an `index.js` file, whose contents are

    1. a valid Javascript function expression, that
    2. optionally self-executes,
    1. an assignable, valid Javascript expression, that
    2. contains no more than 140 bytes, and
    3. does not pollute global scope.
    3. does not leak to the global scope.

    All entries must also be licensed under the MIT license.
    All entries must also be licensed under a license as or more permitting than the MIT license.

    For more information
    --------------------
  17. @140bytes 140bytes revised this gist May 22, 2011. 1 changed file with 2 additions and 0 deletions.
    2 changes: 2 additions & 0 deletions README.md
    Original file line number Diff line number Diff line change
    @@ -10,6 +10,8 @@ How to play
    2. Modify all the files to according to the rules below.
    3. Save your entry and tweet it up!

    Keep in mind that thanks to the awesome sensibilities of the GitHub team, gists are just repos. So feel free to clone yours and work locally for a more comfortable environment, and to allow commit messages.

    Rules
    -----
    All entries must exist in an `index.js` file, whose contents are
  18. @140bytes 140bytes revised this gist May 21, 2011. 1 changed file with 2 additions and 0 deletions.
    2 changes: 2 additions & 0 deletions README.md
    Original file line number Diff line number Diff line change
    @@ -26,4 +26,6 @@ For more information

    The [140byt.es](http://140byt.es) site hasn't launched yet, but for now follow [@140bytes](http://twitter.com/140bytes) on Twitter.

    To learn about byte-saving hacks for your own code, or to contribute what you've learned, head to [the wiki](https://github.com/jed/140bytes/wiki/Byte-saving-techniques).

    140byt.es is brought to you by [Jed Schmidt](http://jed.is). It was inspired by work from [Thomas Fuchs](http://mir.aculo.us) and [Dustin Diaz](http://www.dustindiaz.com/).
  19. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion package.json
    Original file line number Diff line number Diff line change
    @@ -5,7 +5,7 @@

    // [OPTIONAL] A description of your library, phrased as a verb predicate.
    // The gist description is used by default.
    "description": "Explain the 140byt.es rules."
    "description": "Explain the 140byt.es rules.",

    // [OPTIONAL] Up to 5 keywords used for indexing.
    "keywords": [
  20. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 13 additions and 1 deletion.
    14 changes: 13 additions & 1 deletion package.json
    Original file line number Diff line number Diff line change
    @@ -1,4 +1,16 @@
    {
    // [REQUIRED] A name for your library.
    // This must match /^[a-z_]\w*$/i
    "name": "140bytes",
    "keywords": [ "140bytes", "master", "rules" ]

    // [OPTIONAL] A description of your library, phrased as a verb predicate.
    // The gist description is used by default.
    "description": "Explain the 140byt.es rules."

    // [OPTIONAL] Up to 5 keywords used for indexing.
    "keywords": [
    "140bytes",
    "master",
    "rules"
    ]
    }
  21. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 3 additions and 1 deletion.
    4 changes: 3 additions & 1 deletion README.md
    Original file line number Diff line number Diff line change
    @@ -24,4 +24,6 @@ All entries must also be licensed under the MIT license.
    For more information
    --------------------

    The [140byt.es](http://140byt.es) site hasn't launched yet, but for now follow [@140bytes](http://twitter.com/140bytes) on Twitter.
    The [140byt.es](http://140byt.es) site hasn't launched yet, but for now follow [@140bytes](http://twitter.com/140bytes) on Twitter.

    140byt.es is brought to you by [Jed Schmidt](http://jed.is). It was inspired by work from [Thomas Fuchs](http://mir.aculo.us) and [Dustin Diaz](http://www.dustindiaz.com/).
  22. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 2 additions and 2 deletions.
    4 changes: 2 additions & 2 deletions README.md
    Original file line number Diff line number Diff line change
    @@ -14,8 +14,8 @@ Rules
    -----
    All entries must exist in an `index.js` file, whose contents are

    1. a valid Javascript function expression, that is
    2. is optionally self-executing,
    1. a valid Javascript function expression, that
    2. optionally self-executes,
    2. contains no more than 140 bytes, and
    3. does not pollute global scope.

  23. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 12 additions and 1 deletion.
    13 changes: 12 additions & 1 deletion README.md
    Original file line number Diff line number Diff line change
    @@ -7,9 +7,20 @@ How to play
    -----------

    1. Click the ![Fork](https://d3nwyuy0nl342s.cloudfront.net/images/gist/buttons/fork_button.png) button above to fork this gist.
    2. Modify all the files to according to the rules and style guide below.
    2. Modify all the files to according to the rules below.
    3. Save your entry and tweet it up!

    Rules
    -----
    All entries must exist in an `index.js` file, whose contents are

    1. a valid Javascript function expression, that is
    2. is optionally self-executing,
    2. contains no more than 140 bytes, and
    3. does not pollute global scope.

    All entries must also be licensed under the MIT license.

    For more information
    --------------------

  24. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 3 additions and 2 deletions.
    5 changes: 3 additions & 2 deletions README.md
    Original file line number Diff line number Diff line change
    @@ -1,7 +1,7 @@
    140byt.es
    =========

    All the Codes that Fits in Tweet
    A tweet-sized, fork-to-play, community-curated collection of JavaScript.

    How to play
    -----------
    @@ -12,4 +12,5 @@ How to play

    For more information
    --------------------
    The 140byt.es site launched yet, but for now follow [@140bytes](http://twitter.com/140bytes) on Twitter, and keep you eye on http://140byt.es.

    The [140byt.es](http://140byt.es) site hasn't launched yet, but for now follow [@140bytes](http://twitter.com/140bytes) on Twitter.
  25. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 14 additions and 1 deletion.
    15 changes: 14 additions & 1 deletion README.md
    Original file line number Diff line number Diff line change
    @@ -1,2 +1,15 @@
    140byt.es
    =========
    =========

    All the Codes that Fits in Tweet

    How to play
    -----------

    1. Click the ![Fork](https://d3nwyuy0nl342s.cloudfront.net/images/gist/buttons/fork_button.png) button above to fork this gist.
    2. Modify all the files to according to the rules and style guide below.
    3. Save your entry and tweet it up!

    For more information
    --------------------
    The 140byt.es site launched yet, but for now follow [@140bytes](http://twitter.com/140bytes) on Twitter, and keep you eye on http://140byt.es.
  26. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 2 additions and 0 deletions.
    2 changes: 2 additions & 0 deletions README.md
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,2 @@
    140byt.es
    =========
  27. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 2 additions and 2 deletions.
    4 changes: 2 additions & 2 deletions package.json
    Original file line number Diff line number Diff line change
    @@ -1,4 +1,4 @@
    {
    "name": "sample",
    "keywords": [ "sample", "original" ]
    "name": "140bytes",
    "keywords": [ "140bytes", "master", "rules" ]
    }
  28. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 7 additions and 7 deletions.
    14 changes: 7 additions & 7 deletions annotated.js
    Original file line number Diff line number Diff line change
    @@ -1,9 +1,9 @@
    function(){
    /* Rules: // make sure
    (1) anonymous function // to annotate
    (2) optionally self-executing // your code
    (3) <140 bytes // so everyone
    (4) no global vars // can learn
    (5) MIT license // from it!
    (6) good luck!
    /* Rules:
    (1) anonymous function // make sure
    (2) may be self-executing // to annotate
    (3) <=140 bytes // your code
    (4) no globals // so everyone
    (5) MIT license // can learn
    (6) have a good time! // from it!
    */}
  29. @140bytes 140bytes revised this gist May 18, 2011. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion index.js
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    function(){/*Rules: (1) anonymous function (2) optionally self-executing (3) <140 bytes (4) no global vars (5) MIT license (6) good luck!*/}
    function(){/*Rules: (1) anonymous function (2) may be self-executing (3) <=140 bytes (4) no globals (5) MIT license (6) have a good time!*/}
  30. @140bytes 140bytes renamed this gist May 18, 2011. 1 changed file with 0 additions and 0 deletions.
    File renamed without changes.