FIXED SOME TABULATION BUGS, DO NOT LOOK AT MY PREVIOUS SYSTEM
This commit is contained in:
parent
b8adc5bd55
commit
28dec5384c
@ -1,3 +0,0 @@
|
|||||||
{% ELDEF main %}
|
|
||||||
AAAAAAAA
|
|
||||||
{% ENDELDEF %}
|
|
@ -87,4 +87,9 @@ namespace nytl {
|
|||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void rstrip(std::string &str) {
|
||||||
|
while (!str.empty() && isSPACE(str.back()))
|
||||||
|
str.resize(str.size() - 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
#ifndef NEW_YORK_TRANSIT_LINE_ALOTALOT_H
|
#ifndef NEW_YORK_TRANSIT_LINE_ALOTALOT_H
|
||||||
#define NEW_YORK_TRANSIT_LINE_ALOTALOT_H
|
#define NEW_YORK_TRANSIT_LINE_ALOTALOT_H
|
||||||
|
|
||||||
/* A little of this, a little of that
|
|
||||||
* DO NOT EXPORT THIS FILE */
|
|
||||||
|
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
|
/* A little of this, a little of that
|
||||||
|
* DO NOT EXPORT THIS FILE */
|
||||||
|
|
||||||
namespace nytl {
|
namespace nytl {
|
||||||
template<typename T>
|
template<typename T>
|
||||||
using uptr = std::unique_ptr<T>;
|
using uptr = std::unique_ptr<T>;
|
||||||
@ -46,6 +46,8 @@ namespace nytl {
|
|||||||
bool is_uname_dotted_sequence(const std::string& uinp);
|
bool is_uname_dotted_sequence(const std::string& uinp);
|
||||||
|
|
||||||
std::string make_uppercase(const std::string& source);
|
std::string make_uppercase(const std::string& source);
|
||||||
|
|
||||||
|
void rstrip(std::string& str);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -4,7 +4,11 @@
|
|||||||
#include "templater.h"
|
#include "templater.h"
|
||||||
#include <functional>
|
#include <functional>
|
||||||
|
|
||||||
|
/* Do not export this header */
|
||||||
|
|
||||||
namespace nytl {
|
namespace nytl {
|
||||||
|
void debug_print_templater(const Templater& T);
|
||||||
|
|
||||||
/* ============== For parsing =============================*/
|
/* ============== For parsing =============================*/
|
||||||
void parse_bare_file(const std::string& filename, const std::string& content,
|
void parse_bare_file(const std::string& filename, const std::string& content,
|
||||||
global_elem_set_t& result);
|
global_elem_set_t& result);
|
||||||
|
49
src/http_server/new_york_transit_line/debug_print.cpp
Normal file
49
src/http_server/new_york_transit_line/debug_print.cpp
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
#include "templater.h"
|
||||||
|
#include "alotalot.h"
|
||||||
|
#include "jsonincpp/string_representation.h"
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
namespace nytl {
|
||||||
|
void debug_print_templater(const Templater& T) {
|
||||||
|
printf("===== TEMPLATER INTERNAL RESOURCES =====\n");
|
||||||
|
for (auto& p: T.elements) {
|
||||||
|
printf("=== %s element =====\n", p.first.c_str());
|
||||||
|
const Element& el = p.second;
|
||||||
|
printf("%s, %s\n", el.base ? "BASE" : "NOT BASE", el.is_hidden ? "HIDDEN" : "NOT HIDDEN");
|
||||||
|
if (!el.is_hidden) {
|
||||||
|
std::string signature;
|
||||||
|
for (const json::JSON& arg_type: el.arguments) {
|
||||||
|
if (!signature.empty())
|
||||||
|
signature += " ";
|
||||||
|
signature += json::generate_str(arg_type, json::print_compact);
|
||||||
|
}
|
||||||
|
printf("Signature: %s\n", signature.c_str());
|
||||||
|
}
|
||||||
|
for (const ElementPart& part: el.parts) {
|
||||||
|
if (part.type == ElementPart::p_code) {
|
||||||
|
printf("code: <b><e><f><o><r><e><><l><f>\n%s\n<a><f><t><e><r><><l><f>\n", part.when_code.lines.c_str());
|
||||||
|
} else if (part.type == ElementPart::p_for_put) {
|
||||||
|
const ElementPart::when_for_put_S& P = part.when_for_put;
|
||||||
|
printf("dor cycle call:\ninternal_element: %s,\nref_over:%s,\nwhere_key_var: %ld, where_value_var: %ld, %s\n",
|
||||||
|
P.internal_element.c_str(), json::generate_str(P.ref_over, json::print_pretty).c_str(),
|
||||||
|
P.where_key_var, P.where_value_var, P.line_feed ? "LF" : "NOLF");
|
||||||
|
} else if (part.type == ElementPart::p_ref_put) {
|
||||||
|
const ElementPart::when_ref_put_S& P = part.when_ref_put;
|
||||||
|
printf("ref block call:\ninternal_element: %s\nref_over:%s\n",
|
||||||
|
P.internal_element.c_str(), json::generate_str(P.ref_over, json::print_pretty).c_str());
|
||||||
|
} else {
|
||||||
|
assert(part.type == ElementPart::p_put);
|
||||||
|
const ElementPart::when_put_S& P = part.when_put;
|
||||||
|
printf("PUT:\ncalled_element: %s\n",
|
||||||
|
json::generate_str(P.called_element, json::print_pretty).c_str());
|
||||||
|
for (size_t i = 0; i < P.passed_arguments.size(); i++) {
|
||||||
|
printf("passed_arguments[%lu] = %s\n", i,
|
||||||
|
json::generate_str(P.passed_arguments[i], json::print_pretty).c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
printf("=== That was element %s ====\n", p.first.c_str());
|
||||||
|
}
|
||||||
|
printf("===== DEBUG IS OVER =====\n");
|
||||||
|
}
|
||||||
|
}
|
@ -3,6 +3,7 @@
|
|||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
namespace nytl {
|
namespace nytl {
|
||||||
|
/* Expression Execution Frame */
|
||||||
struct EEFrame {
|
struct EEFrame {
|
||||||
const json::JSON& expr;
|
const json::JSON& expr;
|
||||||
LocalVarValue& result;
|
LocalVarValue& result;
|
||||||
|
@ -16,11 +16,6 @@ namespace nytl {
|
|||||||
return first_nw_char(str) == str.size();
|
return first_nw_char(str) == str.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
void rstrip(std::string& str) {
|
|
||||||
while (!str.empty() && isSPACE(str.back()))
|
|
||||||
str.resize(str.size() - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string clement_lstrip(const std::string& str) {
|
std::string clement_lstrip(const std::string& str) {
|
||||||
size_t gone = 0;
|
size_t gone = 0;
|
||||||
size_t n = str.size();
|
size_t n = str.size();
|
||||||
@ -28,10 +23,10 @@ namespace nytl {
|
|||||||
if (str[i] == '\n') {
|
if (str[i] == '\n') {
|
||||||
gone = i + 1;
|
gone = i + 1;
|
||||||
} else if (!isSPACE(str[i])) {
|
} else if (!isSPACE(str[i])) {
|
||||||
return str.substr(gone);
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return "";
|
return str.substr(gone);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct ParsingContext {
|
struct ParsingContext {
|
||||||
@ -125,22 +120,29 @@ namespace nytl {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void one_part_update_min_start_wsp_non_empty(const std::string& str, bool is_first, size_t& min) {
|
bool is_relevant_in_tab_cut(size_t PN, size_t I, size_t LN, size_t j, const std::string& line) {
|
||||||
|
if (j == 0 && I != 0)
|
||||||
|
return false;
|
||||||
|
if (!is_space_only(line))
|
||||||
|
return true;
|
||||||
|
return j + 1 == LN && I + 1 < PN;
|
||||||
|
}
|
||||||
|
|
||||||
|
void one_part_update_min_start_wsp_non_empty(const std::string& str, size_t I, size_t PN, size_t& min) {
|
||||||
std::vector<std::string> lines = splitIntoLines(str);
|
std::vector<std::string> lines = splitIntoLines(str);
|
||||||
size_t L = lines.size();
|
size_t LN = lines.size();
|
||||||
for (size_t i = is_first ? 0 : 1; i < L; i++) {
|
for (size_t j = 0; j < LN; j++) {
|
||||||
size_t first_nw = first_nw_char(lines[i]);
|
if (is_relevant_in_tab_cut(PN, I, LN, j, lines[j]))
|
||||||
if (first_nw < lines[i].size())
|
min = std::min(min, first_nw_char(lines[j]));
|
||||||
min = std::min(min, first_nw);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string one_part_cut_excess_tab(const std::string& str, bool is_first, size_t cut) {
|
std::string one_part_cut_excess_tab(const std::string& str, size_t I, size_t PN, size_t cut) {
|
||||||
std::vector<std::string> lines = splitIntoLines(str);
|
std::vector<std::string> lines = splitIntoLines(str);
|
||||||
size_t L = lines.size();
|
size_t LN = lines.size();
|
||||||
for (size_t i = is_first ? 0 : 1; i < L; i++) {
|
for (size_t j = 0; j < LN; j++) {
|
||||||
if (!is_space_only(lines[i]))
|
if (is_relevant_in_tab_cut(PN, I, LN, j, lines[j]))
|
||||||
lines[i] = lines[i].substr(cut);
|
lines[j] = lines[j].substr(cut);
|
||||||
}
|
}
|
||||||
return concatenateLines(lines);
|
return concatenateLines(lines);
|
||||||
}
|
}
|
||||||
@ -149,17 +151,17 @@ namespace nytl {
|
|||||||
global_elem_set_t& result)
|
global_elem_set_t& result)
|
||||||
{
|
{
|
||||||
ASSERT(result.count(filename) == 0, "Repeated element " + filename);
|
ASSERT(result.count(filename) == 0, "Repeated element " + filename);
|
||||||
std::string P = clement_lstrip(content);
|
std::string txt = clement_lstrip(content);
|
||||||
rstrip(P);
|
rstrip(txt);
|
||||||
size_t cut = 9999999999999;
|
size_t cut = 9999999999999;
|
||||||
one_part_update_min_start_wsp_non_empty(P, true, cut);
|
one_part_update_min_start_wsp_non_empty(txt, 0, 1, cut);
|
||||||
P = one_part_cut_excess_tab(P, true, cut);
|
txt = one_part_cut_excess_tab(txt, 0, 1, cut);
|
||||||
Element& el = result[filename];
|
Element& el = result[filename];
|
||||||
el.parts = {ElementPart{element_part_types::code}};
|
el.parts = {ElementPart{}};
|
||||||
el.parts[0].when_code.lines = mv(P);
|
el.parts[0].when_code.lines = mv(txt);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This function parses variable type */
|
/* Type parsing frame */
|
||||||
struct TPFrame {
|
struct TPFrame {
|
||||||
json::JSON& result;
|
json::JSON& result;
|
||||||
|
|
||||||
@ -206,6 +208,7 @@ namespace nytl {
|
|||||||
/* From arg name to arg ID */
|
/* From arg name to arg ID */
|
||||||
typedef std::map<std::string, size_t> arg_name_list_t;
|
typedef std::map<std::string, size_t> arg_name_list_t;
|
||||||
|
|
||||||
|
/* Expression parsing frame */
|
||||||
struct EPFrame {
|
struct EPFrame {
|
||||||
json::JSON& result;
|
json::JSON& result;
|
||||||
|
|
||||||
@ -295,6 +298,7 @@ namespace nytl {
|
|||||||
return peep(ctx) == syntax.magic_block_end[0];
|
return peep(ctx) == syntax.magic_block_end[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Element content parsing frame */
|
||||||
struct ECPFrame {
|
struct ECPFrame {
|
||||||
enum block_type{
|
enum block_type{
|
||||||
gone_for_nothing,
|
gone_for_nothing,
|
||||||
@ -322,7 +326,7 @@ namespace nytl {
|
|||||||
uptr<ECPFrame> toMe(bool returned, ParsingContext& ctx, const TemplaterSettings& syntax, global_elem_set_t& elem_ns) {
|
uptr<ECPFrame> toMe(bool returned, ParsingContext& ctx, const TemplaterSettings& syntax, global_elem_set_t& elem_ns) {
|
||||||
if (returned) {
|
if (returned) {
|
||||||
if (stopped_for == gone_for_for) {
|
if (stopped_for == gone_for_for) {
|
||||||
assert(result.parts.back().type == element_part_type_t::for_put);
|
assert(result.parts.back().type == ElementPart::p_for_put);
|
||||||
if (ret_data_int == 1)
|
if (ret_data_int == 1)
|
||||||
result.parts.back().when_for_put.line_feed = false;
|
result.parts.back().when_for_put.line_feed = false;
|
||||||
else if (ret_data_int == 2)
|
else if (ret_data_int == 2)
|
||||||
@ -344,7 +348,7 @@ namespace nytl {
|
|||||||
std::string op = make_uppercase(readName(ctx));
|
std::string op = make_uppercase(readName(ctx));
|
||||||
if (op == "FOR") {
|
if (op == "FOR") {
|
||||||
result.parts.emplace_back();
|
result.parts.emplace_back();
|
||||||
result.parts.back().type = element_part_type_t::for_put;
|
result.parts.back().type = ElementPart::p_for_put;
|
||||||
ElementPart::when_for_put_S& P = result.parts.back().when_for_put;
|
ElementPart::when_for_put_S& P = result.parts.back().when_for_put;
|
||||||
skipWhitespace(ctx);
|
skipWhitespace(ctx);
|
||||||
std::string V1 = readName(ctx);
|
std::string V1 = readName(ctx);
|
||||||
@ -387,7 +391,7 @@ namespace nytl {
|
|||||||
}
|
}
|
||||||
if (op == "REF") {
|
if (op == "REF") {
|
||||||
result.parts.emplace_back();
|
result.parts.emplace_back();
|
||||||
result.parts.back().type = element_part_type_t::ref_put;
|
result.parts.back().type = ElementPart::p_ref_put;
|
||||||
ElementPart::when_ref_put_S& P = result.parts.back().when_ref_put;
|
ElementPart::when_ref_put_S& P = result.parts.back().when_ref_put;
|
||||||
skipWhitespace(ctx);
|
skipWhitespace(ctx);
|
||||||
std::string Vn = readName(ctx);
|
std::string Vn = readName(ctx);
|
||||||
@ -411,7 +415,7 @@ namespace nytl {
|
|||||||
}
|
}
|
||||||
if (op == "PUT") {
|
if (op == "PUT") {
|
||||||
result.parts.emplace_back();
|
result.parts.emplace_back();
|
||||||
result.parts.back().type = element_part_type_t::put;
|
result.parts.back().type = ElementPart::p_put;
|
||||||
ElementPart::when_put_S& P = result.parts.back().when_put;
|
ElementPart::when_put_S& P = result.parts.back().when_put;
|
||||||
skipWhitespace(ctx);
|
skipWhitespace(ctx);
|
||||||
P.called_element = parse_expression(ctx, local_var_names);
|
P.called_element = parse_expression(ctx, local_var_names);
|
||||||
@ -427,7 +431,7 @@ namespace nytl {
|
|||||||
}
|
}
|
||||||
auto mediocre_operator = [&](const std::string& base_el) -> void {
|
auto mediocre_operator = [&](const std::string& base_el) -> void {
|
||||||
result.parts.emplace_back();
|
result.parts.emplace_back();
|
||||||
result.parts.back().type = element_part_type_t::put;
|
result.parts.back().type = ElementPart::p_put;
|
||||||
ElementPart::when_put_S& P = result.parts.back().when_put;
|
ElementPart::when_put_S& P = result.parts.back().when_put;
|
||||||
P.called_element["V"] = json::JSON(base_el);
|
P.called_element["V"] = json::JSON(base_el);
|
||||||
P.called_element["C"] = json::JSON(json::array);
|
P.called_element["C"] = json::JSON(json::array);
|
||||||
@ -446,20 +450,20 @@ namespace nytl {
|
|||||||
ASSERT(myself == gone_for_nothing, "Unexpected end of element");
|
ASSERT(myself == gone_for_nothing, "Unexpected end of element");
|
||||||
skip_magic_block_end(ctx, syntax);
|
skip_magic_block_end(ctx, syntax);
|
||||||
if (!result.parts.empty()) {
|
if (!result.parts.empty()) {
|
||||||
if (result.parts[0].type == element_part_type_t::code)
|
if (result.parts[0].type == ElementPart::p_code)
|
||||||
result.parts[0].when_code.lines = clement_lstrip(result.parts[0].when_code.lines);
|
result.parts[0].when_code.lines = clement_lstrip(result.parts[0].when_code.lines);
|
||||||
if (result.parts.back().type == element_part_type_t::code)
|
if (result.parts.back().type == ElementPart::p_code)
|
||||||
rstrip(result.parts.back().when_code.lines);
|
rstrip(result.parts.back().when_code.lines);
|
||||||
size_t cut = 999999999999;
|
size_t cut = 999999999999;
|
||||||
size_t N = result.parts.size();
|
size_t N = result.parts.size();
|
||||||
for (size_t i = 0; i < N; i++) {
|
for (size_t i = 0; i < N; i++) {
|
||||||
if (result.parts[i].type == element_part_type_t::code) {
|
if (result.parts[i].type == ElementPart::p_code) {
|
||||||
one_part_update_min_start_wsp_non_empty(result.parts[i].when_code.lines, i == 0, cut);
|
one_part_update_min_start_wsp_non_empty(result.parts[i].when_code.lines, i, N, cut);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (size_t i = 0; i < N; i++) {
|
for (size_t i = 0; i < N; i++) {
|
||||||
if (result.parts[i].type == element_part_type_t::code) {
|
if (result.parts[i].type == ElementPart::p_code) {
|
||||||
result.parts[i].when_code.lines = one_part_cut_excess_tab(result.parts[i].when_code.lines, i == 0, cut);
|
result.parts[i].when_code.lines = one_part_cut_excess_tab(result.parts[i].when_code.lines, i, N, cut);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -114,6 +114,7 @@ namespace nytl {
|
|||||||
const std::function<std::string(std::string)> &escape) override;
|
const std::function<std::string(std::string)> &escape) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Rendering Frame */
|
||||||
uptr<RFrame> RFrame_OverParts::toMe(bool returned, const global_elem_set_t &elem_ns, Ditch &result,
|
uptr<RFrame> RFrame_OverParts::toMe(bool returned, const global_elem_set_t &elem_ns, Ditch &result,
|
||||||
const std::function<std::string(std::string)> &escape) {
|
const std::function<std::string(std::string)> &escape) {
|
||||||
if (!returned)
|
if (!returned)
|
||||||
@ -147,7 +148,9 @@ namespace nytl {
|
|||||||
const json::JSON* X = passed_args[0].JSON_subval;
|
const json::JSON* X = passed_args[0].JSON_subval;
|
||||||
assert(X);
|
assert(X);
|
||||||
if (name == "jesc") {
|
if (name == "jesc") {
|
||||||
append(escape(json::generate_str(*X, json::print_pretty)), result);
|
std::string escaped_json = escape(json::generate_str(*X, json::print_pretty));
|
||||||
|
rstrip(escaped_json);
|
||||||
|
append(escaped_json, result);
|
||||||
} else if (name == "str2text") {
|
} else if (name == "str2text") {
|
||||||
ASSERT(X->isString(), "str2text takes json string");
|
ASSERT(X->isString(), "str2text takes json string");
|
||||||
append(escape(X->asString()), result);
|
append(escape(X->asString()), result);
|
||||||
@ -161,10 +164,10 @@ namespace nytl {
|
|||||||
if (part_to_do == el.parts.size())
|
if (part_to_do == el.parts.size())
|
||||||
return NULL;
|
return NULL;
|
||||||
const ElementPart& cur_part = el.parts[part_to_do++];
|
const ElementPart& cur_part = el.parts[part_to_do++];
|
||||||
if (cur_part.type == element_part_types::code) {
|
if (cur_part.type == ElementPart::p_code) {
|
||||||
const ElementPart::when_code_S& pt = cur_part.when_code;
|
const ElementPart::when_code_S& pt = cur_part.when_code;
|
||||||
append(pt.lines, result);
|
append(pt.lines, result);
|
||||||
} else if (cur_part.type == element_part_types::put) {
|
} else if (cur_part.type == ElementPart::p_put) {
|
||||||
const ElementPart::when_put_S& pt = cur_part.when_put;
|
const ElementPart::when_put_S& pt = cur_part.when_put;
|
||||||
LocalVarValue called_element_expv = rendering_core_execute_expression(elem_ns, passed_args, pt.called_element);
|
LocalVarValue called_element_expv = rendering_core_execute_expression(elem_ns, passed_args, pt.called_element);
|
||||||
ASSERT(!called_element_expv.is_json, "Can't PUT json variable");
|
ASSERT(!called_element_expv.is_json, "Can't PUT json variable");
|
||||||
@ -174,7 +177,7 @@ namespace nytl {
|
|||||||
passed_arguments_expv[i] = rendering_core_execute_expression(elem_ns, passed_args, pt.passed_arguments[i]);
|
passed_arguments_expv[i] = rendering_core_execute_expression(elem_ns, passed_args, pt.passed_arguments[i]);
|
||||||
return std::make_unique<RFrame_OverParts>(called_element_expv.EL_name, passed_arguments_expv,
|
return std::make_unique<RFrame_OverParts>(called_element_expv.EL_name, passed_arguments_expv,
|
||||||
result.cur_line_width);
|
result.cur_line_width);
|
||||||
} else if (cur_part.type == element_part_types::for_put) {
|
} else if (cur_part.type == ElementPart::p_for_put) {
|
||||||
const ElementPart::when_for_put_S& pt = cur_part.when_for_put;
|
const ElementPart::when_for_put_S& pt = cur_part.when_for_put;
|
||||||
LocalVarValue iting_over = rendering_core_execute_expression(elem_ns, passed_args, pt.ref_over);
|
LocalVarValue iting_over = rendering_core_execute_expression(elem_ns, passed_args, pt.ref_over);
|
||||||
ASSERT(iting_over.is_json, "Can't iterate over element");
|
ASSERT(iting_over.is_json, "Can't iterate over element");
|
||||||
@ -185,7 +188,7 @@ namespace nytl {
|
|||||||
return std::make_unique<RFrame_OverDictionary>(pt, result.cur_line_width, passed_args, container.asDictionary());
|
return std::make_unique<RFrame_OverDictionary>(pt, result.cur_line_width, passed_args, container.asDictionary());
|
||||||
} else
|
} else
|
||||||
THROW("Can't iterate over non-natalistic jsobject");
|
THROW("Can't iterate over non-natalistic jsobject");
|
||||||
} else if (cur_part.type == element_part_types::ref_put) {
|
} else if (cur_part.type == ElementPart::p_ref_put) {
|
||||||
const ElementPart::when_ref_put_S& pt = cur_part.when_ref_put;
|
const ElementPart::when_ref_put_S& pt = cur_part.when_ref_put;
|
||||||
std::vector<LocalVarValue> more_variables(passed_args.size() + 1);
|
std::vector<LocalVarValue> more_variables(passed_args.size() + 1);
|
||||||
std::copy(passed_args.begin(), passed_args.end(), more_variables.begin());
|
std::copy(passed_args.begin(), passed_args.end(), more_variables.begin());
|
||||||
|
@ -10,21 +10,15 @@
|
|||||||
namespace nytl {
|
namespace nytl {
|
||||||
typedef json::JSON expression_t;
|
typedef json::JSON expression_t;
|
||||||
|
|
||||||
namespace element_part_types {
|
|
||||||
enum element_part_type_E {
|
|
||||||
code,
|
|
||||||
/* write statements really mean PUT str2text X */
|
|
||||||
put,
|
|
||||||
for_put,
|
|
||||||
ref_put
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef element_part_types::element_part_type_E element_part_type_t;
|
|
||||||
|
|
||||||
struct ElementPart {
|
struct ElementPart {
|
||||||
/* Used with all types */
|
/* Used with all types */
|
||||||
element_part_type_t type = element_part_types::code;
|
enum element_part_type_E {
|
||||||
|
p_code,
|
||||||
|
/* write statements really mean PUT str2text X */
|
||||||
|
p_put,
|
||||||
|
p_for_put,
|
||||||
|
p_ref_put
|
||||||
|
} type = p_code;
|
||||||
struct when_code_S {
|
struct when_code_S {
|
||||||
std::string lines;
|
std::string lines;
|
||||||
} when_code;
|
} when_code;
|
||||||
|
8
src/http_server/nytl_tests/HypertextPages/test.nytl.html
Normal file
8
src/http_server/nytl_tests/HypertextPages/test.nytl.html
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{% ELDEF main JSON abc %}
|
||||||
|
{% PUT jesc abc %}
|
||||||
|
|
||||||
|
AAAAAAAA
|
||||||
|
BBB
|
||||||
|
{% PUT jesc abc %}
|
||||||
|
|
||||||
|
{% ENDELDEF %}
|
@ -1,6 +1,5 @@
|
|||||||
#include <new_york_transit_line/templater.h>
|
#include <new_york_transit_line/templater.h>
|
||||||
|
#include <new_york_transit_line/core.h>
|
||||||
/* Yep, tests for nytl depend on assets for website. Yep, I see no problem with that */
|
|
||||||
|
|
||||||
int main(int argc, char** argv) {
|
int main(int argc, char** argv) {
|
||||||
if (argc < 2) {
|
if (argc < 2) {
|
||||||
@ -11,10 +10,10 @@ int main(int argc, char** argv) {
|
|||||||
std::string dir_path = argv[1];
|
std::string dir_path = argv[1];
|
||||||
nytl::Templater templater(nytl::TemplaterSettings{nytl::TemplaterDetourRules{dir_path}});
|
nytl::Templater templater(nytl::TemplaterSettings{nytl::TemplaterDetourRules{dir_path}});
|
||||||
templater.update();
|
templater.update();
|
||||||
std::string answer = templater.render("list-rooms", {});
|
nytl::debug_print_templater(templater);
|
||||||
printf("%s\n<a><f><t><e><r><><l><f>\n", answer.c_str());
|
|
||||||
std::string answer2 = templater.render("test", {});
|
std::string answer2 = templater.render("test", {json::JSON()});
|
||||||
printf("%s\n<a><f><t><e><r><><l><f>\n", answer.c_str());
|
printf("%s\n<a><f><t><e><r><><l><f>\n", answer2.c_str());
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user