Mercurial > hg > orthanc
changeset 1224:29cf3dd2cea4
removal of Plustache experiments
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 12 Nov 2014 14:05:02 +0100 |
parents | 5bd4c9f85b4c |
children | 4c649dbeb61a |
files | CMakeLists.txt Resources/CMake/PlustacheConfiguration.cmake Resources/CMake/PlustacheConfiguration.patch UnitTestsSources/PlustacheTests.cpp |
diffstat | 4 files changed, 0 insertions(+), 200 deletions(-) [+] |
line wrap: on
line diff
--- a/CMakeLists.txt Wed Nov 12 11:52:40 2014 +0100 +++ b/CMakeLists.txt Wed Nov 12 14:05:02 2014 +0100 @@ -37,9 +37,7 @@ SET(USE_SYSTEM_PUGIXML ON CACHE BOOL "Use the system version of Pugixml)") # Experimental options -SET(USE_PLUSTACHE OFF CACHE BOOL "Use the Plustache templating engine (experimental)") SET(USE_PUGIXML ON CACHE BOOL "Use the Pugixml parser (turn off only for debug)") -SET(USE_SYSTEM_PLUSTACHE OFF CACHE BOOL "Use the system version of Plustache (experimental)") # Distribution-specific settings SET(USE_GTEST_DEBIAN_SOURCE_PACKAGE OFF CACHE BOOL "Use the sources of Google Test shipped with libgtest-dev (Debian only)") @@ -198,7 +196,6 @@ UnitTestsSources/ImageProcessingTests.cpp UnitTestsSources/JpegLosslessTests.cpp UnitTestsSources/PluginsTests.cpp - UnitTestsSources/PlustacheTests.cpp ) @@ -229,7 +226,6 @@ include(${CMAKE_SOURCE_DIR}/Resources/CMake/LibPngConfiguration.cmake) include(${CMAKE_SOURCE_DIR}/Resources/CMake/LuaConfiguration.cmake) include(${CMAKE_SOURCE_DIR}/Resources/CMake/LibCurlConfiguration.cmake) -include(${CMAKE_SOURCE_DIR}/Resources/CMake/PlustacheConfiguration.cmake) include(${CMAKE_SOURCE_DIR}/Resources/CMake/PugixmlConfiguration.cmake)
--- a/Resources/CMake/PlustacheConfiguration.cmake Wed Nov 12 11:52:40 2014 +0100 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,34 +0,0 @@ -if (USE_PLUSTACHE) - add_definitions(-DORTHANC_PLUSTACHE_ENABLED=1) - - if (STATIC_BUILD OR NOT USE_SYSTEM_PLUSTACHE) - set(PLUSTACHE_SOURCES_DIR ${CMAKE_BINARY_DIR}/plustache-0.3.0) - DownloadPackage( - "6162946bdb3dccf3b2185fcf149671ee" - "http://www.montefiore.ulg.ac.be/~jodogne/Orthanc/ThirdPartyDownloads/plustache-0.3.0.tar.gz" - "${PLUSTACHE_SOURCES_DIR}") - - list(APPEND THIRD_PARTY_SOURCES - ${PLUSTACHE_SOURCES_DIR}/src/context.cpp - ${PLUSTACHE_SOURCES_DIR}/src/template.cpp - ) - - include_directories( - ${PLUSTACHE_SOURCES_DIR} - ) - - execute_process( - COMMAND patch -p0 -i ${ORTHANC_ROOT}/Resources/CMake/PlustacheConfiguration.patch - WORKING_DIRECTORY ${CMAKE_BINARY_DIR} - ) - - source_group(ThirdParty\\Plustache REGULAR_EXPRESSION ${PLUSTACHE_SOURCES_DIR}/.*) - - else() - message(FATAL_ERROR "Dynamic linking against plustache not implemented (a patch is required)") - endif() - -else() - add_definitions(-DORTHANC_PLUSTACHE_ENABLED=0) - -endif()
--- a/Resources/CMake/PlustacheConfiguration.patch Wed Nov 12 11:52:40 2014 +0100 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,42 +0,0 @@ -diff -r -u plustache-0.3.0.orig/include/template.hpp plustache-0.3.0/include/template.hpp ---- plustache-0.3.0.orig/include/template.hpp 2014-01-29 13:26:52.000000000 +0100 -+++ plustache-0.3.0/include/template.hpp 2014-05-28 17:51:51.623305914 +0200 -@@ -21,7 +21,7 @@ - public: - template_t (); - template_t (std::string& tmpl_path); -- ~template_t (); -+ virtual ~template_t (); - std::string render(const std::string& tmplate, const Context& ctx); - std::string render(const std::string& tmplate, const ObjectType& ctx); - -@@ -42,11 +42,13 @@ - std::string render_sections(const std::string& tmplate, - const Context& ctx); - std::string html_escape(const std::string& s); -- std::string get_partial(const std::string& partial) const; - void change_delimiter(const std::string& opentag, - const std::string& closetag); - void compile_data(); -- std::string get_template(const std::string& tmpl); -+ -+ protected: -+ virtual std::string get_partial(const std::string& partial) const; -+ virtual std::string get_template(const std::string& tmpl); - }; - } // namespace Plustache - #endif -Only in plustache-0.3.0/include: template.hpp~ -diff -r -u plustache-0.3.0.orig/src/template.cpp plustache-0.3.0/src/template.cpp ---- plustache-0.3.0.orig/src/template.cpp 2014-01-29 13:26:52.000000000 +0100 -+++ plustache-0.3.0/src/template.cpp 2014-05-28 17:51:32.599306393 +0200 -@@ -126,7 +126,7 @@ - // found a partial - else if (modifier == ">") - { -- std::string partial = template_t::get_partial(key); -+ std::string partial = get_partial(key); - repl.assign(template_t::render(partial, ctx)); - } - // normal tag -Only in plustache-0.3.0/src: template.cpp~
--- a/UnitTestsSources/PlustacheTests.cpp Wed Nov 12 11:52:40 2014 +0100 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,120 +0,0 @@ -/** - * Orthanc - A Lightweight, RESTful DICOM Store - * Copyright (C) 2012-2014 Medical Physics Department, CHU of Liege, - * Belgium - * - * This program is free software: you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation, either version 3 of the - * License, or (at your option) any later version. - * - * In addition, as a special exception, the copyright holders of this - * program give permission to link the code of its release with the - * OpenSSL project's "OpenSSL" library (or with modified versions of it - * that use the same license as the "OpenSSL" library), and distribute - * the linked executables. You must obey the GNU General Public License - * in all respects for all of the code used other than "OpenSSL". If you - * modify file(s) with this exception, you may extend this exception to - * your version of the file(s), but you are not obligated to do so. If - * you do not wish to do so, delete this exception statement from your - * version. If you delete this exception statement from all source files - * in the program, then also delete it here. - * - * This program is distributed in the hope that it will be useful, but - * WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see <http://www.gnu.org/licenses/>. - **/ - - -#include "PrecompiledHeadersUnitTests.h" -#include "gtest/gtest.h" - -#if ORTHANC_PLUSTACHE_ENABLED == 1 - -#include <include/template.hpp> - -class OrthancPlustache : public Plustache::template_t -{ -public: -protected: - virtual std::string get_template(const std::string& tmpl) - { - //printf("OK [%s]\n", tmpl.c_str()); - return Plustache::template_t::get_template(tmpl); - } - - virtual std::string get_partial(const std::string& partial) const - { - //printf("OK2 [%s]\n", partial.c_str()); - //return Plustache::template_t::get_partial(partial); - return "<li>{{name}}</li>"; - } -}; - - -TEST(Plustache, Basic1) -{ - PlustacheTypes::ObjectType ctx; - ctx["title"] = "About"; - - OrthancPlustache t; - ASSERT_EQ("<h1>About</h1>", t.render("<h1>{{title}}</h1>", ctx)); -} - - -TEST(Plustache, Basic2) -{ - Plustache::Context ctx; - ctx.add("title", "About"); - - OrthancPlustache t; - ASSERT_EQ("<h1>About</h1>", t.render("<h1>{{title}}</h1>", ctx)); -} - - -TEST(Plustache, Context) -{ - PlustacheTypes::ObjectType a; - a["name"] = "Orthanc"; - - PlustacheTypes::ObjectType b; - b["name"] = "Jodogne"; - - PlustacheTypes::CollectionType c; - c.push_back(a); - c.push_back(b); - - Plustache::Context ctx; - ctx.add("items", c); - - OrthancPlustache t; - ASSERT_EQ("<ul><li>Orthanc</li><li>Jodogne</li></ul>", - t.render("<ul>{{#items}}<li>{{name}}</li>{{/items}}</ul>", ctx)); -} - - -TEST(Plustache, Partials) -{ - PlustacheTypes::ObjectType a; - a["name"] = "Orthanc"; - - PlustacheTypes::ObjectType b; - b["name"] = "Jodogne"; - - PlustacheTypes::CollectionType c; - c.push_back(a); - c.push_back(b); - - Plustache::Context ctx; - ctx.add("items", c); - - OrthancPlustache t; - ASSERT_EQ("<ul><li>Orthanc</li><li>Jodogne</li></ul>", - t.render("<ul>{{#items}}{{>partial}}{{/items}}</ul>", ctx)); -} - -#endif