mirror of
https://github.com/triqs/dft_tools
synced 2025-01-14 06:45:59 +01:00
3fe400d34c
- examples split from the rst file using a python script (split_code). - Final result for the doc is unchanged. - examples are compiled and tested with the other tests. - examples' code have been clang-formatted, with triqs style. - doc compiles much faster, and with the same options as the rest of the test. - examples are added as tests, so they are run by make test, as simple C tests. - done for the tutorials and the reference. - autocompile removed (changed into triqs_example directive). - add triqs_example : - make a literal include of the source code. - runs the compiled example - add, as before, the result to the source code in the doc. - added the script split_code, used to make the changes automatically, maybe for later reuse. (in _tools)
33 lines
914 B
C++
33 lines
914 B
C++
#include <triqs/clef.hpp>
|
|
#include <iostream>
|
|
|
|
// a simple foo function
|
|
double foo(double x) { return x / 2; }
|
|
int foo(int x) { return x * 2; }
|
|
|
|
// a more complex case : bar is already a template
|
|
// we have to disable it for CLEF expression to avoid ambiguity
|
|
|
|
// C++14 clean syntax will be (using concepts)
|
|
// template<NotClefExpression T>
|
|
// T bar (T const & x) { return x+1;}
|
|
|
|
// C++11 workaround
|
|
template <typename T> typename std::enable_if<!triqs::clef::is_clef_expression<T>::value, T>::type bar(T const& x) {
|
|
return x + 1;
|
|
}
|
|
|
|
namespace triqs {
|
|
namespace clef {
|
|
TRIQS_CLEF_MAKE_FNT_LAZY(foo);
|
|
TRIQS_CLEF_MAKE_FNT_LAZY(bar);
|
|
}
|
|
}
|
|
|
|
int main() {
|
|
triqs::clef::placeholder<3> x_;
|
|
std::cout << foo(2.0) << " " << eval(x_ + foo(x_), x_ = 3) << " " << eval(x_ + foo(x_), x_ = 3.5) << std::endl;
|
|
std::cout << bar(2.0) << " " << eval(x_ + bar(x_), x_ = 3) << " " << eval(x_ + bar(x_), x_ = 3.5) << std::endl;
|
|
}
|
|
|