Simple, fast, safe, compiled language for developing maintainable software. Compiles itself in <1s with zero library dependencies. https://vlang.io
 
 
Go to file
Delyan Angelov 5d0cb1437c Add support for VFLAGS environment variable, merged with cmd args.
Using VFLAGS, you can pass common options through it to the V compiler,
without having to manually specify them everytime when you type V ...
In addition, since environment variables are *inherited*, all subprocess
V compilers, which V launches (for example when compiling with -live),
will *also* use the same VFLAGS environment variable.

Example usage:
  export VFLAGS="-debug -show_c_cmd"
  v -live message.v

=> This will keep *both* of the generated C source files .message.c
   *AND* .message_shared_lib.c . It will also cause both V compile
   subprocesses to print their resulting C compiler backend lines.
   This is very useful when using GDB to debug problems.
2019-07-16 19:35:16 +02:00
.github vlib: update and cleanup tests + fix PR template 2019-06-29 22:49:57 +02:00
compiler Add support for VFLAGS environment variable, merged with cmd args. 2019-07-16 19:35:16 +02:00
examples [][]int 2019-07-16 13:56:48 +02:00
thirdparty move zip C dependency to thirdparty/ 2019-07-15 19:30:53 +02:00
vlib os: hostname function 2019-07-16 19:23:47 +02:00
.gitattributes .gitattributes etc 2019-06-22 20:24:15 +02:00
.gitignore Update .gitignore 2019-07-03 16:12:37 +02:00
.travis.yml travis: make.bat 2019-07-12 21:10:22 +02:00
CHANGELOG.md http_win: fix BUF_MAX 2019-07-16 15:29:27 +02:00
CONDUCT.md Update CONDUCT.md 2019-06-24 18:07:25 +02:00
CONTRIBUTING.md Rename CodeStructure.md to CONTRIBUTING.md 2019-06-30 22:34:25 +02:00
LICENSE README.md 2019-06-22 20:22:41 +02:00
Makefile Makefile: add `-lm` 2019-07-10 21:59:08 +02:00
README.md readme: clarify installation instructions 2019-07-13 12:49:55 +02:00
azure-pipelines.yml Azure: remove `cd compiler` 2019-06-29 13:04:59 +02:00
make.bat make.bat for easier compilation on Windows 2019-07-04 20:44:44 +02:00

README.md

The V Programming Language 0.1.x

Build Status Build Status

https://vlang.io

Documentation: https://vlang.io/docs

Twitter: https://twitter.com/v_language

Discord (primary community): https://discord.gg/n7c74HM

Installing V: https://github.com/vlang/v#installing-v-from-source

Key Features of V

  • Simplicity: the language can be learned in half an hour, less if you already know Go
  • Fast compilation: ~100k loc/s right now, ~1.2 million loc/s once x64 generation is mature enough
  • Easy to develop: V compiles itself in less than a second
  • Performance: within 5% of C
  • Safety: no null, no globals, no undefined behavior, immutability by default
  • C to V translation
  • Hot code reloading
  • Powerful UI and graphics libraries
  • Easy cross compilation
  • REPL

V 1.0 release is planned for December 2019. Right now V is in an alpha stage.

Notes

GitHub marks V's code as written in Go. It's actually written in V, GitHub doesn't support the language yet.

The compilation is temporarily slower for this release:

  • Debug builds are used (use ./v -prod -o v compiler to get faster compilation).
  • vlib is recompiled with every program you build.
  • The new formatter runs on every single token and slows the compiler down by ~20%. This will be taken care of.

Code structure

https://github.com/vlang/v/blob/master/CONTRIBUTING.md

Installing V from source

Linux, macOS, Windows, WSL, Android, Raspberry Pi

git clone https://github.com/vlang/v
cd v
make

That's it! Now you have a V executable at [path to V repo]/v. [path to V repo] can be anywhere.

C compiler

You'll need Clang or GCC.

On macOS run xcode-select --install if you don't have XCode or XCode tools installed.

On Windows follow these instructions: github.com/vlang/v/wiki/Installing-a-C-compiler-on-Windows

Building without make

# Download the V compiler's source translated to C
curl -O https://raw.githubusercontent.com/vlang/vc/master/v.c
cc -std=gnu11 -w -o v v.c  # Build it with Clang or GCC
./v -o v compiler          # Use the resulting V binary to build V from V source

(These instructions won't work on Windows, use make.bat instead).

Symlinking and updates

You can create a symlink so that it's globally available:

sudo ln -s [path to V repo]/v /usr/local/bin/v

V is being constantly updated. To update V, simply run

git pull origin master
make

Testing

$ cd examples
$ v run hello_world.v
hello world

$ v
V 0.1.x
Use Ctrl-D to exit

>>> println('hello world')
hello world
>>>

Now if you want, you can start tinkering with the compiler. If you introduce a breaking change and rebuild V, you will no longer be able to use V to build itself. So it's a good idea to make a backup copy of a working compiler executable.

Running the examples

v hello_world.v && ./hello_world    # or simply
v run hello_world.v                 # this builds the program and runs it right away

v word_counter.v && ./word_counter cinderella.txt
v run news_fetcher.v
v run tetris.v

In order to build Tetris and anything else using the graphics module, you will need to install glfw and freetype.

If you plan to use the http package, you also need to install libcurl.

macOS:
brew install glfw freetype curl

Ubuntu:
sudo apt install libglfw3 libglfw3-dev libfreetype6-dev libcurl3-dev

Arch:
sudo pacman -S glfw-x11 curl freetype2

glfw and libcurl dependencies will be removed soon.