From 52a8d7b3f5cbf3538d0c4e9f60446ebb59fb72ff Mon Sep 17 00:00:00 2001 From: Denton Liu Date: Wed, 11 May 2016 17:07:25 -0400 Subject: [PATCH] Added content --- docs/control-structures.rst | 51 +++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) diff --git a/docs/control-structures.rst b/docs/control-structures.rst index 77fbee527..0ad1c591f 100644 --- a/docs/control-structures.rst +++ b/docs/control-structures.rst @@ -147,6 +147,57 @@ Scoping and Declarations .. index:: ! scoping, ! declarations +In Solidity, a variable declared anywhere within a function will be in scope for the *entire function*, regardless of where it is declared. +This is in contrast to many languages where variables are only scoped where they are declared until the end of the semantic block. +As a result, the following code is illegal and cause the compiler to throw an error, `Identifier already declared.`:: + + contract ScopingErrors { + function scoping() { + uint i = 0; + + while (i++ < 1) { + uint same1 = 0; + } + + while (i++ < 2) { + uint same1 = 0;// Illegal, second declaration of same1 + } + } + + function minimalScoping() { + { + uint same2 = 0; + } + + { + uint same2 = 0;// Illegal, second declaration of same2 + } + } + + function forLoopScoping() { + for (uint same3 = 0; same3 < 1; same3++) { + } + + for (uint same3 = 0; same3 < 1; same3++) {// Illegal, second declaration of same3 + } + } + } + +In addition to this, if a variable is declared, it will be initialized at the beginning of the function to its default value. +As a result, the following code is legal, despite being poorly written.:: + + function foo() returns (uint) { + uint bar = 5; + // baz is implicitly initialized as 0 + if (true) { + bar += baz; + } + else { + uint baz = 10;// never executes + } + return bar;// returns 5 + } + Exceptions ==========