/usr/include/libqalculate/Prefix.h is in libqalculate-dev 0.9.7-9.
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 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 | /*
Qalculate
Copyright (C) 2003-2006 Niklas Knutsson (nq@altern.org)
This program 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 2 of the License, or
(at your option) any later version.
*/
#ifndef PREFIX_H
#define PREFIX_H
#include <libqalculate/includes.h>
#include <libqalculate/Number.h>
/** @file */
///Types for prefix classes.
typedef enum {
PREFIX_DECIMAL,
PREFIX_BINARY,
PREFIX_NUMBER
} PrefixType;
///Abstract class for prefixes.
/** A prefix is prepended to a unit to specificy a quantity multiplicator. A prefix has a numerical value which raised to the units power defines the quantity. In for example the expression "3 kilometers", meter is the unit, 3 is regular quantity, and kilo is a prefix with a value 1000, thus the example equals "3000 meters". If the unit instead had been squared, the value of the prefix would have been raised by two and the total quantity would have been 3.000.000.
Prefixes can have up to free different three names -- a long name, a short name and a short unicode name. The unicode name is an alternative to the short name that is preferred if unicode characters can be displayed. The names or used to reference the prefix in mathematical expressions and to display a prefix in a result.
*/
class Prefix {
protected:
string l_name, s_name, u_name;
public:
/** Create a prefix.
*
* @param long_name Long name.
* @param short_name Short name.
* @param unicode_name Unicode name.
*/
Prefix(string long_name, string short_name = "", string unicode_name = "");
virtual ~Prefix();
/** Returns the short name of the prefix.
*
* @param return_long_if_no_short If the long name shall be returned if the prefix has not got a short name (if it is empty).
* @param use_unicode If a unicode version of the name is allowed and preferred.
* @returns The short name of the prefix.
*/
const string &shortName(bool return_long_if_no_short = true, bool use_unicode = false) const;
/** Returns the long name of the prefix.
*
* @param return_short_if_no_long If the short name shall be returned if the prefix has not got a long name (if it is empty).
* @param use_unicode If a unicode version of the name is allowed and preferred.
* @returns The long name of the prefix.
*/
const string &longName(bool return_short_if_no_long = true, bool use_unicode = false) const;
/** Returns the unicode name of the prefix.
*
* @param return_short_if_no_uni If the short name shall be returned if the prefix has not got a unicode name (if it is empty).
* @returns The unicode name of the prefix.
*/
const string &unicodeName(bool return_short_if_no_uni = true) const;
/** Sets the short name of the prefix.
*
* @param short_name The new short name for the prefix.
*/
void setShortName(string short_name);
/** Sets the long name of the prefix.
*
* @param long_name The new long name for the prefix.
*/
void setLongName(string long_name);
/** Sets the unicode name of the prefix. The unicode name is an alternative to the short name that is preferred if unicode characters can be displayed.
*
* @param unicode_name The new unicode name for the prefix.
*/
void setUnicodeName(string unicode_name);
/** Returns a preferred name of the prefix.
*
* @param short_default If a short name is preferred.
* @param use_unicode If a unicode name is preferred.
* @param can_display_unicode_string_function Function that tests if the unicode characters in a name can be displayed. If the function returns false, the name will be rejected.
* @param can_display_unicode_string_arg Argument to pass to the above test function.
* @returns A preferred name.
*/
const string &name(bool short_default = true, bool use_unicode = false, bool (*can_display_unicode_string_function) (const char*, void*) = NULL, void *can_display_unicode_string_arg = NULL) const;
/** Returns the value of the prefix.
*
* @param nexp The power of the prefixed unit.
* @returns The value of the prefix.
*/
virtual Number value(const Number &nexp) const = 0;
/** Returns the value of the prefix.
*
* @param iexp The power of the prefixed unit.
* @returns The value of the prefix.
*/
virtual Number value(int iexp) const = 0;
/** Returns the value of the prefix.
*
* @returns The value of the prefix.
*/
virtual Number value() const = 0;
/** Returns type, subclass, of the prefix. This can be PREFIX_DECIMAL for prefixes of the class DecimalPrefix, PREFIX_BINARY for BinaryPrefix, or PREFIX_NUMBER for NumberPrefix.
*
* @returns The type of the prefix.
*/
virtual int type() const = 0;
};
///A decimal (metric) prefix.
/** A metric or decimal prefix has an integer exponent which with a base of ten constitutes the value of the prefix (value=10^exponent).
*/
class DecimalPrefix : public Prefix {
protected:
int exp;
public:
/** Create a decimal prefix.
*
* @param exp10 Exponent for the value.
* @param long_name Long name.
* @param short_name Short name.
* @param unicode_name Unicode name.
*/
DecimalPrefix(int exp10, string long_name, string short_name = "", string unicode_name = "");
~DecimalPrefix();
/** Returns the exponent.
*
* @param iexp Exponent of the unit.
* @returns The exponent of the prefix.
*/
int exponent(int iexp = 1) const;
/** Returns the exponent.
*
* @param nexp Exponent of the unit.
* @returns The exponent of the prefix.
*/
Number exponent(const Number &nexp) const;
/** Sets the exponent of the prefix.
*
* @param iexp New exponent for the prefix.
*/
void setExponent(int iexp);
Number value(const Number &nexp) const;
Number value(int iexp) const;
Number value() const;
int type() const;
};
///A binary prefix.
/** A Binary prefix has an integer exponent which with a base of two constitutes the value of the prefix (value=2^exponent).
*/
class BinaryPrefix : public Prefix {
protected:
int exp;
public:
/** Create a binary prefix.
*
* @param exp2 Exponent for the value.
* @param long_name Long name.
* @param short_name Short name.
* @param unicode_name Unicode name.
*/
BinaryPrefix(int exp2, string long_name, string short_name = "", string unicode_name = "");
~BinaryPrefix();
/** Returns the exponent.
*
* @param iexp Exponent of the unit.
* @returns The exponent of the prefix.
*/
int exponent(int iexp = 1) const;
/** Returns the exponent.
*
* @param nexp Exponent of the unit.
* @returns The exponent of the prefix.
*/
Number exponent(const Number &nexp) const;
/** Sets the exponent of the prefix.
*
* @param iexp New exponent for the prefix.
*/
void setExponent(int iexp);
Number value(const Number &nexp) const;
Number value(int iexp) const;
Number value() const;
int type() const;
};
///A prefix with a free numerical value.
/** A prefix without any predefined base, which can use any number.
*/
class NumberPrefix : public Prefix {
protected:
Number o_number;
public:
/** Create a number prefix.
*
* @param nr Value of the prefix.
* @param long_name Long name.
* @param short_name Short name.
* @param unicode_name Unicode name.
*/
NumberPrefix(const Number &nr, string long_name, string short_name = "", string unicode_name = "");
~NumberPrefix();
/** Sets the value of the prefix.
*
* @param nr New value for the prefix.
*/
void setValue(const Number &nr);
Number value(const Number &nexp) const;
Number value(int iexp) const;
Number value() const;
int type() const;
};
#endif
|