ref: de6cb0639a50a4449dccee0b3a3469973cdea352
parent: 5cd5d8899f0ca0f3d9c6b56d7feabfa0729df88c
parent: b97ced1225b718d1812fdc7f4a82d292ebec3db3
author: cinap_lenrek <cinap_lenrek@centraldogma>
date: Thu May 12 08:07:40 EDT 2011
merge
--- /dev/null
+++ b/rc/bin/xargs
@@ -1,0 +1,21 @@
+#!/bin/rc
+fn usage {+ echo usage: $0 [-n num] program [arguments]
+ exit usage
+}
+rfork e
+ifs='
+'
+nargs=1
+while(~ $1 -*) {+ switch($1) {+ case -n
+ nargs=$2
+ shift 2
+ case *
+ echo bla
+ usage
+ }
+}
+while(x = `{read -n $nargs})+ $* $x
--- a/sys/lib/python/hgext/hgfactotum.py
+++ b/sys/lib/python/hgext/hgfactotum.py
@@ -8,6 +8,8 @@
class factotumbasic(urllib2.BaseHandler):
def __init__(self, passmgr=None):
self.f = factotum.Factotum()
+ self.retried = 0
+ self.auth = None
def http_error_401(self, req, fp, code, msg, headers):
host = urllib2.urlparse.urlparse(req.get_full_url())[1]
authreq = headers.get('www-authenticate', None)@@ -16,13 +18,23 @@
if authreq[0].lower() != 'basic': return None
chal = urllib2.parse_keqv_list(urllib2.parse_http_list(authreq[1]))
realm = chal['realm']
+ self.auth = (host, realm)
+ self.retried += 1
+ if self.retried >= 3:
+ self.f.delkey(proto="pass", host=host, realm=realm, role="client")
self.f.start(proto="pass", host=host, realm=realm, role="client")
pw = self.f.read().replace(' ', ':', 1)val = 'Basic %s' % base64.b64encode(pw).strip()
if req.headers.get('Authorization', None) == val: return None req.add_header('Authorization', val)- return self.parent.open(req)
-
+ result = self.parent.open(req)
+ self.retried = 0
+ return result
+ def http_error_403(self, req, fp, code, msg, headers):
+ if self.auth != None:
+ self.f.delkey(proto="pass", host=self.auth[0], realm=self.auth[1], role="client")
+ self.auth = None
+
class factotumdigest(urllib2.BaseHandler):
auth_header = 'Authorization'
handler_order = 490
--
⑨