/usr/include/muparserx/mpIValReader.h is in libmuparserx-dev 4.0.7+dfsg-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 | /*
__________ ____ ___
_____ __ _\______ \_____ _______ ______ __________\ \/ /
/ \| | \ ___/\__ \\_ __ \/ ___// __ \_ __ \ /
| Y Y \ | / | / __ \| | \/\___ \\ ___/| | \/ \
|__|_| /____/|____| (____ /__| /____ >\___ >__| /___/\ \
\/ \/ \/ \/ \_/
Copyright (C) 2016 Ingo Berg
All rights reserved.
muParserX - A C++ math parser library with array and string support
Copyright (c) 2016, Ingo Berg
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
* 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 MU_IPARSER_VALUE_READER_H
#define MU_IPARSER_VALUE_READER_H
#include "mpValue.h"
#include "mpIToken.h"
#include "mpTokenReader.h"
/** \defgroup valreader Value reader classes
This group lists all classes that detect and parse values in an expression string.
*/
MUP_NAMESPACE_START
class TokenReader;
/** \brief Interface for custom value reader objects.
\ingroup valreader
Value readers are objects used for identifying values
in an expression.
*/
class IValueReader
{
public:
IValueReader();
IValueReader(const IValueReader &ref);
virtual ~IValueReader();
/** \brief Check a certain position in an expression for the presence of a value.
\param a_iPos [in/out] Reference to an integer value representing the current
position of the parser in the expression.
\param a_Val If a value is found it is stored in a_Val
\return true if a value was found
*/
virtual bool IsValue(const char_type *a_szExpr,
int &a_iPos,
Value &a_Val ) = 0;
/** \brief Clone this ValueReader object.
\return Pointer to the cloned value reader object.
*/
virtual IValueReader* Clone(TokenReader *pParent) const = 0;
/** \brief Assign this value reader object to a token
reader object.
The token reader does the tokenization of the expression.
It uses this value reader to detect values.
*/
virtual void SetParent(TokenReader *pTokenReader);
protected:
const IToken* TokenHistory(std::size_t pos) const;
private:
TokenReader *m_pTokenReader; ///< Pointer to the TokenReader class used for token recognition
}; // class IValueReader
MUP_NAMESPACE_END
#endif
|