Files
quickbook/code_snippet_actions.cpp
2010-04-05 19:43:14 +00:00

100 lines
3.2 KiB
C++

/*=============================================================================
Copyright (c) 2002 2004 2006 Joel de Guzman
Copyright (c) 2004 Eric Niebler
Copyright (c) 2005 Thomas Guest
Copyright (c) 2010 Daniel James
http://spirit.sourceforge.net/
Use, modification and distribution is subject to the Boost Software
License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
http://www.boost.org/LICENSE_1_0.txt)
=============================================================================*/
#include <numeric>
#include <functional>
#include <algorithm>
#include <iterator>
#include <boost/lexical_cast.hpp>
#include "utils.hpp"
#include "grammars.hpp"
#include "code_snippet_types.hpp"
#include "template.hpp"
namespace quickbook
{
void code_snippet_actions::process_action::operator()(char x, unused_type, unused_type) const
{
actions.code += x;
}
namespace detail
{
int callout_id = 0;
}
void code_snippet_actions::process_action::operator()(callout const& x, unused_type, unused_type) const
{
using detail::callout_id;
callout_source item;
item.identifier = std::string(actions.doc_id.begin(), actions.doc_id.end());
item.identifier += boost::lexical_cast<std::string>(callout_id + actions.callouts.size());
item.body = template_value(x.position, x.content);
actions.code += "``[[callout]";
actions.code += x.role;
actions.code += " ";
actions.code += item.identifier;
actions.code += "]``";
actions.callouts.push_back(item);
}
void code_snippet_actions::process_action::operator()(escaped_comment const& x, unused_type, unused_type) const
{
if (!actions.code.empty())
{
detail::unindent(actions.code); // remove all indents
if (actions.code.size() != 0)
{
actions.snippet += "\n\n";
actions.snippet += actions.source_type;
actions.snippet += "``\n" + actions.code + "``\n\n";
actions.code.clear();
}
}
std::string temp(x.content);
detail::unindent(temp); // remove all indents
if (temp.size() != 0)
{
actions.snippet += "\n" + temp; // add a linebreak to allow block marskups
}
}
void code_snippet_actions::output_action::operator()(code_snippet const& x, unused_type, unused_type) const
{
using detail::callout_id;
if (!actions.code.empty())
{
detail::unindent(actions.code); // remove all indents
if (actions.code.size() != 0)
{
actions.snippet += "\n\n";
actions.snippet += actions.source_type;
actions.snippet += "```\n" + actions.code + "```\n\n";
}
}
std::vector<std::string> empty_params;
define_template d(x.identifier, empty_params,
template_value(x.position, actions.snippet));
d.callouts = actions.callouts;
actions.storage.push_back(d);
callout_id += actions.callouts.size();
actions.callouts.clear();
actions.code.clear();
actions.snippet.clear();
}
}