annotate wiki/semantics.wiki @ 622:19e08da86123

Added semantics.wiki.
author Aziz K?ksal <aziz.koeksal@gmail.com>
date Fri, 11 Jan 2008 01:43:31 +0100
parents
children a3fab8b74a7d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
622
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
1 #summary Notes on the semantic rules of elements in the D programming language
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
2
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
3 == Classes ==
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
4 * Inherits from Object (defined in module object) if no base class is specified.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
5 * May inherit only from one class (single inheritance.)
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
6 * May inherit zero to any number of interfaces.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
7 * All classes can be implicitly cast to object.Object.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
8 * Methods are "virtual" by default.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
9 * Is a reference type.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
10 * Instances are allocated on the heap (or on the stack; see attribute 'scope'.)
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
11 * Every class has a ClassInfo (from module object.)
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
12 * Attributes:
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
13 * abstract: class can't be instantiated.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
14 * final: disallows inheritance by other classes.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
15 * scope: instances are allocated on the stack. Variable declarations of this class must be marked with the scope attribute.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
16 * const, invariant: D2.0 feature. All declarations inside the class body are marked as const or invariant.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
17 * deprecated: using the class is an error.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
18 * Meaningless: auto, extern, override, static, synchronized.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
19 == Structs ==
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
20 * 'align' attribute has only a meaning for and in structs.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
21 * Can't inherit other structs.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
22 * Is a value type.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
23 == Interfaces ==
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
24 * Can't have fields (member variables.)
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
25 * Methods must be declared but not defined (i.e. no function body.)
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
26 * Can inherit other interfaces.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
27 == Enums ==
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
28 * The base type must be integral and it defaults to int.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
29 * Named enums have their own scopes.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
30 * The members of an anonymous enum are inserted into the scope that surrounds the enum declaration.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
31 == Functions ==
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
32 * Variable declarations may not shadow other variables in the surrounding scopes. E.g: `void f(){ int a; { int a;/* Error: shadows outer 'a'*/ } }`.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
33 == Variables ==
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
34 * Declarations are default initialized to Type.init.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
35 == Imports ==
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
36 * Private importing is the default.
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
37 == Labels ==
19e08da86123 Added semantics.wiki.
Aziz K?ksal <aziz.koeksal@gmail.com>
parents:
diff changeset
38 * They are stored in a separate symbol table.