doc: document C2V wrapper generator

pull/7376/head
Alexander Medvednikov 2020-12-17 12:25:31 +01:00 committed by GitHub
parent 1016b5073f
commit 7439ed7e2b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 29 additions and 19 deletions

View File

@ -84,7 +84,7 @@ Anything you can do in other languages, you can do in V.
* [Compile-time reflection](#compile-time-reflection) * [Compile-time reflection](#compile-time-reflection)
* [Limited operator overloading](#limited-operator-overloading) * [Limited operator overloading](#limited-operator-overloading)
* [Inline assembly](#inline-assembly) * [Inline assembly](#inline-assembly)
* [Translating C/C++ to V](#translating-cc-to-v) * [Translating C to V](#translating-c-to-v)
* [Hot code reloading](#hot-code-reloading) * [Hot code reloading](#hot-code-reloading)
* [Cross compilation](#cross-compilation) * [Cross compilation](#cross-compilation)
* [Cross-platform shell scripts in V](#cross-platform-shell-scripts-in-v) * [Cross-platform shell scripts in V](#cross-platform-shell-scripts-in-v)
@ -3101,39 +3101,49 @@ fn main() {
} }
``` ```
## Translating C/C++ to V ## Translating C to V
TODO: translating C to V will be available in V 0.3. C++ to V will be available later this year. TODO: translating C to V will be available in V 0.3.
V can translate your C/C++ code to human readable V code. V can translate your C code to human readable V code and generate V wrappers on top of C libraries.
Let's create a simple program `test.cpp` first:
```cpp
#include <vector> Let's create a simple program `test.c` first:
#include <string>
#include <iostream> ```c
#include "stdio.h"
int main() { int main() {
std::vector<std::string> s; for (int i = 0; i < 10; i++) {
s.push_back("V is "); printf("hello world\n");
s.push_back("awesome"); }
std::cout << s.size() << std::endl;
return 0; return 0;
} }
``` ```
Run `v translate test.cpp` and V will generate `test.v`: Run `v translate test.c`, and V will generate `test.v`:
```v ```v
fn main() { fn main() {
mut s := []string{} for i := 0; i < 10; i++ {
s << 'V is ' println('hello world')
s << 'awesome' }
println(s.len)
} }
``` ```
An online C/C++ to V translator is coming soon. To generate a wrapper on top of a C library use this command:
```bash
v wrapper c_code/libsodium/src/libsodium
```
This will generate a directory `libsodium` with a V module.
Example of a C2V generated libsodium wrapper:
https://github.com/medvednikov/libsodium
<br>
When should you translate C code and when should you simply call C code from V? When should you translate C code and when should you simply call C code from V?