aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2016-10-20 00:43:07 +0800
committerchriseth <c@ethdev.com>2016-11-16 21:37:18 +0800
commit679ea2820fd6bb76ddd294101ef548bab6cd6425 (patch)
treee13c6d35f47b979ecb742278cf04953c82c32851
parent62492b67e783dd19c67850e2b8ae107aeeb83217 (diff)
downloaddexon-solidity-679ea2820fd6bb76ddd294101ef548bab6cd6425.tar
dexon-solidity-679ea2820fd6bb76ddd294101ef548bab6cd6425.tar.gz
dexon-solidity-679ea2820fd6bb76ddd294101ef548bab6cd6425.tar.bz2
dexon-solidity-679ea2820fd6bb76ddd294101ef548bab6cd6425.tar.lz
dexon-solidity-679ea2820fd6bb76ddd294101ef548bab6cd6425.tar.xz
dexon-solidity-679ea2820fd6bb76ddd294101ef548bab6cd6425.tar.zst
dexon-solidity-679ea2820fd6bb76ddd294101ef548bab6cd6425.zip
Part of the documentation.
-rw-r--r--docs/types.rst42
1 files changed, 41 insertions, 1 deletions
diff --git a/docs/types.rst b/docs/types.rst
index 9ec9e526..2e1cbee9 100644
--- a/docs/types.rst
+++ b/docs/types.rst
@@ -234,7 +234,7 @@ Hexademical Literals behave like String Literals and have the same convertibilit
.. _enums:
Enums
-=====
+-----
Enums are one way to create a user-defined type in Solidity. They are explicitly convertible
to and from all integer types but implicit conversion is not allowed. The explicit conversions
@@ -267,6 +267,46 @@ check the value ranges at runtime and a failure causes an exception. Enums need
}
}
+.. index:: ! function type, ! type; function
+
+.. _function_types:
+
+Function Types
+--------------
+
+Functions can be assigned to variables and passed on together with function calls.
+These types come in two flavours: *internal* and *external* functions.
+
+Internal functions can only be used inside the current contract (more specifically,
+inside the current code unit, which also includes internal library functions)
+because they cannot be executed outside of the
+context of the current function. Calling an internal function is realized
+by jumping to its entry label, just like when calling an function of the current
+contract internally.
+
+External functions consist of an address and a function signature and they can
+be passed via and returned from external function calls.
+
+Function types are notated as follows:
+
+ function (<argument types>) internal / external returns (<return types>)
+
+As always, the ``returns (<return types>)`` is optional.
+
+By default, function types are internal, so the ``internal`` keyword can be
+omitted.
+
+If a function type variable is not initialized, calling it will result
+in an exception.
+
+If external function types are used outside of the context of Solidity,
+they are converted into the ``bytes24`` type.
+
+Example usage:
+
+ library ArrayUtils {
+
+
.. index:: ! type;reference, ! reference type, storage, memory, location, array, struct
Reference Types