-/*\r
-* Copyright (c) 2011 Sveriges Television AB <info@casparcg.com>\r
-*\r
-* This file is part of CasparCG (www.casparcg.com).\r
-*\r
-* CasparCG is free software: you can redistribute it and/or modify\r
-* it under the terms of the GNU General Public License as published by\r
-* the Free Software Foundation, either version 3 of the License, or\r
-* (at your option) any later version.\r
-*\r
-* CasparCG is distributed in the hope that it will be useful,\r
-* but WITHOUT ANY WARRANTY; without even the implied warranty of\r
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\r
-* GNU General Public License for more details.\r
-*\r
-* You should have received a copy of the GNU General Public License\r
-* along with CasparCG. If not, see <http://www.gnu.org/licenses/>.\r
-*\r
-* Author: Robert Nagy, ronag89@gmail.com\r
-*/\r
-\r
-#include "stdafx.h"\r
-\r
-#include "env.h"\r
-\r
-#include "../version.h"\r
-\r
-#include "exception\exceptions.h"\r
-#include "utility/string.h"\r
-\r
-#include <boost/property_tree/ptree.hpp>\r
-#include <boost/property_tree/xml_parser.hpp>\r
-#include <boost/filesystem.hpp>\r
-#include <boost/thread/once.hpp>\r
-\r
-#include <functional>\r
-#include <iostream>\r
-\r
-namespace caspar { namespace env {\r
-\r
-using namespace boost::filesystem2;\r
-\r
-std::wstring media;\r
-std::wstring log;\r
-std::wstring ftemplate;\r
-std::wstring data;\r
-boost::property_tree::wptree pt;\r
-\r
-void check_is_configured()\r
-{\r
- if(pt.empty())\r
- BOOST_THROW_EXCEPTION(invalid_operation() << msg_info("Enviroment properties has not been configured"));\r
-}\r
-\r
-void configure(const std::wstring& filename)\r
-{\r
- try\r
- {\r
- auto initialPath = boost::filesystem::initial_path<boost::filesystem2::wpath>().file_string();\r
- \r
- std::wifstream file(initialPath + L"\\" + filename);\r
- boost::property_tree::read_xml(file, pt, boost::property_tree::xml_parser::trim_whitespace | boost::property_tree::xml_parser::no_comments);\r
-\r
- auto paths = pt.get_child(L"configuration.paths");\r
- media = widen(paths.get(L"media-path", initialPath + L"\\media\\"));\r
- log = widen(paths.get(L"log-path", initialPath + L"\\log\\"));\r
- ftemplate = complete(wpath(widen(paths.get(L"template-path", initialPath + L"\\template\\")))).string(); \r
- data = widen(paths.get(L"data-path", initialPath + L"\\data\\"));\r
- }\r
- catch(...)\r
- {\r
- std::wcout << L" ### Invalid configuration file. ###";\r
- throw;\r
- }\r
-}\r
- \r
-const std::wstring& media_folder()\r
-{\r
- check_is_configured();\r
- return media;\r
-}\r
-\r
-const std::wstring& log_folder()\r
-{\r
- check_is_configured();\r
- return log;\r
-}\r
-\r
-const std::wstring& template_folder()\r
-{\r
- check_is_configured();\r
- return ftemplate;\r
-}\r
-\r
-const std::wstring& data_folder()\r
-{\r
- check_is_configured();\r
- return data;\r
-}\r
-\r
-const std::wstring& version()\r
-{\r
- static std::wstring ver = std::wstring(L"") + CASPAR_GEN + L"." + CASPAR_MAYOR + L"." + CASPAR_MINOR + L"." + CASPAR_REV + L" " + CASPAR_TAG;\r
- return ver;\r
-}\r
-\r
-const boost::property_tree::wptree& properties()\r
-{\r
- check_is_configured();\r
- return pt;\r
-}\r
-\r
-}}
\ No newline at end of file
+/*
+* Copyright (c) 2011 Sveriges Television AB <info@casparcg.com>
+*
+* This file is part of CasparCG (www.casparcg.com).
+*
+* CasparCG 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.
+*
+* CasparCG 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 CasparCG. If not, see <http://www.gnu.org/licenses/>.
+*
+* Author: Robert Nagy, ronag89@gmail.com
+*/
+
+#include "stdafx.h"
+
+#include "env.h"
+
+#include "../version.h"
+
+#include "except.h"
+#include "log.h"
+#include "string.h"
+#include "os/filesystem.h"
+
+#include <boost/property_tree/ptree.hpp>
+#include <boost/property_tree/xml_parser.hpp>
+#include <boost/filesystem.hpp>
+#include <boost/filesystem/fstream.hpp>
+#include <boost/thread/once.hpp>
+
+#include <functional>
+#include <iostream>
+#include <fstream>
+
+namespace caspar { namespace env {
+
+std::wstring media;
+std::wstring log;
+std::wstring ftemplate;
+std::wstring data;
+std::wstring font;
+std::wstring thumbnails;
+boost::property_tree::wptree pt;
+
+void check_is_configured()
+{
+ if(pt.empty())
+ CASPAR_THROW_EXCEPTION(invalid_operation() << msg_info(L"Enviroment properties has not been configured"));
+}
+
+void configure(const std::wstring& filename)
+{
+ try
+ {
+ auto initialPath = boost::filesystem::initial_path().wstring();
+
+ boost::filesystem::wifstream file(initialPath + L"/" + filename);
+ boost::property_tree::read_xml(file, pt, boost::property_tree::xml_parser::trim_whitespace | boost::property_tree::xml_parser::no_comments);
+
+ auto paths = pt.get_child(L"configuration.paths");
+ media = paths.get(L"media-path", initialPath + L"/media/");
+ log = paths.get(L"log-path", initialPath + L"/log/");
+ ftemplate = boost::filesystem::complete(paths.get(L"template-path", initialPath + L"/template/")).wstring();
+ data = paths.get(L"data-path", initialPath + L"/data/");
+ font = paths.get(L"font-path", initialPath + L"/font/");
+ thumbnails = paths.get(L"thumbnail-path", initialPath + L"/thumbnail/");
+ }
+ catch(...)
+ {
+ CASPAR_LOG(error) << L" ### Invalid configuration file. ###";
+ throw;
+ }
+
+ try
+ {
+ auto found_media_path = find_case_insensitive(media);
+ if (found_media_path)
+ media = *found_media_path;
+ else
+ boost::filesystem::create_directories(media);
+
+ auto found_template_path = find_case_insensitive(ftemplate);
+ if (found_template_path)
+ ftemplate = *found_template_path;
+ else
+ boost::filesystem::create_directories(ftemplate);
+
+ auto found_data_path = find_case_insensitive(data);
+ if (found_data_path)
+ data = *found_data_path;
+ else
+ boost::filesystem::create_directories(data);
+
+ auto found_font_path = find_case_insensitive(font);
+ if (found_font_path)
+ font = *found_font_path;
+ else
+ boost::filesystem::create_directories(font);
+
+ auto found_thumbnails_path = find_case_insensitive(thumbnails);
+ if (found_thumbnails_path)
+ thumbnails = *found_thumbnails_path;
+ else
+ boost::filesystem::create_directories(thumbnails);
+
+ auto found_log_path = find_case_insensitive(log);
+ if (found_log_path)
+ log = *found_log_path;
+ else if (!boost::filesystem::create_directories(log))
+ log = L"./";
+
+ //Make sure that all paths have a trailing slash
+ if(media.at(media.length()-1) != L'/')
+ media.append(L"/");
+ if(log.at(log.length()-1) != L'/')
+ log.append(L"/");
+ if(ftemplate.at(ftemplate.length()-1) != L'/')
+ ftemplate.append(L"/");
+ if(data.at(data.length()-1) != L'/')
+ data.append(L"/");
+ if(font.at(font.length()-1) != L'/')
+ font.append(L"/");
+ if(thumbnails.at(thumbnails.length()-1) != L'/')
+ thumbnails.append(L"/");
+
+ try
+ {
+ auto initialPath = boost::filesystem::initial_path().wstring();
+
+ for(auto it = boost::filesystem::directory_iterator(initialPath); it != boost::filesystem::directory_iterator(); ++it)
+ {
+ if(it->path().wstring().find(L".fth") != std::wstring::npos)
+ {
+ auto from_path = *it;
+ auto to_path = boost::filesystem::path(ftemplate + L"/" + it->path().wstring());
+
+ if(boost::filesystem::exists(to_path))
+ boost::filesystem::remove(to_path);
+
+ boost::filesystem::copy_file(from_path, to_path);
+ }
+ }
+ }
+ catch(...)
+ {
+ CASPAR_LOG_CURRENT_EXCEPTION();
+ CASPAR_LOG(error) << L"Failed to copy template-hosts from initial-path to template-path.";
+ }
+ }
+ catch(...)
+ {
+ CASPAR_LOG_CURRENT_EXCEPTION();
+ CASPAR_LOG(error) << L"Failed to create configured directories.";
+ }
+}
+
+const std::wstring& media_folder()
+{
+ check_is_configured();
+ return media;
+}
+
+const std::wstring& log_folder()
+{
+ check_is_configured();
+ return log;
+}
+
+const std::wstring& template_folder()
+{
+ check_is_configured();
+ return ftemplate;
+}
+
+const std::wstring& data_folder()
+{
+ check_is_configured();
+ return data;
+}
+
+const std::wstring& font_folder()
+{
+ check_is_configured();
+ return font;
+}
+
+const std::wstring& thumbnails_folder()
+{
+ check_is_configured();
+ return thumbnails;
+}
+
+#define QUOTE(str) #str
+#define EXPAND_AND_QUOTE(str) QUOTE(str)
+
+const std::wstring& version()
+{
+ static std::wstring ver = u16(
+ EXPAND_AND_QUOTE(CASPAR_GEN) "."
+ EXPAND_AND_QUOTE(CASPAR_MAYOR) "."
+ EXPAND_AND_QUOTE(CASPAR_MINOR) "."
+ CASPAR_REV " "
+ CASPAR_TAG);
+ return ver;
+}
+
+const boost::property_tree::wptree& properties()
+{
+ check_is_configured();
+ return pt;
+}
+
+}}