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

Ticket #7421: hash.2.diff

File hash.2.diff, 2.5 kB (added by Tobie, 2 years ago)

and a version with browser sniffing

  • src/hash.js

    old new  
    55Object.extend(Hash, { 
    66  toQueryString: function(obj) { 
    77    var parts = []; 
    8      
    9          this.prototype._each.call(obj, function(pair) { 
     8 
     9    this.prototype._each.call(obj, function(pair) { 
    1010      if (!pair.key) return; 
    11        
     11 
    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          }); 
    27      
     26    }); 
     27 
    2828    return parts.join('&'); 
    2929  } 
    3030}); 
     
    3232Object.extend(Hash.prototype, Enumerable); 
    3333Object.extend(Hash.prototype, { 
    3434  _each: function(iterator) { 
     35    if (navigator.userAgent.include(' AppleWebKit/') 
     36      && parseInt(navigator.userAgent.match(/ AppleWebKit\/(\d+)/)[1]) < 420) 
     37        var cache = []; 
    3538    for (var key in this) { 
    3639      var value = this[key]; 
    3740      if (value && value == Hash.prototype[key]) continue; 
    38        
     41      if (cache) { 
     42        if(cache.include(key)) continue; 
     43        cache.push(key); 
     44      } 
    3945      var pair = [key, value]; 
    4046      pair.key = key; 
    4147      pair.value = value; 
  • 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) {