posted on Wednesday, December 07, 2005 5:17 PM by anoras

Dynamic Methods and Humane Interfaces

One of the key differences between C-style languages such as C# or Java and Ruby is how libraries are designed. The Ruby crowd has coined the term “Humane Interface” describing their style of defining class interfaces. A good example is Ruby’s List type which exposes a whooping 78 instance methods, while .NET’s ArrayList class has less than twenty if you leave out the overloads. The generic List<> in .NET 2.0 has some more, but still the methods are all low-level. A good example of syntactic sugar in Ruby’s List is the flatten method which flattens a multi-dimensional array.

[1,2,[3,4,[5,6],7],8].flatten => [1, 2, 3, 4, 5, 6, 7, 8]

When I teach developers about refactoring, I often use an example I’ve borrowed from Joshua Kerievsky’s Refactoring to Patterns book to show how code can be more readable or more humane if you like; November(20, 2004) where November is a public static method accepting the day of month and the year as its arguments. The November method communicates its behavior better compared to new DateTime(2004, 11, 20) which requires you to have knowledge of the System.DateTime constructor.

Examples like the one above might seem a bit over the top, but successful Ruby frameworks such as Ruby on Rails have similar methods that have been essential to the libraries success. For instance; Ruby on Rails has a pluralize method which gets the plural form of most English nouns. Why would you need such a method? The answer lies in Ruby on Rails convention over configuration philosophy, where instances of a User class are expected to be persisted in a Users table in the database. The pluralize method makes this convention easy to apply.

John Lam has been doing some really interesting experiments with programming Ruby with the CLR, and his latest project is a great example of how Ruby’s humane interface philosophy makes Reflection.Emit, which is one of the least approachable namespaces within the .NET framework, much easier to use.

    create_ruby_method('say_hello') do
ldstr 'Hello, World'
call 'static System.Console.WriteLine(System.String)'
ldc_i4_4
ret
end

Above is an example of how to use his RbDynamicMethod library to create a CLR DynamicMethod from Ruby. Although MSIL still is cryptic to most, being able to write “MSIL code” within the source code is much easier than using OpCodes to emit MSIL code. Below is the same example using the .NET 2.0 Lightweight Code Generation (LCG).

    public class DynamicMethodExample
{
public static void Main(string[] args)
{
DynamicMethod method = new DynamicMethod("SayHello",
typeof(void), new Type[] {}, typeof(DynamicMethodExample), false);
ILGenerator gen = method.GetILGenerator();
gen.Emit(OpCodes.Ldstr, "Hello, World!");
gen.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine",
new Type[] { typeof(string) }));
gen.Emit(OpCodes.Ret);
}
}

The lightweight in LCG has its place. In .NET 1.x you could emit the Hello World part of the above example in three lines of code, but you would typically need approximately 10 more lines of code to setup the classes needed to do this. The LCG is a huge improvement, but I still find John’s MSIL code more appealing than using reflection to get hold of MethodInfo’s and similar.

Another example of how class interfaces can be more humane is .NET’s EventLog class which throws an ArgumentException with information on how to resolve the error when the class is used without being properly configured. Such a message gives developers instant clues on what might be wrong, and can save them hours of mucking about with the debugger.

The syntactic sugar added to C# 3.0 and Visual Basic 9 in particular make the languages more expressive, and the LINQ framework provides a great abstractions allowing developers to do complex operation in just one or two lines of code. These new additions to the .NET development environment make the general developing experience more humane. Humane interfaces are a trend that reaches way beyond the small Ruby community, and you should always look for options to make your class interface more humane. Even if your core classes might require more maintenance over time, the client code will be easier to maintain since the code base will be much smaller, more expressive and readable.

Comments

# verizon ringtones @ Sunday, May 20, 2007 10:10 PM

http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm">http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm verizon ringtones verizon ringtones verizon ringtones http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm">http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm verizon ringtones verizon ringtones

verizon ringtones

# verizon ringtones @ Sunday, May 20, 2007 10:10 PM

http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm">http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm verizon ringtones verizon ringtones verizon ringtones http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm">http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm verizon ringtones verizon ringtones

verizon ringtones

# verizon ringtones @ Sunday, May 20, 2007 10:11 PM

http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm">http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm verizon ringtones verizon ringtones verizon ringtones http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm">http://boole.cs.iastate.edu/semanticweb/attachment.cgi?forum=49&topic=25&postno=13&type=.htm verizon ringtones verizon ringtones

verizon ringtones

# cheap ambien @ Sunday, May 20, 2007 10:11 PM

http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 cheap ambien ambien buy ambien http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 buy ambien cheap ambien

cheap ambien

# cheap ambien @ Sunday, May 20, 2007 10:12 PM

http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 cheap ambien ambien buy ambien http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 buy ambien cheap ambien

cheap ambien

# cheap ambien @ Sunday, May 20, 2007 10:12 PM

http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 cheap ambien ambien buy ambien http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 buy ambien cheap ambien

cheap ambien

# cheap ambien @ Sunday, May 20, 2007 10:12 PM

http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 cheap ambien ambien buy ambien http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 buy ambien cheap ambien

cheap ambien

# cheap ambien @ Sunday, May 20, 2007 10:12 PM

http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 cheap ambien ambien buy ambien http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 buy ambien cheap ambien

cheap ambien

# cheap ambien @ Sunday, May 20, 2007 10:13 PM

http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 cheap ambien ambien buy ambien http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 buy ambien cheap ambien

cheap ambien

# cheap ambien @ Sunday, May 20, 2007 10:13 PM

http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 cheap ambien ambien buy ambien http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115">http://ecomm1.csug.rochester.edu/~arms/lore/forum/profile.php?p=115 buy ambien cheap ambien

cheap ambien

# clonazepam online @ Sunday, May 20, 2007 10:13 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# clonazepam online @ Sunday, May 20, 2007 10:13 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# clonazepam online @ Sunday, May 20, 2007 10:14 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# clonazepam online @ Sunday, May 20, 2007 10:14 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# clonazepam online @ Sunday, May 20, 2007 10:14 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# clonazepam online @ Sunday, May 20, 2007 10:14 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# clonazepam online @ Sunday, May 20, 2007 10:14 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# clonazepam online @ Sunday, May 20, 2007 10:15 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# clonazepam online @ Sunday, May 20, 2007 10:15 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam buy clonazepam http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=159 clonazepam online clonazepam online

clonazepam online

# order hydrocodone @ Sunday, May 20, 2007 10:15 PM

http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ order hydrocodone hydrocodone buy hydrocodone http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ buy hydrocodone order hydrocodone

order hydrocodone

# order hydrocodone @ Sunday, May 20, 2007 10:16 PM

http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ order hydrocodone hydrocodone buy hydrocodone http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ buy hydrocodone order hydrocodone

order hydrocodone

# order hydrocodone @ Sunday, May 20, 2007 10:16 PM

http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ order hydrocodone hydrocodone buy hydrocodone http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ buy hydrocodone order hydrocodone

order hydrocodone

# order hydrocodone @ Sunday, May 20, 2007 10:16 PM

http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ order hydrocodone hydrocodone buy hydrocodone http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ buy hydrocodone order hydrocodone

order hydrocodone

# order hydrocodone @ Sunday, May 20, 2007 10:16 PM

http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ order hydrocodone hydrocodone buy hydrocodone http://coracou.jubiiblog.de/">http://coracou.jubiiblog.de/ buy hydrocodone order hydrocodone

order hydrocodone

# levitra @ Sunday, May 20, 2007 10:17 PM

http://www.sccs.swarthmore.edu/org/daily/forum/papprint.php?id=5549">http://www.sccs.swarthmore.edu/org/daily/forum/papprint.php?id=5549 levitra cheap levitra cheap levitra http://www.sccs.swarthmore.edu/org/daily/forum/papprint.php?id=5549">http://www.sccs.swarthmore.edu/org/daily/forum/papprint.php?id=5549 cheap levitra levitra

levitra

# meridia online @ Sunday, May 20, 2007 10:17 PM

http://cahn.mnsu.edu/msuatdisc/_msuatdisc/0000056d.htm">http://cahn.mnsu.edu/msuatdisc/_msuatdisc/0000056d.htm meridia online meridia buy meridia http://cahn.mnsu.edu/msuatdisc/_msuatdisc/0000056d.htm">http://cahn.mnsu.edu/msuatdisc/_msuatdisc/0000056d.htm buy meridia meridia online

meridia online

# free free ringtones @ Sunday, May 20, 2007 10:17 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=163">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=163 free free ringtones free ringtones free ringtones http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=163">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=163 free ringtones free free ringtones

free free ringtones

# ritalin online @ Sunday, May 20, 2007 10:18 PM

http://domelc4t.dl.pl">http://domelc4t.dl.pl ritalin online ritalin cheap ritalin http://domelc4t.dl.pl">http://domelc4t.dl.pl cheap ritalin ritalin online

ritalin online

# mtv ringtones @ Sunday, May 20, 2007 10:18 PM

http://kelley.iu.edu/mbaa/forum/viewmessages.cfm?Forum=54&Topic=445">http://kelley.iu.edu/mbaa/forum/viewmessages.cfm?Forum=54&Topic=445 mtv ringtones mtv ringtones mtv ringtones http://kelley.iu.edu/mbaa/forum/viewmessages.cfm?Forum=54&Topic=445">http://kelley.iu.edu/mbaa/forum/viewmessages.cfm?Forum=54&Topic=445 mtv ringtones mtv ringtones

mtv ringtones

# online fioricet @ Sunday, May 20, 2007 10:18 PM

http://www2.cs.washington.edu/bugzilla/attachment.cgi?id=83">http://www2.cs.washington.edu/bugzilla/attachment.cgi?id=83 online fioricet cheap fioricet cheap fioricet http://www2.cs.washington.edu/bugzilla/attachment.cgi?id=83">http://www2.cs.washington.edu/bugzilla/attachment.cgi?id=83 fioricet online fioricet

online fioricet

# free music ringtones @ Sunday, May 20, 2007 10:18 PM

http://www.csulb.edu/~d49er/lounge/messages/8973.html">http://www.csulb.edu/~d49er/lounge/messages/8973.html free music ringtones music ringtones music ringtones http://www.csulb.edu/~d49er/lounge/messages/8973.html">http://www.csulb.edu/~d49er/lounge/messages/8973.html music ringtones free music ringtones

free music ringtones

# samsung ringtones @ Sunday, May 20, 2007 10:18 PM

http://edweb6.educ.msu.edu/forum/forum_posts.asp?TID=388">http://edweb6.educ.msu.edu/forum/forum_posts.asp?TID=388 samsung ringtones samsung ringtones samsung ringtones http://edweb6.educ.msu.edu/forum/forum_posts.asp?TID=388">http://edweb6.educ.msu.edu/forum/forum_posts.asp?TID=388 samsung ringtones samsung ringtones

samsung ringtones

# free tracfone ringtones @ Sunday, May 20, 2007 10:18 PM

http://intranet.education.umn.edu/Bush/Forum/forum_posts.asp?TID=100">http://intranet.education.umn.edu/Bush/Forum/forum_posts.asp?TID=100 free tracfone ringtones tracfone ringtones tracfone ringtones http://intranet.education.umn.edu/Bush/Forum/forum_posts.asp?TID=100">http://intranet.education.umn.edu/Bush/Forum/forum_posts.asp?TID=100 tracfone ringtones free tracfone ringtones

free tracfone ringtones

# ambien online @ Sunday, May 20, 2007 10:18 PM

http://kybele.psych.cornell.edu/forums/TAU-05/attach/reri.htm">http://kybele.psych.cornell.edu/forums/TAU-05/attach/reri.htm ambien online ambien buy ambien http://kybele.psych.cornell.edu/forums/TAU-05/attach/reri.htm">http://kybele.psych.cornell.edu/forums/TAU-05/attach/reri.htm ambien online ambien online

ambien online

# cheap adipex @ Sunday, May 20, 2007 10:18 PM

http://ist.greenville.edu/drupal/files/nesoz.html">http://ist.greenville.edu/drupal/files/nesoz.html cheap adipex adipex buy adipex http://ist.greenville.edu/drupal/files/nesoz.html">http://ist.greenville.edu/drupal/files/nesoz.html buy adipex cheap adipex

cheap adipex

# cheap meridia @ Sunday, May 20, 2007 10:18 PM

http://shell.ce.sharif.edu/~taghi/nph-proxy.cgi/011100A/http/diving-deep.net/net/meridia/n83">http://shell.ce.sharif.edu/~taghi/nph-proxy.cgi/011100A/http/diving-deep.net/net/meridia/n83 cheap meridia meridia buy meridia http://shell.ce.sharif.edu/~taghi/nph-proxy.cgi/011100A/http/diving-deep.net/net/meridia/n83">http://shell.ce.sharif.edu/~taghi/nph-proxy.cgi/011100A/http/diving-deep.net/net/meridia/n83 meridia online cheap meridia

cheap meridia

# free tracfone ringtones @ Sunday, May 20, 2007 10:18 PM

http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=164">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=164 free tracfone ringtones tracfone ringtones tracfone ringtones http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=164">http://www.salisbury.edu/pace/forum/topic.asp?TOPIC_ID=164 tracfone ringtones free tracfone ringtones

free tracfone ringtones

# nokia ringtones @ Sunday, May 20, 2007 10:18 PM

http://www.jhu.edu/cgi-bin/cgiwrap/gradro/ubbmisc.cgi?action=getbio&UserName=noorolo">http://www.jhu.edu/cgi-bin/cgiwrap/gradro/ubbmisc.cgi?action=getbio&UserName=noorolo nokia ringtones nokia ringtones nokia ringtones http://www.jhu.edu/cgi-bin/cgiwrap/gradro/ubbmisc.cgi?action=getbio&UserName=noorolo">http://www.jhu.edu/cgi-bin/cgiwrap/gradro/ubbmisc.cgi?action=getbio&UserName=noorolo nokia ringtones nokia ringtones

nokia ringtones

# free motorola ringtones @ Sunday, May 20, 2007 10:18 PM

http://edweb6.educ.msu.edu/forum/forum_posts.asp?TID=387">http://edweb6.educ.msu.edu/forum/forum_posts.asp?TID=387 free motorola ringtones motorola ringtones motorola ringtones http://edweb6.educ.msu.edu/forum/forum_posts.asp?TID=387">http://edweb6.educ.msu.edu/forum/forum_posts.asp?TID=387 motorola ringtones free motorola ringtones

free motorola ringtones

# sonyericsson ringtones @ Sunday, May 20, 2007 10:18 PM

http://www.csulb.edu/~d49er/lounge/messages/9098.html">http://www.csulb.edu/~d49er/lounge/messages/9098.html sonyericsson ringtones sonyericsson ringtones sonyericsson ringtones http://www.csulb.edu/~d49er/lounge/messages/9098.html">http://www.csulb.edu/~d49er/lounge/messages/9098.html sonyericsson ringtones sonyericsson ringtones

sonyericsson ringtones

# re: Dynamic Methods and Humane Interfaces http://risibile-divano.olbok.info @ Friday, May 25, 2007 8:33 AM

risibile-divano@30.04
http://www.http://bambola-ramona-hardcore.olbok.info bambola-ramona-hardcore.30.04 http://femmine-tettone.olbok.info femmine tettone http://www.http://imbarazzato-torride-sex.olbok.info imbarazzato-torride-sex.30.04 http://damerino-lesbiche-masturbate.olbok.info damerino lesbiche masturbate http://www.http://eros-coppie.olbok.info eros-coppie.30.04 http://idraulico-***-in-pace.olbok.info idraulico *** in pace http://www.http://nice-cowgirl-pompino.olbok.info nice-cowgirl-pompino.30.04 http://sheepish-amatoriali-pompino.olbok.info sheepish amatoriali pompino http://www.http://amabile-idraulico-amore.olbok.info amabile-idraulico-amore.30.04 http://beautiful-ragazze-***.olbok.info beautiful ragazze *** http://www.http://indescrivibile-infermiera-merda.oqewz.info indescrivibile-infermiera-merda.30.04 http://foto-facce-schizzate-gratis.oqewz.info foto facce schizzate gratis http://www.http://pretty-nonne-sex.oqewz.info pretty-nonne-sex.30.04 http://sex-ragazze-fottilo.oqewz.info sex ragazze fottilo http://www.http://sentimento-americano-masturbate.oqewz.info sentimento-americano-masturbate.30.04 http://felicitous-pulcino-spogliarello.oqewz.info felicitous pulcino spogliarello http://www.http://piacevole-fighetta-urinate.oqewz.info piacevole-fighetta-urinate.30.04 http://nonsensical-lesbiche-frode.oqewz.info nonsensical lesbiche frode http://www.http://pompini-di-trish-stratus.oqewz.info pompini-di-trish-stratus.30.04 http://giapponesi-puttane.oqewz.info giapponesi puttane http://www.http://piernotas.uxorr.info piernotas.30.04 http://infieles-espaolas.uxorr.info infieles espaolas http://www.http://travestis-navidenos.uxorr.info travestis-navidenos.30.04 http://teta-galeria-sekx.uxorr.info teta galeria sekx http://www.http://relatos-fogosos.uxorr.info relatos-fogosos.30.04 http://besos-anales.uxorr.info besos anales http://www.http://impresoras.uxorr.info impresoras.30.04 http://culos-violando.uxorr.info culos violando http://www.http://tranny-pps.uxorr.info tranny-pps.30.04 http://gatito-maine-coon.uxorr.info gatito maine coon http://www.http://desnudos-de-celular.uzimg.info desnudos-de-celular.30.04 http://impotence.uzimg.info impotence http://www.http://videos-folladoras.uzimg.info videos-folladoras.30.04 http://como-tener.uzimg.info como tener http://www.http://video-clips-de-sexo-gratis.uzimg.info video-clips-de-sexo-gratis.30.04 http://vela-latina-www.uzimg.info vela latina www http://www.http://lavativa-por-placer.uzimg.info lavativa-por-placer.30.04 http://jesica-cirio-fotos.uzimg.info jesica cirio fotos http://www.http://hetaira.uzimg.info hetaira.30.04 http://los-dibujos.uzimg.info los dibujos http://www.http://caja-fuerte.wmsoq.info caja-fuerte.30.04 http://matrimonios.wmsoq.info matrimonios http://www.http://chistes-de-adolecentes.wmsoq.info chistes-de-adolecentes.30.04 http://panochas-chicas.wmsoq.info panochas chicas http://www.http://imagenes-looney-toons.wmsoq.info imagenes-looney-toons.30.04 http://fotos-amigas-zarpadas.wmsoq.info fotos amigas zarpadas http://www.http://strippers-valencianas.wmsoq.info strippers-valencianas.30.04 http://fat-tranny-mpg.wmsoq.info fat tranny mpg http://www.http://madre-guapas.wmsoq.info madre-guapas.30.04 http://mujers-pornos-vids.wmsoq.info mujers pornos vids

risibile divano

# re: Dynamic Methods and Humane Interfaces @ Sunday, May 27, 2007 9:31 AM

http://www.lkioe.info/cuckold-2bmoglie-porca-2bcazzi-neri.html vecchie che scopano con giovani http://www.lkioe.info/mazda.html samantha trans roma http://www.lkioe.info/donne-maiale-godendo.html prodigiosamente bionde masturbate http://www.lkioe.info/donne-grasse-esibizioniste.html fotostorie porno http://www.lkioe.info/foto-reggicalze-gangbang.html foto di fighe arrapate di enni http://www.lmnst.info/foto-uomini-travestiti-hard.html sexsi foto free italiani http://www.lmnst.info/perizomi-amatoriali.html la mia gallery bocchini http://www.lmnst.info/solo-foto-bisex.html sederini perfetti http://www.lmnst.info/suocere-troie.html strip poker da scaricare http://www.lmnst.info/immagini-ingoio-record.html galleria foto trans che sborrano http://www.loetr.info/freddissimo-attraente-profilattico.html tette latte http://www.loetr.info/affari-foto.html studentesse in lingerie gratis http://www.loetr.info/fica-di-lollipop.html vecchie e grasse com http://www.loetr.info/maschi-bisex.html ragazze con calze di nylon http://www.loetr.info/rap-italiano-it.html piedi filmati gratis http://www.lokrt.info/foto-dal-mondo-it.html fotoracconti gratis http://www.lokrt.info/pornononne.html sessualita nella donna matura http://www.lokrt.info/discreto-pulcino-anale-fotti.html piu caldo insegnante http://www.lokrt.info/sesso-per-amatori-a-cartoni.html pelose rosse http://www.lokrt.info/foto-maschi.html vedere transex http://www.mcbvo.info/racconti-erotici-con-paola-perego.html timoroso tedesco inculate http://www.mcbvo.info/orgie-anziane.html storie di vampiri http://www.mcbvo.info/studentessa-vogliosa-storie.html audace zoccoleborghesi spogliarello http://www.mcbvo.info/annunci-di-vecchie-pompinare.html donne sexi gratis http://www.mcbvo.info/affetto-ragazze-fottilo.html sesso con donne formose torino

pfoto ditalini belle ragazze

# Testing @ Monday, May 28, 2007 4:54 PM

Helloins - this is just a testing, don't worry about it

Testerzda

# re: Dynamic Methods and Humane Interfaces @ Monday, June 04, 2007 11:48 PM

http://babulki.pornwebring.net/120070525.html
http://dojarka.pornwebring.net/720070525.html
http://zaeblo.pornwebring.net/820070525.html
http://nognici.atspace.com/320070526.html
http://bumaga.0moola.com/420070525.html
http://nauka.juicypornhost.com/220070525.html
http://karablik.fateback.com/720070525.html
http://alfa.pornwebring.net/120070525.html
http://porog.pornwebring.net/120070525.html
http://onal.pornzonehost.com/420070525.html
http://zilos.deep-ice.com/420070525.html
http://kanal.pornwebring.net/220070525.html
http://blowjobs.freegayspace.com/smens/320070525.html
http://dojdik.juicypornhost.com/420070525.html
http://makalkin.100free.com/420070525.html
http://marlop126.100webspace.net/820070525.html
http://prikolist.juicypornhost.com/920070525.html
http://moshniy.sphosting.net/520070525.html
http://gribok.1gb.in/920070525.html
http://durinda.100free.com/120070525.html
http://fo1getz.100free.com/920070525.html
http://legenda.somee.com/320070525.html
http://paklonik.pornwebring.net/320070525.html
http://matka.porkyhost.com/220070525.html
http://nana.my-animal-sex.net/820070525.html
http://noterdam.beast-space.net/520070526.html
http://mtz80.undonet.com/120070525.html
http://oblomchik.ob.funpic.org/520070525.html
http://matka.porkyhost.com/920070526.html

Deb

# re: Dynamic Methods and Humane Interfaces @ Thursday, June 07, 2007 3:16 AM

http://www.teens-asiatiques.info - http://sylia-nue.teens-asiatiques.info - http://sylvia-nue.teens-asiatiques.info - http://sylvianne-nue.teens-asiatiques.info - http://sylvie-nue.teens-asiatiques.info - http://sylvie-marie-nue.teens-asiatiques.info - http://sylvie-anne-nue.teens-asiatiques.info - http://syme-nue.teens-asiatiques.info - http://syndy-nue.teens-asiatiques.info - http://synthia-nue.teens-asiatiques.info - http://tabara-nue.teens-asiatiques.info - http://tabasum-nue.teens-asiatiques.info - http://tabatha-nue.teens-asiatiques.info - http://tabitha-nue.teens-asiatiques.info - http://tacita-nue.teens-asiatiques.info - http://tacy-ann-nue.teens-asiatiques.info - http://tadiana-nue.teens-asiatiques.info - http://tafarha-nue.teens-asiatiques.info - http://tahina-nue.teens-asiatiques.info - http://tahmim-nue.teens-asiatiques.info - http://tahmina-nue.teens-asiatiques.info - http://taierahkwenhawi-nue.teens-asiatiques.info - http://taiisha-nue.teens-asiatiques.info - http://taija-nue.teens-asiatiques.info - http://taina-nue.teens-asiatiques.info - http://taina-leila-nue.teens-asiatiques.info - http://taina-milagro-nue.teens-asiatiques.info - http://tais-nue.teens-asiatiques.info - http://taisa-nue.teens-asiatiques.info - http://taisha-nue.teens-asiatiques.info - http://taishia-nue.teens-asiatiques.info - http://taiya-nue.teens-asiatiques.info - http://tajdina-nue.teens-asiatiques.info - http://takatsitsontie-nue.teens-asiatiques.info - http://takhisis-nue.teens-asiatiques.info - http://tala-nue.teens-asiatiques.info - http://taleen-nue.teens-asiatiques.info - http://taleesha-nue.teens-asiatiques.info - http://talenna-nue.teens-asiatiques.info - http://talia-nue.teens-asiatiques.info - http://talia-amelia-nue.teens-asiatiques.info - http://taliana-nue.teens-asiatiques.info - http://talisha-nue.teens-asiatiques.info - http://talissa-nue.teens-asiatiques.info - http://taliyah-nue.teens-asiatiques.info - http://talya-kasandra-nue.teens-asiatiques.info - http://talyana-kelly-nue.teens-asiatiques.info - http://talyanna-nue.teens-asiatiques.info - http://talyna-nue.teens-asiatiques.info - http://tamana-nue.teens-asiatiques.info - http://tamara-nue.teens-asiatiques.info - http://tamara-esther-nue.teens-asiatiques.info - http://tamarah-nue.teens-asiatiques.info - http://tamara-kim-nue.teens-asiatiques.info - http://tamara-nelesha-nue.teens-asiatiques.info - http://tamaya-nue.teens-asiatiques.info - http://tameeah-nue.teens-asiatiques.info - http://tameeka-nue.teens-asiatiques.info - http://tameka-nue.teens-asiatiques.info - http://tamia-nue.teens-asiatiques.info - http://tamiah-nue.teens-asiatiques.info - http://tamika-nue.teens-asiatiques.info - http://tamilyn-ashley-nue.teens-asiatiques.info - http://tamisha-nue.teens-asiatiques.info - http://tam-lan-nue.teens-asiatiques.info - http://tammy-nue.teens-asiatiques.info - http://tammy-eve-nue.teens-asiatiques.info - http://tamrah-nue.teens-asiatiques.info - http://tamyla-nue.teens-asiatiques.info - http://tamy-lou-nue.teens-asiatiques.info - http://tamyra-nue.teens-asiatiques.info - http://tanais-nue.teens-asiatiques.info - http://tanesha-nue.teens-asiatiques.info - http://taneza-nue.teens-asiatiques.info - http://tanha-nue.teens-asiatiques.info - http://tania-nue.teens-asiatiques.info - http://tania-alexandra-nue.teens-asiatiques.info - http://tania-delfina-nue.teens-asiatiques.info - http://tanisha-nue.teens-asiatiques.info - http://tanjela-nue.teens-asiatiques.info - http://tanjim-nue.teens-asiatiques.info - http://tannisha-nue.teens-asiatiques.info - http://tanya-nue.teens-asiatiques.info - http://tanya-fleur-nue.teens-asiatiques.info - http://tanya-kerria-nue.teens-asiatiques.info - http://tanysha-nue.teens-asiatiques.info - http://tanyssa-nue.teens-asiatiques.info - http://tao-ping-nue.teens-asiatiques.info - http://tapanie-nue.teens-asiatiques.info - http://tapia-nue.teens-asiatiques.info - http://www.sexe-sexxx.com - http://www.hispanosexo.info - http://www.descarga-de-videos.info - http://www.descargar-videos.info - http://www.descarga-videos.info - http://www.ver-videos.info - http://www.ver-videos-porno.info - http://www.videos-cachondos.info - http://www.videos-chicas.info -