mirror of
https://github.com/KingDuckZ/kamokan.git
synced 2025-01-13 19:56:40 +00:00
105 lines
3.2 KiB
C++
105 lines
3.2 KiB
C++
/* Copyright 2017, Michele Santullo
|
|
* This file is part of "tawashi".
|
|
*
|
|
* "tawashi" 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.
|
|
*
|
|
* "tawashi" 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 "tawashi". If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "pastie_response.hpp"
|
|
#include "incredis/incredis.hpp"
|
|
#include "settings_bag.hpp"
|
|
#include "escapist.hpp"
|
|
#include "cgi_env.hpp"
|
|
#include <ciso646>
|
|
#include <srchilite/sourcehighlight.h>
|
|
#include <srchilite/langmap.h>
|
|
#include <sstream>
|
|
|
|
namespace tawashi {
|
|
namespace {
|
|
const char g_nolang_token[] = "plaintext";
|
|
} //unnamed namespace
|
|
|
|
PastieResponse::PastieResponse (
|
|
const Kakoune::SafePtr<SettingsBag>& parSettings,
|
|
std::ostream* parStreamOut,
|
|
const Kakoune::SafePtr<cgi::Env>& parCgiEnv
|
|
) :
|
|
Response(parSettings, parStreamOut, parCgiEnv, true),
|
|
m_langmap_dir(parSettings->as<std::string>("langmap_dir")),
|
|
m_plain_text(false),
|
|
m_syntax_highlight(true)
|
|
{
|
|
}
|
|
|
|
void PastieResponse::on_process() {
|
|
auto env = cgi_env().query_string_split();
|
|
const std::string& query_str(cgi_env().query_string());
|
|
if (env["m"] == "plain" or query_str.empty()) {
|
|
this->change_type(Response::ContentType, "text/plain; charset=utf-8");
|
|
m_plain_text = true;
|
|
}
|
|
else if (query_str == g_nolang_token) {
|
|
m_syntax_highlight = false;
|
|
}
|
|
else {
|
|
srchilite::LangMap lang_map(m_langmap_dir, "lang.map");
|
|
lang_map.open();
|
|
m_lang_file.clear();
|
|
if (not query_str.empty())
|
|
m_lang_file = lang_map.getFileName(query_str);
|
|
if (m_lang_file.empty())
|
|
m_lang_file = "default.lang";
|
|
}
|
|
}
|
|
|
|
void PastieResponse::on_mustache_prepare (mstch::map& parContext) {
|
|
using opt_string = redis::IncRedis::opt_string;
|
|
using opt_string_list = redis::IncRedis::opt_string_list;
|
|
|
|
auto token = boost::string_ref(cgi_env().path_info()).substr(1);
|
|
auto& redis = this->redis();
|
|
opt_string_list pastie_reply = redis.hmget(token, "pastie");
|
|
opt_string pastie = (pastie_reply and not pastie_reply->empty() ? (*pastie_reply)[0] : opt_string());
|
|
|
|
srchilite::SourceHighlight highlighter;
|
|
highlighter.setDataDir(settings().as<std::string>("langmap_dir"));
|
|
highlighter.setGenerateEntireDoc(false);
|
|
highlighter.setGenerateLineNumbers(true);
|
|
|
|
std::string processed_pastie;
|
|
if (m_syntax_highlight) {
|
|
processed_pastie = std::move(*pastie);
|
|
}
|
|
else {
|
|
Escapist houdini;
|
|
processed_pastie = houdini.escape_html(*pastie);
|
|
}
|
|
|
|
if (not m_plain_text and m_syntax_highlight) {
|
|
std::istringstream iss(std::move(processed_pastie));
|
|
std::ostringstream oss;
|
|
highlighter.highlight(iss, oss, m_lang_file);
|
|
processed_pastie = oss.str();
|
|
}
|
|
|
|
parContext["pastie"] = std::move(processed_pastie);
|
|
}
|
|
|
|
std::string PastieResponse::on_mustache_retrieve() {
|
|
if (m_plain_text)
|
|
return "{{pastie}}";
|
|
else
|
|
return load_mustache();
|
|
}
|
|
} //namespace tawashi
|