Frequently Asked Questions (FAQ)

Updated January 2015

1 - Introduction

1.1 - What is Tntnet?

Tntnet is a web application framework for C++.

Here a short overview:

back to top

1.2 - What are the goals of Tntnet?

The goal is to provide an easy and convenient way to create web applications in C++ by embedding the code into HTML. With Tntnet web applications can be structured as desired. Tntnet is policy free, i.e. it lets developers the freedom to structure their applications as needed. Our components use ISO standards and are developed according to POSIX guidelines. This offers investment protection, i.e. a secure and reliable basis. Another important goal is stability of the API: Tntnet is already deployed in several commercial applications with high demand for stability. Thus good code quality is also essential for Tntnet's development.

back to top

1.3 - How is Tntnet licensed?

Tntnet is licensed under the Lesser General Public Licence (LGPL) with a template extension. It can be used in both open source and closed source scenarios. For more information please read the License information.

back to top

1.4 - How does Tntnet work?

The first program from Tntnet that is called when building a web app is the ecpp compiler (ecppc), which compiles your ecpp pages into C++ classes. These are then compiled into native code using a C++ compiler. This code can either reside in a shared library (.so) or in an own executable linked against libtntnet (for details, see the quick start guide). Tntnet does not require to use a specific C++ compiler, you can use the compiler which fits best to your needs. Tntnet itself is multithreaded, so that requests are processed in parallel. It is highly optimized for speed. Benchmarks have shown its excellent performance.

back to top

1.5 - Which operating systems does Tntnet run on?

Tntnet is usable in all POSIX compliant systems. It is known to work on various GNU/Linux distributions and BSD derivatives, as well as on AIX and Solaris.

back to top

1.6 - Does tntnet run under Windows?

No. Tntnet do not run under Windows. Until now nobody was willing to port tntnet to Windows. If someone want to port it to Windows, we'll love to support it.

back to top

1.7 - Who developed Tntnet?

Tntnet is developed and maintained by Tommi Mäkitalo, the main developer and some contributors under open source development rules.

back to top

1.8 - When should I use Tntnet?

If your web application/service needs:

back to top

1.9 - Where can I get Tntnet?

Currently there are three ways to get Tntnet and its components.

  1. Through the package manager in your operating system
  2. Through the download page
  3. Through GitHub, mainly if you want to have to absolutely latest version

Note: For productive use the best option is 1, but you should fall back to 2 if those packages are outdated.

back to top

2 - Development

2.1 - What are the first steps?

The Quick Start Guide includes everything you need to get started. If you have any further questions, we are available via mailing list and IRC (details can be found on the contact page).

back to top

2.2 - Where do I find the documentation?

We have howto's, an API documentation, man pages and a quick start guide. It can be found on our homepage and in the source code.

back to top

2.3 - Where do I find an example application?

There are many small demos available on GitHub. This website serves as an example too, you can find its source code on GitHub as well: maekitalo/tntnet-homepage

back to top

2.4 - Why does Tntnet use a template engine?

When a web developer designs web sites, he writes HTML code. The task of the application developer in the Tntnet world is to add application logic to the web pages. That is easily done by just adding the program logic using ecpp tags. There is no need to translate the actual html code produced from the designer into long lists of print statements or similar. You can use #include in Tntnet applications to import you application logic classes into your ecpp template. There are only few lines of glue code needed to access your application logic in the ecpp template.

back to top

2.5 - Can I reuse my existing C++ code?

Of course you can. It is just easy to "web enable" existing C++ code. Thats one of the great things about Tntnet, that you can just reuse your existing code. There are so many C++ applications out there, which use other languages to add a web interface to the application. This leads to the problem, how to transfer the data into the other world. With Tntnet you can just use the existing C++ classes in the web application. No rewrite or interfacing is needed.

back to top

3 - Contributing

3.1 - How can I contribute?

We appreciate all efforts to improve Tntnet itself or any other part of this project.

You can help in several ways:

back to top

3.2 - Where can I find the source code?

The source code is available on GitHub. Links to all repositories can be found on the development page.

back to top

3.3 - How do I report a bug or submit a patch?

You can write an email to the main developer directly or use the mailing list, see the contact page.

back to top

3.4 - I'm a package maintainer, what do i need to know?

We use GNU autotools for a build system and we develop according to the POSIX standards. Cxxtools and tntdb are shared libraries and are treated as such. Tntnet needs cxxtools as a requirement. Tntnet itself can be used as a shared libraries and as a runtime environment like JavaServer Pages (JSP). Therefore, it is important to distinguish between a development platform and hosting (deployment) platform.

Typical structure of packages:




Tntdb requires a database (Oracle, SQLite, MySQL, Postgres) and can be configured for one specific database, e.g.: tntdb-sqlite, to avoid having all those databases installed.

Note: GNU/TLS, OpenSSL will be enabled in the source tarball configurations as standard.

back to top