1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00

doc: move variadics, tweak methods, add missing TOC item (#8949)

This commit is contained in:
Nick Treleaven 2021-02-24 18:27:48 +00:00 committed by GitHub
parent e53476d5e1
commit 8e9e9b2f89
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -61,7 +61,6 @@ For more details and troubleshooting, please visit the [vab GitHub repository](h
* [Comments](#comments)
* [Functions](#functions)
* [Returning multiple values](#returning-multiple-values)
* [Variable number of arguments](#variable-number-of-arguments)
* [Symbol visibility](#symbol-visibility)
* [Variables](#variables)
* [Types](#types)
@ -90,6 +89,7 @@ For more details and troubleshooting, please visit the [vab GitHub repository](h
* [Functions 2](#functions-2)
* [Pure functions by default](#pure-functions-by-default)
* [Mutable arguments](#mutable-arguments)
* [Variable number of arguments](#variable-number-of-arguments)
* [Anonymous & high order functions](#anonymous--high-order-functions)
* [References](#references)
* [Constants](#constants)
@ -119,7 +119,8 @@ For more details and troubleshooting, please visit the [vab GitHub repository](h
* [Profiling](#profiling)
* [Advanced Topics](#advanced-topics)
* [Memory-unsafe code](#memory-unsafe-code)
* [sizeof and __offsetof](#sizeof-and-__offsetof)
* [Structs with reference fields](structs-with-reference-fields)
* [sizeof and __offsetof](#sizeof-and-__offsetof)
* [Calling C functions from V](#calling-c-functions-from-v)
* [Debugging generated C code](#debugging-generated-c-code)
* [Conditional compilation](#conditional-compilation)
@ -235,27 +236,6 @@ println(b) // 3
c, _ := foo() // ignore values using `_`
```
### Variable number of arguments
```v
fn sum(a ...int) int {
mut total := 0
for x in a {
total += x
}
return total
}
println(sum()) // 0
println(sum(1)) // 1
println(sum(2, 3)) // 5
// using array decomposition
a := [2, 3, 4]
println(sum(...a)) // <-- using prefix ... here. output: 9
b := [5, 6, 7]
println(sum(...b)) // output: 18
```
## Symbol visibility
```v
@ -1559,7 +1539,7 @@ fn main() {
This means that defining public readonly fields is very easy in V,
no need in getters/setters or properties.
### Methods
## Methods
```v
struct User {
@ -1583,6 +1563,7 @@ println(user2.can_register()) // "true"
V doesn't have classes, but you can define methods on types.
A method is a function with a special receiver argument.
The receiver appears in its own argument list between the `fn` keyword and the method name.
Methods must be in the same module as the receiver type.
In this example, the `can_register` method has a receiver of type `User` named `u`.
The convention is not to use receiver names like `self` or `this`,
@ -1718,6 +1699,27 @@ user = register(user)
println(user)
```
### Variable number of arguments
```v
fn sum(a ...int) int {
mut total := 0
for x in a {
total += x
}
return total
}
println(sum()) // 0
println(sum(1)) // 1
println(sum(2, 3)) // 5
// using array decomposition
a := [2, 3, 4]
println(sum(...a)) // <-- using prefix ... here. output: 9
b := [5, 6, 7]
println(sum(...b)) // output: 18
```
### Anonymous & high order functions
```v