Jish Karoshi wrote: > How do you design programs when you can't specify types? If all > I can specify in a method definition are the names of the arguments, > then how does anybody know how to use that method without knowing > about the implementation of the method? If all you know about a function is the name of the arguments, you cannot do serious programming. But if you know the types of the arguments, you cannot do neiter! Imagine a function pid_t waitpid(pid_t wpid, int *status, int options) do you exacly know what is does, or what meaning return values have, without having seen any documentation? Type information does not help much here. The clue is, if you write a function, and want it get used by others, you have to provide some documentation, either as comments, or elsewhere. In the documentation, you also can provide type informatin - if the functin is restricted to some types. If you just know parameter types, you start trying out - and programming by try and error might be fun, but is not a serious thing. In Ruby, you need not specify types, as often functions can take more than one type. def add_up(a,b) a + b end It adds what you give - It cill act on every type having a method "+" defined. if you pass strings it will result strings. If you pass integer, it will return integer: add_up("Hello", "World") --> "HelloWorld" add_up(22, 33) --> 55 That is what I call polymorphic! Look at C++, where for that class of polymorphism you need templates. And I cannot imagine something like template <class T_IN, class T_OUT> T_OUT process(T_IN input, T_OUT output) is more intuitive (or even easier to program) like the Ruby def process(input, output) > The same thing goes for > the return value. Shure! > I have only been looking into ruby for a brief time, but from what > I can tell, it seems like everybody on a project would have to know > implementation details of the whole system in order to participate. > I don't understand how to chop a system up into little black boxes > if I don't have type information. I do not agree here. The C++ STL has more in common with a black box (at least for beginners) than any Ruby function. Also, I do not consider black boxes to be that bad. It does a great deal in hiding implementation details. > I especially don't understand how anyone would ever be able to > implement a distributed system in this way. Do not mind. You will learn as you get used to OOP, type abstraction and software engineering :-) > I feel that I must be missing something obvious and important here! > If somebody could clue me in I would really appreciate it. I have to admit that there is not so much documenation on Ruby like on other programming languages, but if you want to learn something about the concepts of Ruby, try http://www.ruby-lang.org/en/doc.html The "Ruby User's Guide" is a good point to start with. Greetings, /Bernd