doc: tweak Modules section (#6480)

pull/6483/head
Nick Treleaven 2020-09-25 19:34:58 +01:00 committed by GitHub
parent fbae0a7274
commit acbfc11eef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 20 additions and 19 deletions

View File

@ -610,7 +610,7 @@ For information about creating a module, see [Modules](#modules)
### Importing a module ### Importing a module
Modules can be imported using keyword `import`. Modules can be imported using the `import` keyword.
```v ```v
import os import os
@ -1380,14 +1380,15 @@ fn print_backtrace()
V is a very modular language. Creating reusable modules is encouraged and is V is a very modular language. Creating reusable modules is encouraged and is
very simple. very simple.
To create a new module, create a directory with your module's name and To create a new module, create a directory with your module's name containing
.v files with code: .v files with code:
```v ```
cd ~/code/modules cd ~/code/modules
mkdir mymodule mkdir mymodule
vim mymodule/myfile.v vim mymodule/myfile.v
```
```v
// myfile.v // myfile.v
module mymodule module mymodule
@ -1397,13 +1398,9 @@ pub fn say_hi() {
} }
``` ```
You can have as many .v files in `mymodule/` as you want. You can now use `mymodule` in your code:
That's it, you can now use it in your code:
```v ```v
module main
import mymodule import mymodule
fn main() { fn main() {
@ -1411,20 +1408,23 @@ fn main() {
} }
``` ```
Note that you have to specify the module every time you call an external function. Note that you have to specify the module prefix every time you call an external function.
This may seem verbose at first, but it makes code much more readable This may seem verbose at first, but it makes code much more readable
and easier to understand, since it's always clear which function from and easier to understand - it's always clear which function from
which module is being called. Especially in large code bases. which module is being called. This is especially useful in large code bases.
Module names should be short, under 10 characters. Circular imports are not allowed. * Module names should be short, under 10 characters.
* Circular imports are not allowed.
* You can have as many .v files in a module as you want.
* You can create modules anywhere.
* All modules are compiled statically into a single executable.
You can create modules anywhere. See also: [Module imports](#module-imports).
All modules are compiled statically into a single executable. ### `init` functions
If you want to write a module that will automatically call some If you want a module to automatically call some setup/initialization code when it is imported,
setup/initialization code when imported (perhaps you want to call you can use a module `init` function:
some C library functions), write a module `init` function inside the module:
```v ```v
fn init() { fn init() {
@ -1432,7 +1432,8 @@ fn init() {
} }
``` ```
The init function cannot be public. It will be called automatically. The `init` function cannot be public - it will be called automatically. This feature is
particularly useful for initializing a C library.
## Types 2 ## Types 2