Ruby on Rails | Screencasts | Download | Documentation | Weblog | Community | Source

Ticket #7421: forinloop.diff

File forinloop.diff, 2.6 kB (added by Tobie, 2 years ago)

final patch, ready to be applied (redefines Hash.prototype._each if the bug is present)

  • test/unit/hash.html

    old new  
    104104      assertEqual("color=",                  $H(Fixtures.multiple_all_nil).toQueryString()) 
    105105      assertEqual("color=",                  $H(Fixtures.multiple_empty).toQueryString()) 
    106106       
    107       assertEqual("_each=E&map=M&keys=K&values=V&collect=C&inject=I", Hash.toQueryString(Fixtures.dangerous)) 
     107      assertEnumEqual($w("_each=E map=M keys=K values=V collect=C inject=I").sort(), 
     108        Hash.toQueryString(Fixtures.dangerous).split('&').sort()); 
     109      assertEnumEqual($w('_each=E map=M keys=K values=V collect=C inject=I').sort(), 
     110        $H(Fixtures.dangerous).toQueryString().split('&').sort()); 
    108111    }}, 
    109112     
    110113    testInspect: function(){ with(this) { 
  • src/hash.js

    old new  
    66  toQueryString: function(obj) { 
    77    var parts = []; 
    88     
    9          this.prototype._each.call(obj, function(pair) { 
     9    this.prototype._each.call(obj, function(pair) { 
    1010      if (!pair.key) return; 
    1111       
    1212      if (pair.value && pair.value.constructor == Array) { 
    1313        var values = pair.value.compact(); 
    1414        if (values.length < 2) pair.value = values.reduce(); 
    1515        else { 
    16                key = encodeURIComponent(pair.key); 
     16          key = encodeURIComponent(pair.key); 
    1717          values.each(function(value) { 
    18             value = value != undefined ? encodeURIComponent(value) : ''; 
     18            value = value != undefined ? value : ''; 
    1919            parts.push(key + '=' + encodeURIComponent(value)); 
    2020          }); 
    2121          return; 
     
    2323      } 
    2424      if (pair.value == undefined) pair[1] = ''; 
    2525      parts.push(pair.map(encodeURIComponent).join('=')); 
    26          }); 
     26    }); 
    2727     
    2828    return parts.join('&'); 
    2929  } 
     
    8989  if (object && object.constructor == Hash) return object; 
    9090  return new Hash(object); 
    9191}; 
     92 
     93 
     94if(function() { 
     95  var TestObject = function(value) { 
     96    this.key = value; 
     97  }; 
     98  TestObject.prototype.key = 'foo'; 
     99  var instance = new TestObject('bar'); 
     100  var i = 0; 
     101  for (var property in instance) i++; 
     102  return (i != 1); 
     103}()) Hash.prototype._each = function(iterator) { 
     104  var cache = []; 
     105  for (var key in this) { 
     106    var value = this[key]; 
     107    if ((value && value == Hash.prototype[key]) || cache.include(key)) continue; 
     108    cache.push(key); 
     109    var pair = [key, value]; 
     110    pair.key = key; 
     111    pair.value = value; 
     112    iterator(pair); 
     113  } 
     114};