From 9cbb259817d3bdc31e7d4bea258d43ebdfe307f3 Mon Sep 17 00:00:00 2001 From: Klaas Freitag Date: Fri, 4 Sep 2015 16:04:56 +0200 Subject: [PATCH] New github friendly README file with links to the html docs. --- README.md | 67 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 67 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..306737d --- /dev/null +++ b/README.md @@ -0,0 +1,67 @@ +Welcome to the C++ CTemplate system! +==================================== + +This library provides an easy to use and lightning fast text templating system +to use with C++ programs. + +It was originally called Google Templates, due to its origin as the template +system used for Google search result pages. Now it has a more general name +matching its community-owned nature. + +Documentation +------------- + +Refer to the [Project +Documentation]() +to learn how to use the CTemplate system. + +There is also a +[HOWTO]() +and +[Examples](). + +Compiling +--------- + +To compile test applications with these classes, run `./configure` followed by +`make` on unixoid platforms like Linux or MacOSX. + +To install these header files on your system, run `make install`. + +See INSTALL for more details. + +This code should work on any modern C++ system. It has been tested on Linux +(Ubuntu, Fedora, RedHat), Solaris 10 x86, FreeBSD 6.0, OS X 10.3 and 10.4, and +Windows under both VC++7 and VC++8. + +There are a few Windows-specific details; see README.windows for more +information. + +CTemplate and Threads +--------------------- + +The ctemplate library has thread support, so it works properly in a threaded +environment. + +For this to work, if you link libraries with `-lctemplate` you may also need to +add `-pthread` (or, on some systems, `-pthreads`, and on others, `-lpthread`) to +get the library to compile. If you leave out the `-pthread`, you'll see errors +like this: + +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +symbol lookup error: /usr/local/lib/libctemplate.so.0: undefined symbol: pthread_rwlock_init +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +If your code isn't multi-threaded, you can instead use the ctemplate\_nothread +library: `-lctemplate_nothreads` + +To summarize, there are two ways to link in ctemlpate in non-threaded +applications. For instance: + +1. Thread safe build:`gcc -o my_app my_app.o -lctemplate -pthread` + +2. Unthreaded code:`gcc -o my_app my_app.o -lctemplate_nothreads` + +If your application uses threads, you should use form (1). + +