[#3109] Is divmod dangerous? — Dave Thomas <Dave@...>

14 messages 2000/06/06

[#3149] Retrieving the hostname and port in net/http — Roland Jesse <jesse@...>

Hi,

12 messages 2000/06/07

[#3222] Ruby coding standard? — Robert Feldt <feldt@...>

16 messages 2000/06/09

[#3277] Re: BUG or something? — Aleksi Niemel<aleksi.niemela@...>

> |I am new to Ruby and this brings up a question I have had

17 messages 2000/06/12
[#3281] Re: BUG or something? — Dave Thomas <Dave@...> 2000/06/12

Aleksi Niemel<aleksi.niemela@cinnober.com> writes:

[#3296] RE: about documentation — Aleksi Niemel<aleksi.niemela@...>

> I want to contribute to the ruby project in my spare time.

15 messages 2000/06/12

[#3407] Waffling between Python and Ruby — "Warren Postma" <embed@...>

I was looking at the Ruby editor/IDE for windows and was disappointed with

19 messages 2000/06/14

[#3410] Exercice: Translate into Ruby :-) — Jilani Khaldi <jilanik@...>

Hi All,

17 messages 2000/06/14

[#3415] Re: Waffling between Python and Ruby — Andrew Hunt <andy@...>

>Static typing..., hmm,...

11 messages 2000/06/14

[#3453] Re: Static Typing( Was: Waffling between Python and Ruby) — Andrew Hunt <andy@...>

32 messages 2000/06/16

[#3516] Deep copy? — Hugh Sasse Staff Elec Eng <hgs@...>

Given that I cannot overload =, how should I go about ensuring a deep

20 messages 2000/06/19

[#3694] Why it's quiet — hal9000@...

We are all busy learning the new language

26 messages 2000/06/29
[#3703] Re: Why it's quiet — "NAKAMURA, Hiroshi" <nahi@...> 2000/06/30

Hi,

[#3705] Re: Why it's quiet — matz@... (Yukihiro Matsumoto) 2000/06/30

Hi,

[ruby-talk:03646] Re: Static Typing( Was: Waffling between Python and Ruby)

From: Rainer Joswig <rainer.joswig@...>
Date: 2000-06-24 08:58:58 UTC
List: ruby-talk #3646
In article <8ir5bg$5cklh$1@fu-berlin.de>, "Joachim Durchholz" 
<joachim.durchholz@halstenbach.com.or.de> wrote:

> However, Design by Contract isn't just assertions. What makes DbC stand
> out is that contract rules are inherited to subclasses.

Yes. But this can be inherited in a dynamically typed language
that might support DbC, too.

Dynamically typed doesn't mean that you can't declare
and use types or classes. It just means that a compiler
might not try to infer type declarations
and/or enforce type declarations at compile time.
At runtime types and classes may be available.

> This is a very
> unspectacular property in a dynamically-typed language, but in a
> statically-typed language, it means that I can write code like
>   x: FOO
>   x.some_feature
> and I can look up the contract of 'some_feature' in FOO and be sure that
> at least the contract that I find there will be honored, no matter what
> kind of object was assigned to x.

The same is true for dynamically typed languages with DbC.

> In a dynamically-typed language, I don't know that x will always be of
> type FOO,

Just assert it. This can be done in many ways.

> so there's no place to look what the contract of
> 'some_feature' is.

You have to lookup the contract at runtime anyway. Since
in dynamically typed languages the classes are a property
of the objects (at any time you can ask what type or
class the object is of) you just look that up too.

-- 
Rainer Joswig, BU Partner,
ISION Internet AG, Steinht 9, 20459 Hamburg, Germany
Tel: +49 40 3070 2950, Fax: +49 40 3070 2999
Email: mailto:rainer.joswig@ision.net WWW: http://www.ision.net/

In This Thread