가장 작은 p2p 코드..
글쓴이: siabard / 작성시간: 수, 2005/01/12 - 2:22오후
Edward Felten 이라는 프린스턴 대학의 컴퓨터 과학 교수가 쓴 15줄짜리 파이썬 P2P프로그램입니다.
당나귀나 소리바다같은 엄청난 기능은 무리겠지만 소규모의 P2P 시스템 운영은 가능하다고 하는군요.
목적이 P2P프로그램이 얼마나 작아질 수 있는지와, 어느 정도 소양을 갖춘 프로그래머라면 제작이 가능하다는 것을 보여주려고 했다고 합니다.
예전에 동영상 관련 디코드 루틴-펄로 작성했던가요?-에 이어서 대단한 능력들입니다. 가만히 보면 Lamda의 압박이 꽤 되는군요.
테스트해보고는 싶지만 지금 회사에 파이썬이 없어서 그냥 눈팅만 잔뜩하고 있다는..
출처는 Computer Active 입니다.
# tinyp2p.py 1.0 (documentation at http://freedom-to-tinker.com/tinyp2p.html) import sys, os, SimpleXMLRPCServer, xmlrpclib, re, hmac # (C) 2004, E.W. Felten ar,pw,res = (sys.argv,lambda u:hmac.new(sys.argv[1],u).hexdigest(),re.search) pxy,xs = (xmlrpclib.ServerProxy,SimpleXMLRPCServer.SimpleXMLRPCServer) def ls(p=""):return filter(lambda n:(p=="")or res(p,n),os.listdir(os.getcwd())) if ar[2]!="client": # license: http://creativecommons.org/licenses/by-nc-sa/2.0 myU,prs,srv = ("http://"+ar[3]+":"+ar[4], ar[5:],lambda x:x.serve_forever()) def pr(x=[]): return ([(y in prs) or prs.append(y) for y in x] or 1) and prs def c(n): return ((lambda f: (f.read(), f.close()))(file(n)))[0] f=lambda p,n,a:(p==pw(myU))and(((n==0)and pr(a))or((n==1)and [ls(a)])or c(a)) def aug(u): return ((u==myU) and pr()) or pr(pxy(u).f(pw(u),0,pr([myU]))) pr() and [aug(s) for s in aug(pr()[0])] (lambda sv:sv.register_function(f,"f") or srv(sv))(xs((ar[3],int(ar[4])))) for url in pxy(ar[3]).f(pw(ar[3]),0,[]): for fn in filter(lambda n:not n in ls(), (pxy(url).f(pw(url),1,ar[4]))[0]): (lambda fi:fi.write(pxy(url).f(pw(url),2,fn)) or fi.close())(file(fn,"wc"))
Forums:
http://bbs.kldp.org/viewtopic.php?t=4905
http://bbs.kldp.org/viewtopic.php?t=49056
----------------------------
May the F/OSS be with you..
중복입니다.
http://bbs.kldp.org/viewtopic.php?t=49056&highlight=tinyp2p
전 슬레쉬 닷에서 제일 먼저 봤었는데.....
지금은 펄과 루비도 나와서 성전이 형성되고 있다고 들었습니다.
제가 이겼어요 >_<*
제가 이겼어요 >_<*
----------------------------
May the F/OSS be with you..
저버렸네요 흑 :cry:
저버렸네요 흑 :cry: