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
|
/***************************************************************************
mapihd.h - description
-------------------
begin : Tue Jul 25 2000
copyright : (C) 2000 by Hans Dijkema
email : kmailcvt@hum.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 _MAPIHD_H_
#define _MAPIHD_H_
#include <tqmemarray.h>
#include "pab_xxport.h"
#define T_MS_ARRAY 0x1100 // Some sort of array
#define T_MS_STRING ((unsigned long) 0x1e) // definitely a string
typedef unsigned long adr_t;
typedef unsigned long content_t;
typedef unsigned short pabsize_t;
typedef unsigned char byte_t;
typedef unsigned short word_t;
typedef byte_t byte;
class pab;
class pabrec {
private:
char entry[1024];
byte *_mem;
word_t m_N;
word_t *m_W;
public:
pabrec(pab &); // expects record the begin at reading point (ftell).
~pabrec();
public:
word_t N(void) { return m_N; }
word_t operator[](int i) { return m_W[i]; }
const char *getEntry(int i);
public:
content_t read(word_t offset);
};
typedef enum {
pr_unknown,pr_notused,
pr_givenname,pr_email,
pr_firstname,pr_additionalname,pr_lastname,pr_title,
pr_address,pr_town,pr_state,pr_zip,pr_country,
pr_organization,pr_department,pr_subdep,pr_job,
pr_tel,pr_fax,pr_modem,pr_mobile,pr_url,pr_talk,
pr_notes,pr_birthday
}
pabrec_entry;
class mapitag_t
{
friend bool operator < (mapitag_t &,mapitag_t &);
friend bool operator > (mapitag_t &,mapitag_t &);
friend bool operator == (mapitag_t &,mapitag_t &);
private:
word_t _tag;
word_t _type;
content_t _order;
public:
mapitag_t(content_t tag,content_t order) { _tag=(word_t) tag;_type=(word_t) (tag>>16);_order=order; }
mapitag_t() { _tag=0;_type=0;_order=0; }
public:
mapitag_t & operator = (mapitag_t & t) { _tag=t._tag;_type=t._type;_order=t._order;return *this; }
public:
bool isUsed(void) { return (_type==T_MS_STRING || (_type&T_MS_ARRAY)!=0) && _order!=0; }
word_t literal(void) { return _tag; }
content_t order(void) { return _order; }
pabrec_entry matchTag(void);
};
bool operator < (mapitag_t & a,mapitag_t & b);
bool operator > (mapitag_t & a,mapitag_t & b);
bool operator == (mapitag_t & a,mapitag_t & b);
class pabfields_t
{
private:
TQMemArray<mapitag_t> tags,context_tags;
pabrec *m_R;
TQString givenName,email,
title,firstName,additionalName,lastName,
address,town,state,zip,country,
organization,department,subDep,job,
tel,fax,modem,mobile,homepage,talk,
comment,birthday;
bool OK;
private:
bool isUsed(int k);
pabrec_entry isWhat(int k);
word_t literal(int k);
content_t order(int k);
public:
pabfields_t(pabrec & R, TQWidget *parent);
public:
TDEABC::Addressee get( );
bool isOK(void) { return OK; }
bool isUsable(void) { return givenName!=""; }
};
#endif
|