diff options
| author | drry | 2008-04-21 18:37:29 +0000 | 
|---|---|---|
| committer | drry | 2008-04-21 18:37:29 +0000 | 
| commit | 5911f209c13e1ba092fd31d90f8cb823695471c8 (patch) | |
| tree | ae9b0ee7d149d9cfbd426f70ce25dfa9ed7dc606 | |
| parent | c5388b180f7bccf60d0be9fa059a96232f0b677c (diff) | |
| download | vimperator-plugins-5911f209c13e1ba092fd31d90f8cb823695471c8.tar.bz2 | |
lang/javascript/vimperator-plugins/trunk/direct_bookmark.js:
 * WSSE の無効な `zeropad()` を修正しました。
 * 正規表現を修正しました。
 * ほか。
git-svn-id: http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk@10105 d0d07461-0603-4401-acd4-de1884942a52
| -rw-r--r-- | direct_bookmark.js | 46 | 
1 files changed, 22 insertions, 24 deletions
| diff --git a/direct_bookmark.js b/direct_bookmark.js index 4203335..bcb173e 100644 --- a/direct_bookmark.js +++ b/direct_bookmark.js @@ -123,8 +123,8 @@          d.xhr = req;
          return d;
      }
 -    http.get  = function (url)       { return http({method:"get",  url:url}) }
 -    http.post = function (url, data) { return http({method:"post", url:url, data:data, headers:{"Content-Type":"application/x-www-form-urlencoded"}}) }
 +    http.get  = function (url)       http({method:"get",  url:url});
 +    http.post = function (url, data) http({method:"post", url:url, data:data, headers:{"Content-Type":"application/x-www-form-urlencoded"}});
      Deferred.Deferred = Deferred;
      Deferred.http     = http;
 @@ -174,22 +174,23 @@          },
          _getISO8601String: function(aDate){
 +            var result = [
 +                zeropad(aDate.getUTCFullYear(), 4), "-",
 +                zeropad(aDate.getUTCMonth() + 1, 2), "-",
 +                zeropad(aDate.getUTCDate(), 2), "T",
 +                zeropad(aDate.getUTCHours(), 2), ":",
 +                zeropad(aDate.getUTCMinutes(), 2), ":",
 +                zeropad(aDate.getUTCSeconds(), 2), "Z"
 +            ].join("");
 +            return result;
 +
              function zeropad(s, l){
 +                s = String(s);
                  while(s.length < l){
                      s = "0" + s;
                  }
                  return s;
              }
 -
 -            var result = [
 -                            zeropad(aDate.getUTCFullYear(), 4), "-",
 -                            zeropad(aDate.getUTCMonth() + 1, 2), "-",
 -                            zeropad(aDate.getUTCDate(), 2), "T",
 -                            zeropad(aDate.getUTCHours(), 2), ":",
 -                            zeropad(aDate.getUTCMinutes(), 2), ":",
 -                            zeropad(aDate.getUTCSeconds(), 2), "Z"
 -                         ].join("");
 -            return result;
          }
      };
 @@ -466,8 +467,8 @@              [user,password] = currentService.account ? getUserAccount.apply(currentService,currentService.account) : ["", ""];
              d = d.next(function(t) t.concat(currentService.tags(user,password)));
          });
 -        d.next(function(tags){liberator.plugins.direct_bookmark.tags = tags.filter(function(e,i,a) {return a.indexOf(e) == i}).sort()})
 -            .error(function(e){liberator.echoerr("direct_bookmark.js: Exception throwed! " + e)});
 +        d.next(function(tags){liberator.plugins.direct_bookmark.tags = tags.filter(function(e,i,a) a.indexOf(e) == i).sort()})
 +         .error(function(e){liberator.echoerr("direct_bookmark.js: Exception throwed! " + e)});
          return first;
      }
      liberator.commands.addUserCommand(['btags'],"Update Social Bookmark Tags",
 @@ -525,25 +526,22 @@              useServicesByPost.split(/\s*/).forEach(function(service){
                  var user, password, currentService = services[service] || null;
                  [user,password] = currentService.account ? getUserAccount.apply(currentService,currentService.account) : ["", ""];
 -                d = d.next(function(){
 -                    return currentService.poster(
 -                        user,password,
 -                        isNormalize ? getNormalizedPermalink(liberator.buffer.URL) : liberator.buffer.URL,
 -                        comment,
 -                        tags
 -                    );
 -                });
 +                d = d.next(function() currentService.poster(
 +                    user,password,
 +                    isNormalize ? getNormalizedPermalink(liberator.buffer.URL) : liberator.buffer.URL,
 +                    comment,tags
 +                ));
              });
              d.error(function(e){liberator.echoerr("direct_bookmark.js: Exception throwed! " + e);});
              setTimeout(function(){first.call();},0);
          },{
              completer: function(filter){
 -                var match_result = filter.match(/((?:\[[^\]]*\])+)?\[?(.*)/); //[all, commited, now inputting]
 +                var match_result = filter.match(/((?:\[[^\]]*\])*)\[?(.*)/); //[all, commited, now inputting]
                  var m = new RegExp(XMigemoCore && isUseMigemo ? "^(" + XMigemoCore.getRegExp(match_result[2]) + ")" : "^" + match_result[2],'i');
                  var completionList = [];
                  if(liberator.plugins.direct_bookmark.tags.length == 0)
                      getTags().call([]);
 -                return [0, [[(match_result[1] || "") + "[" + tag + "]","Tag"]
 +                return [0, [[match_result[1] + "[" + tag + "]","Tag"]
                              for each (tag in liberator.plugins.direct_bookmark.tags) if (m.test(tag))]];
              }
          }
 | 
