23 #ifndef LIBWPS_INTERNAL_H 24 #define LIBWPS_INTERNAL_H 39 #include <librevenge-stream/librevenge-stream.h> 40 #include <librevenge/librevenge.h> 43 #define M_PI 3.14159265358979323846 46 #if defined(_MSC_VER) || defined(__DJGPP__) 47 typedef signed char int8_t;
48 typedef unsigned char uint8_t;
49 typedef signed short int16_t;
50 typedef unsigned short uint16_t;
51 typedef signed int int32_t;
52 typedef unsigned int uint32_t;
54 # include <inttypes.h> 65 # define gmtime_r(tp,tmp) (gmtime(tp)?(*(tmp)=*gmtime(tp),(tmp)):0) 66 # define localtime_r(tp,tmp) (localtime(tp)?(*(tmp)=*localtime(tp),(tmp)):0) 77 #if defined(HAVE_CLANG_ATTRIBUTE_FALLTHROUGH) 78 # define WPS_FALLTHROUGH [[clang::fallthrough]] 79 #elif defined(HAVE_GCC_ATTRIBUTE_FALLTHROUGH) 80 # define WPS_FALLTHROUGH __attribute__((fallthrough)) 82 # define WPS_FALLTHROUGH ((void) 0) 118 #if defined(HAVE_FUNC_ATTRIBUTE_FORMAT) 119 # define WPS_ATTRIBUTE_PRINTF(fmt, arg) __attribute__((format(printf, fmt, arg))) 121 # define WPS_ATTRIBUTE_PRINTF(fmt, arg) 124 #define WPS_N_ELEMENTS(m) sizeof(m)/sizeof(m[0]) 132 #define WPS_DEBUG_MSG(M) libwps::printDebugMsg M 134 #define WPS_DEBUG_MSG(M) 170 uint8_t
readU8(librevenge::RVNGInputStream *input);
171 uint16_t
readU16(librevenge::RVNGInputStream *input);
172 uint32_t
readU32(librevenge::RVNGInputStream *input);
174 int8_t
read8(librevenge::RVNGInputStream *input);
175 int16_t
read16(librevenge::RVNGInputStream *input);
176 int32_t
read32(librevenge::RVNGInputStream *input);
180 return readU8(input.get());
193 return read8(input.get());
197 return read16(input.get());
201 return read32(input.get());
220 void appendUnicode(uint32_t val, librevenge::RVNGString &buffer);
223 #define WPS_LE_GET_GUINT16(p) \ 224 (uint16_t)((((uint8_t const *)(p))[0] << 0) | \ 225 (((uint8_t const *)(p))[1] << 8)) 226 #define WPS_LE_GET_GUINT32(p) \ 227 (uint32_t)((((uint8_t const *)(p))[0] << 0) | \ 228 (((uint8_t const *)(p))[1] << 8) | \ 229 (((uint8_t const *)(p))[2] << 16) | \ 230 (((uint8_t const *)(p))[3] << 24)) 232 #define WPS_LE_PUT_GUINT16(p, v) \ 233 *((uint8_t*)(p)) = uint8_t(v); \ 234 *(((uint8_t*)(p)) + 1) = uint8_t((v) >> 8) 236 #define WPS_LE_PUT_GUINT32(p, v) \ 237 *((uint8_t*)(p)) = uint8_t(v); \ 238 *(((uint8_t*)(p)) + 1) = uint8_t((v) >> 8); \ 239 *(((uint8_t*)(p)) + 2) = uint8_t((v) >> 16); \ 240 *(((uint8_t*)(p)) + 3) = uint8_t((v) >> 24) 287 WPSColor(
unsigned char r,
unsigned char g,
unsigned char b,
unsigned char a=255) :
288 m_value(uint32_t((a<<24)+(r<<16)+(g<<8)+b))
327 return (
unsigned char)((m_value>>24)&0xFF);
332 return (
unsigned char)(m_value&0xFF);
337 return (
unsigned char)((m_value>>16)&0xFF);
342 return (
unsigned char)((m_value>>8)&0xFF);
347 return (m_value&0xFFFFFF)==0;
352 return (m_value&0xFFFFFF)==0xFFFFFF;
357 return (c.
m_value&0xFFFFFF)==(m_value&0xFFFFFF);
362 return !operator==(c);
367 return (c.
m_value&0xFFFFFF)<(m_value&0xFFFFFF);
372 return (c.
m_value&0xFFFFFF)<=(m_value&0xFFFFFF);
377 return !operator<=(c);
382 return !operator<(c);
387 std::string str()
const;
397 enum Style { None, Simple, Dot, LargeDot, Dash };
399 enum Type { Single, Double, Triple };
400 enum Pos { Left = 0, Right = 1, Top = 2, Bottom = 3 };
401 enum { LeftBit = 0x01, RightBit = 0x02, TopBit=0x4, BottomBit = 0x08 };
420 bool addTo(librevenge::RVNGPropertyList &propList, std::string which=
"")
const;
424 return m_style==None || m_width <= 0;
436 return !operator==(orig);
439 int compare(
WPSBorder const &orig)
const;
465 enum Type { None, Database, Date, Link, PageCount, PageNumber, PageNumberNext, Time, Title };
480 bool addTo(librevenge::RVNGPropertyList &propList)
const;
482 librevenge::RVNGString getString()
const;
494 #define WPS_EXTRA_LARGE_BIT 1 495 #define WPS_VERY_LARGE_BIT 2 496 #define WPS_LARGE_BIT 4 497 #define WPS_SMALL_PRINT_BIT 8 498 #define WPS_FINE_PRINT_BIT 0x10 499 #define WPS_SUPERSCRIPT_BIT 0x20 500 #define WPS_SUBSCRIPT_BIT 0x40 501 #define WPS_OUTLINE_BIT 0x80 502 #define WPS_ITALICS_BIT 0x100 503 #define WPS_SHADOW_BIT 0x200 504 #define WPS_REDLINE_BIT 0x400 505 #define WPS_DOUBLE_UNDERLINE_BIT 0x800 506 #define WPS_BOLD_BIT 0x1000 507 #define WPS_STRIKEOUT_BIT 0x2000 508 #define WPS_UNDERLINE_BIT 0x4000 509 #define WPS_SMALL_CAPS_BIT 0x8000 510 #define WPS_BLINK_BIT 0x10000L 511 #define WPS_REVERSEVIDEO_BIT 0x20000L 512 #define WPS_ALL_CAPS_BIT 0x40000L 513 #define WPS_EMBOSS_BIT 0x80000L 514 #define WPS_ENGRAVE_BIT 0x100000L 515 #define WPS_OVERLINE_BIT 0x400000L 516 #define WPS_HIDDEN_BIT 0x800000L 519 #define WPS_PAGE_BREAK 0x00 520 #define WPS_SOFT_PAGE_BREAK 0x01 521 #define WPS_COLUMN_BREAK 0x02 524 #define WPS_LEFT 0x00 525 #define WPS_RIGHT 0x01 526 #define WPS_CENTER 0x02 528 #define WPS_BOTTOM 0x04 538 explicit Vec2(T xx=0,T yy=0) : m_x(xx), m_y(yy) { }
540 template <
class U>
explicit Vec2(
Vec2<U> const &p) : m_x(T(p.x())), m_y(T(p.y())) {}
555 return (c==0) ? m_x : m_y;
561 return (c==0) ? m_x : m_y;
642 bool operator<(Vec2<T>
const &p)
const 649 if (m_x<p.
m_x)
return -1;
650 if (m_x>p.
m_x)
return 1;
651 if (m_y<p.
m_y)
return -1;
652 if (m_y>p.
m_y)
return 1;
658 if (m_y<p.
m_y)
return -1;
659 if (m_y>p.
m_y)
return 1;
660 if (m_x<p.
m_x)
return -1;
661 if (m_x>p.
m_x)
return 1;
666 friend std::ostream &operator<< (std::ostream &o, Vec2<T>
const &f)
668 o << f.m_x <<
"x" << f.m_y;
680 return s1.
cmp(s2) < 0;
692 return s1.
cmpY(s2) < 0;
721 for (
int c=0; c < 2; c++) m_pt[c] = Vec2<T>(p[c]);
756 return m_pt[1]-m_pt[0];
761 return 0.5*(m_pt[0]+m_pt[1]);
784 m_pt[1] = m_pt[0]+sz;
789 m_pt[0] = m_pt[1]-sz;
794 Vec2<T> ctr = 0.5*(m_pt[0]+m_pt[1]);
795 m_pt[0] = ctr - 0.5*sz;
796 m_pt[1] = ctr + (sz - 0.5*sz);
800 template <
class U>
void scale(U factor)
809 m_pt[0] -=
Vec2<T>(val/2,val/2);
810 m_pt[1] +=
Vec2<T>(val-(val/2),val-(val/2));
817 m_pt[0][1]<box.
m_pt[0][1]?m_pt[0][1] : box.
m_pt[0][1]);
819 m_pt[1][1]>box.
m_pt[1][1]?m_pt[1][1] : box.
m_pt[1][1]);
827 m_pt[0][1]>box.
m_pt[0][1]?m_pt[0][1] : box.
m_pt[0][1]);
829 m_pt[1][1]<box.
m_pt[1][1]?m_pt[1][1] : box.
m_pt[1][1]);
844 bool operator<(WPSBox2<T>
const &p)
const 852 int diff = m_pt[0].cmpY(p.
m_pt[0]);
853 if (diff)
return diff;
854 diff = m_pt[1].cmpY(p.
m_pt[1]);
855 if (diff)
return diff;
860 friend std::ostream &operator<< (std::ostream &o, WPSBox2<T>
const &f)
862 o <<
"(" << f.m_pt[0] <<
"<->" << f.m_pt[1] <<
")";
874 return s1.
cmp(s2) < 0;
880 typedef std::map<WPSBox2<T>, T,
struct PosSizeLt>
Map;
908 for (
int c = 0; c < 3; c++) m_val[c] = T(p[c]);
940 void set(T xx, T yy, T zz)
963 void add(T dx, T dy, T dz)
973 for (
int c = 0; c < 3; c++) m_val[c] = T(m_val[c]+p.
m_val[c]);
979 for (
int c = 0; c < 3; c++) m_val[c] = T(m_val[c]-p.
m_val[c]);
986 for (
auto &c : m_val) c = T(c*scale);
1021 bool operator<(WPSVec3<T>
const &p)
const 1028 for (
int c = 0; c < 3; c++)
1030 if (m_val[c]<p.
m_val[c])
return -1;
1031 if (m_val[c]>p.
m_val[c])
return 1;
1037 friend std::ostream &operator<< (std::ostream &o, WPSVec3<T>
const &f)
1039 o << f.m_val[0] <<
"x" << f.m_val[1] <<
"x" << f.m_val[2];
1051 return s1.
cmp(s2) < 0;
1057 typedef std::map<WPSVec3<T>, T,
struct PosSizeLt>
Map;
1088 std::string
const &type=
"image/pict") : m_size(), m_dataList(), m_typeList(), m_sent(false)
1090 add(binaryData, type);
1099 for (
auto const &data : m_dataList)
1107 void add(librevenge::RVNGBinaryData
const &binaryData, std::string
const &type=
"image/pict")
1109 size_t pos=m_dataList.size();
1110 if (pos<m_typeList.size()) pos=m_typeList.size();
1111 m_dataList.resize(pos+1);
1112 m_dataList[pos]=binaryData;
1113 m_typeList.resize(pos+1);
1114 m_typeList[pos]=type;
1117 bool addTo(librevenge::RVNGPropertyList &propList)
const;
1137 : m_data(xRow, yRow)
1138 , m_isIdentity(false)
1149 return m_isIdentity;
1154 m_isIdentity= m_data.first==
WPSVec3f(1,0,0) && m_data.second==
WPSVec3f(0,1,0);
1162 return c==0 ? m_data.first : m_data.second;
1167 if (m_isIdentity)
return pt;
1168 return multiplyDirection(pt)+
Vec2f(m_data.first[2],m_data.second[2]);
1173 if (m_isIdentity)
return dir;
1175 for (
int coord=0; coord<2; ++coord)
1177 WPSVec3f
const &row=coord==0 ? m_data.first : m_data.second;
1179 for (
int i=0; i<2; ++i)
1180 value+=row[i]*dir[i];
1188 if (m_isIdentity)
return box;
1196 for (
int row=0; row<2; ++row)
1198 WPSVec3f &resRow=row==0 ? res.
m_data.first : res.
m_data.second;
1199 for (
int col=0; col<3; ++col)
1202 for (
int i=0; i<3; ++i)
1203 value+=(*
this)[row][i]*(i==2 ? (col==2 ? 1.f : 0.f) : mat[i][col]);
1220 return m_data==mat.
m_data;
1225 return m_data!=mat.
m_data;
1230 return m_data<mat.
m_data;
1235 return m_data<=mat.
m_data;
1240 return m_data>mat.
m_data;
1245 return m_data>=mat.
m_data;
1289 bool encodeLotusPassword(
char const *password, uint16_t &key, std::vector<uint8_t> &keys, uint8_t
const(&defValues)[16]);
std::string getCellName(Vec2i const &cellPos, Vec2b const &relative)
returns the cell name corresponding to a cell's position
Definition: libwps_internal.cpp:838
bool operator!=(Vec2< T > const &p) const
comparison!=
Definition: libwps_internal.h:637
std::string m_data
the database/link field ( if defined )
Definition: libwps_internal.h:490
int cmpY(Vec2< T > const &p) const
a comparison function: which first compares y then x
Definition: libwps_internal.h:656
bool isEmpty() const
return true if the picture contains no data
Definition: libwps_internal.h:1097
std::shared_ptr< WPSListener > WPSListenerPtr
shared pointer to WPSListener
Definition: libwps_internal.h:105
Definition: libwps_internal.h:246
void resizeFromCenter(Vec2< T > const &sz)
resize the box keeping the center
Definition: libwps_internal.h:792
void scale(U factor)
scales all points of the box by factor
Definition: libwps_internal.h:800
Vec2< float > Vec2f
Vec2 of float.
Definition: libwps_internal.h:704
WPSColor(unsigned char r, unsigned char g, unsigned char b, unsigned char a=255)
constructor from color
Definition: libwps_internal.h:287
void setY(T yy)
resets the second element
Definition: libwps_internal.h:576
a border list
Definition: libwps_internal.h:394
T m_val[3]
the values
Definition: libwps_internal.h:1061
Definition: libwps_internal.h:268
Definition: libwps_internal.h:161
T m_x
first element
Definition: libwps_internal.h:696
libwps::NumberingType m_numberingType
the number type ( for number field )
Definition: libwps_internal.h:488
uint8_t readU8(RVNGInputStreamPtr const &input)
Definition: libwps_internal.h:178
Definition: libwps_internal.cpp:38
WPSVec3< T > & operator*=(U scale)
generic operator*=
Definition: libwps_internal.h:984
Vec2< T > size() const
the box size
Definition: libwps_internal.h:754
WPSEmbeddedObject(librevenge::RVNGBinaryData const &binaryData, std::string const &type="image/pict")
constructor
Definition: libwps_internal.h:1087
WPSBox2< T > getIntersection(WPSBox2< T > const &box) const
returns the intersection between this and box
Definition: libwps_internal.h:823
bool operator()(Vec2< T > const &s1, Vec2< T > const &s2) const
comparaison function
Definition: libwps_internal.h:690
unsigned char getGreen() const
returns the green value
Definition: libwps_internal.h:340
friend Vec2< T > operator-(Vec2< T > const &p1, Vec2< T > const &p2)
operator-
Definition: libwps_internal.h:618
bool encodeLotusPassword(char const *password, uint16_t &key, std::vector< uint8_t > &keys, uint8_t const(&defValues)[16])
returns the checksum and the keys (to encode a lotus file) given a password file
Definition: libwps_internal.cpp:855
WPSBox2(Vec2< T > minPt=Vec2< T >(), Vec2< T > maxPt=Vec2< T >())
constructor
Definition: libwps_internal.h:713
int cmp(WPSBox2< T > const &p) const
comparison function : fist sorts min by Y,X values then max extremity
Definition: libwps_internal.h:850
uint32_t value() const
return the rgba value
Definition: libwps_internal.h:320
bool operator==(WPSBorder const &orig) const
operator==
Definition: libwps_internal.h:428
T & operator[](int c)
operator[]
Definition: libwps_internal.h:558
bool operator()(Vec2< T > const &s1, Vec2< T > const &s2) const
comparaison function
Definition: libwps_internal.h:678
std::shared_ptr< WKSSubDocument > WKSSubDocumentPtr
shared pointer to WKSSubDocument
Definition: libwps_internal.h:116
define the font properties
Definition: WPSFont.h:36
std::vector< std::string > m_typeList
the picture type: one type by representation
Definition: libwps_internal.h:1126
WPSVec3< T > & operator+=(WPSVec3< T > const &p)
operator+=
Definition: libwps_internal.h:971
void add(librevenge::RVNGBinaryData const &binaryData, std::string const &type="image/pict")
add a picture
Definition: libwps_internal.h:1107
WPSBox2< int > WPSBox2i
WPSBox2 of int.
Definition: libwps_internal.h:888
double m_leftGutter
Definition: libwps_internal.h:264
a field
Definition: libwps_internal.h:462
#define WPS_ATTRIBUTE_PRINTF(fmt, arg)
Definition: libwps_internal.h:121
T x() const
first element
Definition: libwps_internal.h:912
virtual class for content listener
Definition: WPSListener.h:36
internal struct used to create sorted map, sorted by X
Definition: libwps_internal.h:675
Type m_type
the type
Definition: libwps_internal.h:484
static WPSColor black()
return the back color
Definition: libwps_internal.h:306
int32_t read32(RVNGInputStreamPtr const &input)
Definition: libwps_internal.h:199
int m_width
the border width
Definition: libwps_internal.h:450
bool m_sent
a mutable flag which can be used to know if the picture was send to a listener
Definition: libwps_internal.h:1128
Vec2< T > const & max() const
the maximum 2D point (in x and in y)
Definition: libwps_internal.h:730
static WPSColor white()
return the white color
Definition: libwps_internal.h:311
Definition: libwps_internal.h:248
WPSEmbeddedObject()
empty constructor
Definition: libwps_internal.h:1079
void setX(T xx)
resets the first element
Definition: libwps_internal.h:947
Vec2< T > & operator+=(Vec2< T > const &p)
operator+=
Definition: libwps_internal.h:589
Definition: libwps_internal.h:246
Definition: libwps_internal.h:246
std::shared_ptr< WPSSubDocument > WPSSubDocumentPtr
shared pointer to WPSSubDocument
Definition: libwps_internal.h:111
Definition: libwps_internal.h:248
Definition: WPSContentListener.h:44
WPSColor & operator=(uint32_t argb)
operator=
Definition: libwps_internal.h:296
bool readDouble4(RVNGInputStreamPtr &input, double &res, bool &isNaN)
read a double store with 4 bytes: mantisse 2.5 bytes, exponent 1.5 bytes
Definition: libwps_internal.cpp:90
T operator[](int c) const
operator[]
Definition: libwps_internal.h:927
bool isWhite() const
return true if the color is white
Definition: libwps_internal.h:350
uint32_t m_attributes
Definition: libwps_internal.h:275
Definition: libwps_internal.h:248
WPSBox2< float > WPSBox2f
WPSBox2 of float.
Definition: libwps_internal.h:890
Type
Defines some basic type for field.
Definition: libwps_internal.h:465
a structure used to defined the cell position, and a format
Definition: WPSCell.h:288
internal struct used to create sorted map, sorted first min then max
Definition: libwps_internal.h:869
double m_width
Definition: libwps_internal.h:263
Justification
Definition: libwps_internal.h:249
T operator[](int c) const
operator[]
Definition: libwps_internal.h:552
bool operator!=(WPSBox2< T > const &p) const
comparison operator!=
Definition: libwps_internal.h:839
double m_rightGutter
Definition: libwps_internal.h:265
internal struct used to create sorted map, sorted by X, Y, Z
Definition: libwps_internal.h:1046
std::map< WPSBox2< int >, int, struct PosSizeLt > Map
map of WPSBox2
Definition: libwps_internal.h:880
virtual class to define a sub document
Definition: WPSSubDocument.h:33
bool operator!=(WPSBorder const &orig) const
operator!=
Definition: libwps_internal.h:434
WPSField(Type type)
basic constructor
Definition: libwps_internal.h:468
Definition: libwps_internal.h:246
bool readDouble10(RVNGInputStreamPtr &input, double &res, bool &isNaN)
read a double store with 10 bytes: mantisse 8 bytes, exponent 2 bytes
Definition: libwps_internal.cpp:224
bool isEmpty() const
returns true if the border is empty
Definition: libwps_internal.h:422
T y() const
second element
Definition: libwps_internal.h:547
bool operator==(WPSColor const &c) const
operator==
Definition: libwps_internal.h:355
Definition: libwps_internal.h:248
void setMax(Vec2< T > const &y)
resets the maximum point
Definition: libwps_internal.h:776
Vec2(T xx=0, T yy=0)
constructor
Definition: libwps_internal.h:538
Definition: libwps_internal.h:252
void setX(T xx)
resets the first element
Definition: libwps_internal.h:571
WPSBorder()
constructor
Definition: libwps_internal.h:404
bool operator<(WPSColor const &c) const
operator<
Definition: libwps_internal.h:365
Definition: libwps_internal.h:252
bool isBlack() const
return true if the color is black
Definition: libwps_internal.h:345
SubDocumentType
Definition: libwps_internal.h:248
Definition: libwps_internal.h:246
unsigned char getAlpha() const
returns the alpha value
Definition: libwps_internal.h:325
Definition: libwps_internal.h:249
Definition: libwps_internal.h:248
Definition: libwps_internal.h:151
Vec2< T > center() const
the box center
Definition: libwps_internal.h:759
WPSBox2(WPSBox2< U > const &p)
generic constructor
Definition: libwps_internal.h:719
bool operator==(Vec2< T > const &p) const
comparison==
Definition: libwps_internal.h:632
std::vector< double > m_widthsList
the different length used for each line/sep (if defined)
Definition: libwps_internal.h:454
Basic class used to store a spreadsheet sub document.
Definition: WKSSubDocument.h:35
void setZ(T zz)
resets the third element
Definition: libwps_internal.h:957
Definition: libwps_internal.h:250
void appendUnicode(uint32_t val, librevenge::RVNGString &buffer)
adds an unicode character to a string ( with correct encoding ).
Definition: libwps_internal.cpp:721
Vec2< T > & min()
the minimum 2D point (in x and in y)
Definition: libwps_internal.h:735
small class which defines a 2D WPSBox
Definition: libwps_internal.h:709
Definition: libwps_internal.h:248
Vec2f m_size
the picture size in inches(if known)
Definition: libwps_internal.h:1122
void add(T dx, T dy, T dz)
increases the actuals values by dx, dy, dz
Definition: libwps_internal.h:963
Definition: libwps_internal.h:141
friend WPSVec3< T > operator*(U scale, WPSVec3< T > const &p1)
generic operator*
Definition: libwps_internal.h:1004
std::shared_ptr< librevenge::RVNGInputStream > RVNGInputStreamPtr
shared pointer to librevenge::RVNGInputStream
Definition: libwps_internal.h:87
uint32_t m_value
the argb color
Definition: libwps_internal.h:390
internal struct used to create sorted map, sorted by Y
Definition: libwps_internal.h:687
WPSVec3< T > & operator-=(WPSVec3< T > const &p)
operator-=
Definition: libwps_internal.h:977
int cmp(Vec2< T > const &p) const
a comparison function: which first compares x then y
Definition: libwps_internal.h:647
void operator()(T *)
Definition: libwps_internal.h:73
bool operator!=(WPSVec3< T > const &p) const
comparison!=
Definition: libwps_internal.h:1016
WPSVec3< unsigned char > WPSVec3uc
WPSVec3 of unsigned char.
Definition: libwps_internal.h:1065
std::shared_ptr< WPSCell > WPSCellPtr
shared pointer to WPSCell
Definition: libwps_internal.h:100
Type
the line repetition
Definition: libwps_internal.h:399
void extend(T val)
extends the bdbox by (val, val) keeping the center
Definition: libwps_internal.h:807
Definition: libwps_internal.h:156
void add(T dx, T dy)
increases the actuals values by dx and dy
Definition: libwps_internal.h:582
std::vector< librevenge::RVNGBinaryData > m_dataList
the picture content: one data by representation
Definition: libwps_internal.h:1124
uint8_t m_alignment
Definition: libwps_internal.h:276
Definition: libwps_internal.h:255
bool operator>(WPSColor const &c) const
operator>
Definition: libwps_internal.h:375
WPSColumnProperties()
Definition: libwps_internal.h:270
Vec2< T > & operator-=(Vec2< T > const &p)
operator-=
Definition: libwps_internal.h:596
void setMin(Vec2< T > const &x)
resets the minimum point
Definition: libwps_internal.h:771
WPSColor m_color
the border color
Definition: libwps_internal.h:456
Vec2< T > & operator*=(U scale)
generic operator*=
Definition: libwps_internal.h:604
bool operator!=(WPSColor const &c) const
operator!=
Definition: libwps_internal.h:360
NumberingType
Definition: libwps_internal.h:246
T y() const
second element
Definition: libwps_internal.h:917
std::shared_ptr< WPSContentListener > WPSContentListenerPtr
shared pointer to WPSContentListener
Definition: libwps_internal.h:107
unsigned char getBlue() const
returns the green value
Definition: libwps_internal.h:330
int16_t read16(RVNGInputStreamPtr const &input)
Definition: libwps_internal.h:195
void resizeFromMin(Vec2< T > const &sz)
resize the box keeping the minimum
Definition: libwps_internal.h:782
bool operator<=(WPSColor const &c) const
operator<=
Definition: libwps_internal.h:370
bool readDouble4Inv(RVNGInputStreamPtr &input, double &res, bool &isNaN)
read a double store with 4 bytes: exponent 3.5 bytes, mantisse 0.5 bytes
Definition: libwps_internal.cpp:303
Vec2< int > Vec2i
Vec2 of int.
Definition: libwps_internal.h:702
the class to store a color
Definition: libwps_internal.h:280
virtual ~WPSEmbeddedObject()
destructor
Definition: libwps_internal.h:1093
bool operator==(WPSVec3< T > const &p) const
comparison==
Definition: libwps_internal.h:1011
Pos
Definition: libwps_internal.h:400
T z() const
third element
Definition: libwps_internal.h:922
Definition: libwps_internal.h:250
Vec2(Vec2< U > const &p)
generic copy constructor
Definition: libwps_internal.h:540
bool readData(RVNGInputStreamPtr &input, unsigned long size, librevenge::RVNGBinaryData &data)
try to read sz bytes from input and store them in a librevenge::RVNGBinaryData
Definition: libwps_internal.cpp:332
bool readDataToEnd(RVNGInputStreamPtr &input, librevenge::RVNGBinaryData &data)
try to read the last bytes from input and store them in a librevenge::RVNGBinaryData ...
Definition: libwps_internal.cpp:346
WPSVec3< int > WPSVec3i
WPSVec3 of int.
Definition: libwps_internal.h:1067
std::string numberingTypeToString(NumberingType type)
Definition: libwps_internal.cpp:357
bool operator()(WPSVec3< T > const &s1, WPSVec3< T > const &s2) const
comparaison function
Definition: libwps_internal.h:1049
WPSVec3(T xx=0, T yy=0, T zz=0)
constructor
Definition: libwps_internal.h:899
Style
the line style
Definition: libwps_internal.h:397
uint16_t readU16(RVNGInputStreamPtr const &input)
Definition: libwps_internal.h:182
WPSBox2< T > getUnion(WPSBox2< T > const &box) const
returns the union between this and box
Definition: libwps_internal.h:813
small class use to define a embedded object
Definition: libwps_internal.h:1076
unsigned char getRed() const
returns the red value
Definition: libwps_internal.h:335
std::map< WPSVec3< int >, int, struct PosSizeLt > Map
map of WPSVec3
Definition: libwps_internal.h:1057
void setY(T yy)
resets the second element
Definition: libwps_internal.h:952
Definition: libwps_internal.h:146
WPSVec3(WPSVec3< U > const &p)
generic copy constructor
Definition: libwps_internal.h:906
std::shared_ptr< WKSContentListener > WKSContentListenerPtr
shared pointer to WKSContentListener
Definition: libwps_internal.h:114
friend WPSVec3< T > operator+(WPSVec3< T > const &p1, WPSVec3< T > const &p2)
operator+
Definition: libwps_internal.h:991
WPSColumnDefinition()
Definition: libwps_internal.h:257
Style m_style
the border style
Definition: libwps_internal.h:446
Definition: libwps_internal.h:249
int cmp(WPSVec3< T > const &p) const
a comparison function: which first compares x values, then y values then z values.
Definition: libwps_internal.h:1026
Definition: libwps_internal.h:246
bool readDouble8(RVNGInputStreamPtr &input, double &res, bool &isNaN)
read a double store with 8 bytes: mantisse 6.5 bytes, exponent 1.5 bytes
Definition: libwps_internal.cpp:173
Definition: libwps_internal.h:249
bool operator==(WPSBox2< T > const &p) const
comparison operator==
Definition: libwps_internal.h:834
void resizeFromMax(Vec2< T > const &sz)
resize the box keeping the maximum
Definition: libwps_internal.h:787
basic class to store an entry in a file This contained :
Definition: WPSEntry.h:38
small class which defines a vector with 2 elements
Definition: libwps_internal.h:534
Definition: libwps_internal.h:246
friend Vec2< T > operator*(U scale, Vec2< T > const &p1)
generic operator*
Definition: libwps_internal.h:625
Class to define the position of an object (textbox, picture, ..) in the document. ...
Definition: WPSPosition.h:39
bool operator>=(WPSColor const &c) const
operator>=
Definition: libwps_internal.h:380
std::string m_extra
extra data ( if needed)
Definition: libwps_internal.h:458
int8_t read8(RVNGInputStreamPtr const &input)
Definition: libwps_internal.h:191
Definition: libwps_internal.h:248
bool readDouble2Inv(RVNGInputStreamPtr &input, double &res, bool &isNaN)
read a double store with 2 bytes: exponent 1.5 bytes, kind of mantisse 0.5 bytes
Definition: libwps_internal.cpp:273
small structure use to store a stream and it debug file
Definition: WPSStream.h:29
std::ostream & operator<<(std::ostream &o, WPSColor const &c)
Definition: libwps_internal.cpp:401
WPSColor(uint32_t argb=0)
constructor
Definition: libwps_internal.h:283
uint32_t readU32(RVNGInputStreamPtr const &input)
Definition: libwps_internal.h:186
WPSVec3< float > WPSVec3f
WPSVec3 of float.
Definition: libwps_internal.h:1069
bool operator()(WPSBox2< T > const &s1, WPSBox2< T > const &s2) const
comparaison function
Definition: libwps_internal.h:872
T m_y
second element
Definition: libwps_internal.h:696
a noop deleter used to transform a librevenge pointer in a false std::shared_ptr
Definition: libwps_internal.h:71
T & operator[](int c)
operator[]
Definition: libwps_internal.h:933
Vec2< T > m_pt[2]
the two extremities
Definition: libwps_internal.h:884
T x() const
first element
Definition: libwps_internal.h:542
Type m_type
the border repetition
Definition: libwps_internal.h:448
std::string m_DTFormat
the date/time format using strftime format if defined (see strftime)
Definition: libwps_internal.h:486
std::shared_ptr< WPSHeader > WPSHeaderPtr
shared pointer to WPSHeader
Definition: libwps_internal.h:109
Vec2< T > & max()
the maximum 2D point (in x and in y)
Definition: libwps_internal.h:740
Definition: WKSContentListener.h:53
small class which defines a vector with 3 elements
Definition: libwps_internal.h:895
Vec2< T > const & operator[](int c) const
the two extremum points which defined the box
Definition: libwps_internal.h:748
Vec2< T > const & min() const
the minimum 2D point (in x and in y)
Definition: libwps_internal.h:725
Vec2< bool > Vec2b
Vec2 of bool.
Definition: libwps_internal.h:700
friend WPSVec3< T > operator-(WPSVec3< T > const &p1, WPSVec3< T > const &p2)
operator-
Definition: libwps_internal.h:997
friend Vec2< T > operator+(Vec2< T > const &p1, Vec2< T > const &p2)
operator+
Definition: libwps_internal.h:612