/* * This file is a part of EZC -- Easy templating in C++ library * and is distributed under the 2-Clause BSD licence. * Author: Tomasz Sowa */ /* * Copyright (c) 2007-2021, Tomasz Sowa * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * */ #ifndef headerfile_ezc_item #define headerfile_ezc_item #include #include namespace Ezc { struct Item { enum Type { item_none, item_container, item_text, item_function, item_if, item_if_def, item_if_not_def, item_for, item_else, item_end, item_err, item_include, item_comment, item_def, item_def_if_not_set, item_let, item_let_if_not_set, item_filter, item_ezc, item_block, item_return }; struct Function { bool is_function; // if true then we have a function parameter, if false then we have a string parameter std::wstring name; // a function or parameter name std::vector fields; // any number of additional fields after a dot e.g. [name.field1.field2] std::wstring postfix; // a function can have an additional postfix in its name // e.g. [my_function:my_postfix] std::vector parameters; // if is_function is true then it is a function and can have 'parameters' // if is_function is empty then 'parameters' is empty too void * fun_cache; // only valid if is_function is true Item * item_block; void * base_obj; int method_index; int arg; // used if name is numeric (if no then is equal -1) Function() { is_function = false; fun_cache = 0; item_block = 0; base_obj = 0; method_index = -1; arg = -1; } ~Function() { Clear(); } Function(const Function & f) { operator=(f); } Function & operator=(const Function & f) { is_function = f.is_function; name = f.name; fields = f.fields; postfix = f.postfix; fun_cache = f.fun_cache; item_block = f.item_block; base_obj = f.base_obj; method_index = f.method_index; arg = f.arg; for(size_t i=0 ; i item_tab; // childs bool has_function; // the [return] statement can be without a function Function function; Item(); Item(const Item & i); Item & operator=(const Item & i); void CopyItemTable(const Item & i); ~Item(); Item * AddItem(const Item * porg = 0); Item * AddItem(const Item & porg); void ClearItems(); Type LastItemType(); void DeleteLastItem(); void Clear(); void ClearCache(); private: void ClearCache(Item::Function & function); }; } // namespace Ezc #endif