vibe-d ~issue_1994_json_trailing_comma
Event driven web and concurrency framework
To use this package, run the following command in your project's root directory:
Manual usage
Put the following dependency into your project's dependences section:
This package provides sub packages which can be used individually:
vibe-d:utils - Low level utility functionality
vibe-d:data - Data format and serialization support
vibe-d:core - Basic I/O and concurrency primitives, as well as low level utility functions
vibe-d:stream - Library of various pluggable stream implementations
vibe-d:tls - TLS stream implementations
vibe-d:crypto - Cryptographic helper routines
vibe-d:textfilter - Text filtering routines
vibe-d:inet - Internet standard functionality
vibe-d:mail - SMTP client support
vibe-d:http - HTTP server and client implementation and higher level HTTP functionality
vibe-d:mongodb - MongoDB database client implementation
vibe-d:redis - Redis database client implementation
vibe-d:web - High level web and REST service framework
vibe.d is a high-performance asynchronous I/O, concurrency and web application toolkit written in D. It already contains many supplemental features such as database support to be able to offer a complete development environment. For more specialized needs, there are also many compatible DUB packages available.
Visit the website at http://vibed.org/ for more information.
Hello Vibe.d
#!/usr/bin/env dub
/+ dub.sdl:
name "hello_vibed"
dependency "vibe-d" version="~>0.8.0"
+/
import vibe.d;
void main()
{
auto settings = new HTTPServerSettings;
settings.port = 8080;
listenHTTP(settings, (req, res) { res.writeBody("Hello Vibe.d: " ~ req.path); });
runApplication();
}
Download this file as hello.d
and run it with DUB:
> dub hello.d
(or chmod +x
and execute it: ./hello.d
)
Alternatively, you can quickstart with examples directly on .
Support
Vibe.d aims to support at least the 3 latest minor releases of D. At the moment, the following compilers are supported and tested:
- DMD 2.079.0
- DMD 2.078.3
- DMD 2.077.1
- DMD 2.076.1
- DMD 2.075.1
- DMD 2.074.1
- DMD 2.073.2
- LDC 1.8.0 (FE: 2.078.3)
- LDC 1.7.0 (FE: 2.077.1)
- LDC 1.6.0 (FE: 2.076.1)
- LDC 1.5.0 (FE: 2.075.1)
- LDC 1.4.0 (FE: 2.074.1)
- LDC 1.3.0 (FE: 2.073.2)
Up to 0.8.2:
- DMD 2.072.2
- LDC 1.2.0 (FE: 2.072.2)
Up to 0.8.1:
- DMD 2.071.2
- LDC 1.1.1 (FE: 2.071.2)
Up to 0.8.0:
- DMD 2.070.2
- LDC 1.0.0 (FE: 2.070.2)
Up to 0.7.31+:
- DMD 2.069.2
Up to 0.7.30:
- DMD 2.068.2
- LDC 0.17.0-beta.2 (FE: 2.068.2)
Up to 0.7.29:
- DMD 2.067.1
- LDC 0.16.1
Up to 0.7.27:
- DMD 2.066
- GDC 5.2.0
- GDC 4.9.2
- LDC 0.15.1
Installation
Instead of explicitly installing vibe.d, it is recommended to use DUB for building vibe.d based applications. Once DUB is installed, you can create and run a new project using the following shell commands:
dub init <name> -t vibe.d
cd <name>
dub
Similarly, you can run an example by invoking dub
from any of the
example project directories.
Note that on non-Windows operating systems, you also need to have libevent and OpenSSL installed - and of course a D compiler. See below for instructions.
Additional setup on Windows
- Just install DMD using the installer on http://dlang.org/download.html
- And get the latest DUB release
Note for building on Win64
There are currently no 64-bit Windows binaries of libevent included, so you'll either need to build those yourself, or you can switch to the "win32" event driver by inserting "subConfigurations": {"vibe-d": "win32"}
into the dub.json file of your project.
Additional setup on Mac using brew
If you don't have brew installed, install it according to their install instructions and install libevent.
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
brew install libevent
You can then also install DUB using brew:
brew install dub
(Note: Install brew only if you do not have macports, as they will conflict)
Install DMD using the installer on http://dlang.org/download.html.
Optionally, run ./setup-mac.sh
to create a user/group pair for privilege lowering.
Additional setup on Linux (Debian/Ubuntu/Mint)
Install vibe.d's dependencies (*)
sudo apt-get install libevent-dev libssl-dev
On 32-bit linux: Install DMD-i386
sudo apt-get install g++ gcc-multilib xdg-utils
wget "http://downloads.dlang.org/releases/2.x/2.068.2/dmd_2.068.2-0_i386.deb"
sudo dpkg -i dmd_2.068.2-0_i386.deb
On 64-bit linux: Install DMD-amd64
sudo apt-get install g++ gcc-multilib xdg-utils
wget "http://downloads.dlang.org/releases/2.x/2.068.2/dmd_2.068.2-0_amd64.deb"
sudo dpkg -i dmd_2.068.2-0_amd64.deb
Optionally, run ./setup-linux.sh
to create a user/group pair for privilege lowering.
(*) Note that Debian 6 (Squeeze) and older requires manual installation (see below).
Additional setup on Linux (generic)
You need to have the following dependencies installed:
Optionally, run ./setup-linux.sh
to create a user/group pair for privilege lowering.
(*) Note that some Linux distributions such as Debian Squeeze or CentOS 6 may only ship libevent 1.4, in this case you will have to manually compile the latest 2.0.x version:
wget https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz
tar -xf libevent-2.0.21-stable.tar.gz
cd libevent-2.0.21-stable
./configure
make
make install
ldconfig
Additional setup on FreeBSD
Install the DMD compiler and vibe.d's dependencies using portupgrade or a similar mechanism:
sudo portupgrade -PN devel/libevent2 devel/pkgconf
Optionally, run ./setup-freebsd.sh
to create a user/group pair for privilege lowering.
Switching between OpenSSL versions
By default, vibe.d is built against OpenSSL 1.0.x. On systems that use the newer
1.1.x branch, this can be overridden on the DUB command line using
--override-config vibe-d:tls/openssl-1.1
. Alternatively, the same can be done
using a sub configuration directive in the package recipe:
SDL syntax:
dependency "vibe-d:tls" version="~>0.8.2"
subConfiguration "vibe-d:tls" "openssl-1.1"
JSON syntax:
{
...
"dependencies": {
...
"vibe-d:tls": "*"
},
"subConfigurations": {
...
"vibe-d:tls": "openssl-1.1"
}
}
For older systems there is also an "openssl-0.9" configuration that can be used in analogy to the above to build against the OpenSSL 0.9.8 branch.
Finally, there is a "botan" configuration for using the D port of the Botan library.
- ~issue_1994_json_trailing_comma released 6 years ago
- vibe-d/vibe.d
- vibed.org/
- MIT
- Copyright © 2012-2018 rejectedsoftware e.K.
- Authors:
- Sub packages:
- vibe-d:utils, vibe-d:data, vibe-d:core, vibe-d:stream, vibe-d:tls, vibe-d:crypto, vibe-d:textfilter, vibe-d:inet, vibe-d:mail, vibe-d:http, vibe-d:mongodb, vibe-d:redis, vibe-d:web
- Dependencies:
- vibe-d:stream, vibe-d:web, vibe-d:mail, vibe-d:redis, vibe-d:crypto, vibe-d:tls, vibe-d:mongodb, vibe-d:textfilter, vibe-d:data, vibe-d:http, vibe-d:inet, vibe-d:utils, vibe-d:core
- System dependencies:
- Optionally libevent 2.0.x, OpenSSL 1.0.x
- Versions:
-
0.10.1 2024-Sep-07 0.10.1-rc.1 2024-Aug-30 0.10.1-alpha.3 2024-Apr-18 0.10.1-alpha.2 2024-Apr-14 0.10.1-alpha.1 2024-Apr-12 - Download Stats:
-
-
168 downloads today
-
1500 downloads this week
-
7717 downloads this month
-
1440005 downloads total
-
- Score:
- 5.0
- Short URL:
- vibe-d.dub.pm