Mercurial > libpst
changeset 52:034641c26ab9
code cleanup
author | carl |
---|---|
date | Thu, 31 Jan 2008 08:03:30 -0800 (2008-01-31) |
parents | 06c0262ad689 |
children | c97dabe37115 |
files | ChangeLog configure.in regression/regression-tests.bash src/dumpblocks.c src/getidblock.c src/libpst.c src/libpst.h src/lspst.c src/pst2ldif.cpp src/readpst.c src/readpstlog.c xml/libpst.in |
diffstat | 12 files changed, 381 insertions(+), 337 deletions(-) [+] |
line wrap: on
line diff
--- a/ChangeLog Tue Jan 22 14:39:02 2008 -0800 +++ b/ChangeLog Thu Jan 31 08:03:30 2008 -0800 @@ -1,3 +1,11 @@ +LibPST 0.6.6 (2008-01-xx) +=============================== + + * More code cleanup, removing unnecessary null terminations on + binary buffers. All pst file reads now go thru one function. + Logging all pst reads to detect cases where we read the same data + multiple times - discovers node sizes are actually 512 bytes. + LibPST 0.6.5 (2008-01-22) ===============================
--- a/configure.in Tue Jan 22 14:39:02 2008 -0800 +++ b/configure.in Thu Jan 31 08:03:30 2008 -0800 @@ -1,7 +1,7 @@ AC_INIT(configure.in) AM_CONFIG_HEADER(config.h) -AM_INIT_AUTOMAKE(libpst,0.6.5) +AM_INIT_AUTOMAKE(libpst,0.6.6) AC_PATH_PROGS(BASH, bash) AC_LANG_CPLUSPLUS
--- a/regression/regression-tests.bash Tue Jan 22 14:39:02 2008 -0800 +++ b/regression/regression-tests.bash Thu Jan 31 08:03:30 2008 -0800 @@ -29,5 +29,5 @@ $val ../src/lspst -d dumper ams.pst >out9.err 2>&1 ../src/readpstlog -f I dumper >ams.log -rm -f dumper lspst.debug +rm -f dumper
--- a/src/dumpblocks.c Tue Jan 22 14:39:02 2008 -0800 +++ b/src/dumpblocks.c Thu Jan 31 08:03:30 2008 -0800 @@ -10,7 +10,7 @@ pst_file pstfile; pst_index_ll *ptr; char *outdir=NULL, *file=NULL, *outname=NULL; - unsigned char *buf=NULL; + char *buf=NULL; int c; FILE *fp;
--- a/src/getidblock.c Tue Jan 22 14:39:02 2008 -0800 +++ b/src/getidblock.c Thu Jan 31 08:03:30 2008 -0800 @@ -21,7 +21,7 @@ pst_file pstfile; unsigned int id; int decrypt = 0, process = 0, binary = 0, c; - unsigned char *buf = NULL; + char *buf = NULL; size_t readSize; pst_item *item; pst_desc_ll* ptr;
--- a/src/libpst.c Tue Jan 22 14:39:02 2008 -0800 +++ b/src/libpst.c Thu Jan 31 08:03:30 2008 -0800 @@ -40,21 +40,21 @@ #define INDEX_BACK32 (off_t)0xC0 #define SECOND_POINTER32 (off_t)0xBC #define SECOND_BACK32 (off_t)0xB8 -#define ENC_OFFSET32 (off_t)0x1CD +#define ENC_TYPE32 (off_t)0x1CD #define FILE_SIZE_POINTER64 (off_t)0xB8 #define INDEX_POINTER64 (off_t)0xF0 #define INDEX_BACK64 (off_t)0xE8 #define SECOND_POINTER64 (off_t)0xE0 #define SECOND_BACK64 (off_t)0xD8 -#define ENC_OFFSET64 (off_t)0x201 +#define ENC_TYPE64 (off_t)0x201 #define FILE_SIZE_POINTER ((pf->do_read64) ? FILE_SIZE_POINTER64 : FILE_SIZE_POINTER32) #define INDEX_POINTER ((pf->do_read64) ? INDEX_POINTER64 : INDEX_POINTER32) #define INDEX_BACK ((pf->do_read64) ? INDEX_BACK64 : INDEX_BACK32) #define SECOND_POINTER ((pf->do_read64) ? SECOND_POINTER64 : SECOND_POINTER32) #define SECOND_BACK ((pf->do_read64) ? SECOND_BACK64 : SECOND_BACK32) -#define ENC_OFFSET ((pf->do_read64) ? ENC_OFFSET64 : ENC_OFFSET32) +#define ENC_TYPE ((pf->do_read64) ? ENC_TYPE64 : ENC_TYPE32) #define PST_SIGNATURE 0x4E444221 @@ -176,7 +176,7 @@ } // Check pst file magic - if (fread(&sig, sizeof(sig), (size_t)1, pf->fp) == 0) { + if (pst_getAtPos(pf, 0, &sig, sizeof(sig)) != sizeof(sig)) { (void)fclose(pf->fp); WARN(("cannot read signature from PST file. Closing on error\n")); DEBUG_RET(); @@ -192,7 +192,7 @@ } // read index type - (void)pst_getAtPos(pf->fp, INDEX_TYPE_OFFSET, &(pf->ind_type), sizeof(pf->ind_type)); + (void)pst_getAtPos(pf, INDEX_TYPE_OFFSET, &(pf->ind_type), sizeof(pf->ind_type)); DEBUG_INFO(("index_type = %i\n", pf->ind_type)); switch (pf->ind_type) { case INDEX_TYPE32 : @@ -208,7 +208,7 @@ } // read encryption setting - (void)pst_getAtPos(pf->fp, ENC_OFFSET, &(pf->encryption), sizeof(pf->encryption)); + (void)pst_getAtPos(pf, ENC_TYPE, &(pf->encryption), sizeof(pf->encryption)); DEBUG_INFO(("encrypt = %i\n", pf->encryption)); pf->index2_back = pst_getIntAtPos(pf, SECOND_BACK); @@ -264,7 +264,7 @@ } -size_t pst_attach_to_mem(pst_file *pf, pst_item_attach *attach, unsigned char **b){ +size_t pst_attach_to_mem(pst_file *pf, pst_item_attach *attach, char **b){ size_t size=0; pst_index_ll *ptr; pst_holder h = {b, NULL, 0, "", 0}; @@ -395,14 +395,15 @@ pst_desc_ll *p; pst_num_array *na; pst_index2_ll *id2_head = NULL; - unsigned char *buffer=NULL, *headerbuffer=NULL; + char *buffer=NULL, *headerbuffer=NULL; size_t bsize=0, hsize=0, bptr=0; pst_x_attrib xattrib; int32_t tint, err=0, x; pst_x_attrib_ll *ptr, *p_head=NULL, *p_sh=NULL, *p_sh2=NULL; DEBUG_ENT("pst_loadExtendedAttributes"); - if ((p = pst_getDptr(pf, (uint64_t)0x61)) == NULL) { + p = pst_getDptr(pf, (uint64_t)0x61); + if (!p) { DEBUG_WARN(("Cannot find DescID 0x61 for loading the Extended Attributes\n")); DEBUG_RET(); return 0; @@ -527,8 +528,7 @@ return 1; } -#define BLOCK_SIZE32 516 // index blocks -#define DESC_BLOCK_SIZE32 516 // descriptor blocks + #define ITEM_COUNT_OFFSET32 0x1f0 // count byte #define LEVEL_INDICATOR_OFFSET32 0x1f3 // node or leaf #define BACKLINK_OFFSET32 0x1f8 // backlink u1 value @@ -537,8 +537,6 @@ #define INDEX_COUNT_MAX32 41 // max active items #define DESC_COUNT_MAX32 31 // max active items -#define BLOCK_SIZE64 512 // index blocks -#define DESC_BLOCK_SIZE64 512 // descriptor blocks #define ITEM_COUNT_OFFSET64 0x1e8 // count byte #define LEVEL_INDICATOR_OFFSET64 0x1eb // node or leaf #define BACKLINK_OFFSET64 0x1f8 // backlink u1 value @@ -547,8 +545,8 @@ #define INDEX_COUNT_MAX64 20 // max active items #define DESC_COUNT_MAX64 15 // max active items -#define BLOCK_SIZE (size_t)((pf->do_read64) ? BLOCK_SIZE64 : BLOCK_SIZE32) -#define DESC_BLOCK_SIZE (size_t)((pf->do_read64) ? DESC_BLOCK_SIZE64 : DESC_BLOCK_SIZE32) +#define BLOCK_SIZE 512 // index blocks +#define DESC_BLOCK_SIZE 512 // descriptor blocks #define ITEM_COUNT_OFFSET (size_t)((pf->do_read64) ? ITEM_COUNT_OFFSET64 : ITEM_COUNT_OFFSET32) #define LEVEL_INDICATOR_OFFSET (size_t)((pf->do_read64) ? LEVEL_INDICATOR_OFFSET64 : LEVEL_INDICATOR_OFFSET32) #define BACKLINK_OFFSET (size_t)((pf->do_read64) ? BACKLINK_OFFSET64 : BACKLINK_OFFSET32) @@ -1296,8 +1294,8 @@ pst_num_array * pst_parse_block(pst_file *pf, uint64_t block_id, pst_index2_ll *i2_head, pst_num_array *na_head) { - unsigned char *buf = NULL; - size_t read_size = 0; + char *buf = NULL; + size_t read_size = 0; pst_subblocks subblocks; pst_num_array *na_ptr = NULL; pst_block_offset_pointer block_offset1; @@ -4005,7 +4003,7 @@ } -int pst_getBlockOffset(unsigned char *buf, size_t read_size, uint32_t i_offset, uint32_t offset, pst_block_offset *p) { +int pst_getBlockOffset(char *buf, size_t read_size, uint32_t i_offset, uint32_t offset, pst_block_offset *p) { uint32_t low = offset & 0xf; uint32_t of1 = offset >> 4; DEBUG_ENT("pst_getBlockOffset"); @@ -4021,6 +4019,7 @@ DEBUG_WARN(("get block offset finds from=%i(%#x), to=%i(%#x)\n", p->from, p->from, p->to, p->to)); if (p->from > p->to) { DEBUG_WARN(("get block offset from > to")); + DEBUG_RET(); return 0; } DEBUG_RET(); @@ -4054,8 +4053,7 @@ pst_index_ll * pst_getID2(pst_index2_ll *ptr, uint64_t id) { DEBUG_ENT("pst_getID2"); - DEBUG_INDEX(("Head = %p\n", ptr)); - DEBUG_INDEX(("Trying to find %#x\n", id)); + DEBUG_INDEX(("Head = %p id = %#llx\n", ptr, id)); while (ptr && (ptr->id2 != id)) { ptr = ptr->next; } @@ -4133,24 +4131,29 @@ } +/** + * Read a block of data from file into memory + * @param pf PST file + * @param offset offset in the pst file of the data + * @param size size of the block to be read + * @param buf reference to pointer to buffer. If this pointer + is non-NULL, it will first be free()d + * @return size of block read into memory + */ size_t pst_read_block_size(pst_file *pf, off_t offset, size_t size, char **buf) { - off_t fpos; size_t rsize; - DEBUG_ENT("pst_read_block_size"); DEBUG_READ(("Reading block from %#x, %i bytes\n", offset, size)); - fpos = ftell(pf->fp); - (void)fseek(pf->fp, offset, SEEK_SET); if (*buf) { DEBUG_READ(("Freeing old memory\n")); free(*buf); } - - *buf = (void*) xmalloc(size); - rsize = fread(*buf, (size_t)1, size, pf->fp); + *buf = (char*) xmalloc(size); + + rsize = pst_getAtPos(pf, offset, *buf, size); if (rsize != size) { - DEBUG_WARN(("Didn't read all that I could. fread returned less [%i instead of %i]\n", rsize, size)); + DEBUG_WARN(("Didn't read all the data. fread returned less [%i instead of %i]\n", rsize, size)); if (feof(pf->fp)) { DEBUG_WARN(("We tried to read past the end of the file at [offset %#x, size %#x]\n", offset, size)); } else if (ferror(pf->fp)) { @@ -4158,12 +4161,10 @@ } else { DEBUG_WARN(("I can't tell why it failed\n")); } - size = rsize; } - (void)fseek(pf->fp, fpos, SEEK_SET); DEBUG_RET(); - return size; + return rsize; } @@ -4214,51 +4215,81 @@ uint64_t buf64; uint32_t buf32; if (pf->do_read64) { - (void)pst_getAtPos(pf->fp, pos, &buf64, sizeof(buf64)); + (void)pst_getAtPos(pf, pos, &buf64, sizeof(buf64)); LE64_CPU(buf64); return buf64; } else { - (void)pst_getAtPos(pf->fp, pos, &buf32, sizeof(buf32)); + (void)pst_getAtPos(pf, pos, &buf32, sizeof(buf32)); LE32_CPU(buf32); return buf32; } } - -int pst_getAtPos(FILE *fp, off_t pos, void* buf, size_t size) { +/** + * Read part of the pst file. + * + * @param pf PST file structure + * @param pos offset of the data in the pst file + * @param buf buffer to contain the data + * @param size size of the buffer and the amount of data to be read + * @return actual read size, 0 if seek error + */ + +size_t pst_getAtPos(pst_file *pf, off_t pos, void* buf, size_t size) { + size_t rc; DEBUG_ENT("pst_getAtPos"); - if (fseek(fp, pos, SEEK_SET) == -1) { +// pst_block_recorder **t = &pf->block_head; +// pst_block_recorder *p = pf->block_head; +// while (p && ((p->offset+p->size) <= pos)) { +// t = &p->next; +// p = p->next; +// } +// if (p && (p->offset <= pos) && (pos < (p->offset+p->size))) { +// // bump the count +// p->readcount++; +// } else { +// // add a new block +// pst_block_recorder *tail = *t; +// p = (pst_block_recorder*)xmalloc(sizeof(*p)); +// *t = p; +// p->next = tail; +// p->offset = pos; +// p->size = size; +// p->readcount = 1; +// } +// DEBUG_MAIN(("pst file old offset %#llx old size %#x read count %i offset %#llx size %#x\n", +// p->offset, p->size, p->readcount, pos, size)); + + if (fseek(pf->fp, pos, SEEK_SET) == -1) { DEBUG_RET(); - return 1; + return 0; } - if (fread(buf, (size_t)1, size, fp) < size) { - DEBUG_RET(); - return 2; - } + rc = fread(buf, (size_t)1, size, pf->fp); DEBUG_RET(); - return 0; + return rc; } /** * Get an ID block from file using _pst_ff_getIDblock and decrypt if necessary - * @param pf PST file structure - * @param id ID of block to retrieve - * @param b Reference to pointer that will be set to new block. Any memory - pointed to by buffer will be free()d beforehand - * @return Size of block pointed to by *b + * + * @param pf PST file structure + * @param id ID of block to retrieve + * @param buf Reference to pointer that will be set to new block. Any memory + pointed to by buffer will be free()d beforehand + * @return Size of block pointed to by *b */ -size_t pst_ff_getIDblock_dec(pst_file *pf, uint64_t id, unsigned char **b) { +size_t pst_ff_getIDblock_dec(pst_file *pf, uint64_t id, char **buf) { size_t r; int noenc = (int)(id & 2); // disable encryption DEBUG_ENT("pst_ff_getIDblock_dec"); DEBUG_INDEX(("for id %#x\n", id)); - r = pst_ff_getIDblock(pf, id, b); + r = pst_ff_getIDblock(pf, id, buf); if ((pf->encryption) && !(noenc)) { - (void)pst_decrypt(*b, r, pf->encryption); + (void)pst_decrypt(*buf, r, pf->encryption); } - DEBUG_HEXDUMPC(*b, r, 16); + DEBUG_HEXDUMPC(*buf, r, 16); DEBUG_RET(); return r; } @@ -4266,47 +4297,31 @@ /** * Read a block of data from file into memory - * @param pf PST file - * @param id identifier of block to read - * @param b reference to pointer to buffer. If this pointer - is non-NULL, it will first be free()d - * @return size of block read into memory + * @param pf PST file + * @param id identifier of block to read + * @param buf reference to pointer to buffer. If this pointer + is non-NULL, it will first be free()d + * @return size of block read into memory */ -size_t pst_ff_getIDblock(pst_file *pf, uint64_t id, unsigned char** b) { +size_t pst_ff_getIDblock(pst_file *pf, uint64_t id, char** buf) { pst_index_ll *rec; - size_t rsize = 0; + size_t rsize; DEBUG_ENT("pst_ff_getIDblock"); - if ((rec = pst_getID(pf, id)) == NULL) { + rec = pst_getID(pf, id); + if (!rec) { DEBUG_INDEX(("Cannot find ID %#llx\n", id)); DEBUG_RET(); return 0; } - (void)fseek(pf->fp, rec->offset, SEEK_SET); - if (*b) { - DEBUG_INDEX(("freeing old memory in b\n")); - free(*b); - } - DEBUG_INDEX(("id = %#llx, record size = %#x, offset = %#x\n", id, rec->size, rec->offset)); - *b = (char*) xmalloc(rec->size+1); - rsize = fread(*b, (size_t)1, rec->size, pf->fp); - if (rsize != rec->size) { - DEBUG_WARN(("Didn't read all the size. fread returned less [%i instead of %i]\n", rsize, rec->size)); - if (feof(pf->fp)) { - DEBUG_WARN(("We tried to read past the end of the file [offset %#x, size %#x]\n", rec->offset, rec->size)); - } else if (ferror(pf->fp)) { - DEBUG_WARN(("Some error occured on the file stream\n")); - } else { - DEBUG_WARN(("No error has been set on the file stream\n")); - } - } + rsize = pst_read_block_size(pf, rec->offset, rec->size, buf); DEBUG_RET(); return rsize; } #define PST_PTR_BLOCK_SIZE 0x120 -size_t pst_ff_getID2block(pst_file *pf, uint64_t id2, pst_index2_ll *id2_head, unsigned char** buf) { +size_t pst_ff_getID2block(pst_file *pf, uint64_t id2, pst_index2_ll *id2_head, char** buf) { size_t ret; pst_index_ll* ptr; pst_holder h = {buf, NULL, 0, "", 0}; @@ -4326,7 +4341,7 @@ size_t pst_ff_getID2data(pst_file *pf, pst_index_ll *ptr, pst_holder *h) { size_t ret; - unsigned char *b = NULL, *t; + char *b = NULL, *t; DEBUG_ENT("pst_ff_getID2data"); if (!(ptr->id & 0x02)) { ret = pst_ff_getIDblock_dec(pf, ptr->id, &b); @@ -4351,8 +4366,8 @@ DEBUG_READ(("Assuming it is a multi-block record because of it's id\n")); ret = pst_ff_compile_ID(pf, ptr->id, h, (size_t)0); } - if (h->buf && *h->buf) - (*(h->buf))[ret]='\0'; + // bogus null termination off the end of the buffer!! + //if (h->buf && *h->buf) (*(h->buf))[ret]='\0'; DEBUG_RET(); return ret; } @@ -4361,8 +4376,8 @@ size_t pst_ff_compile_ID(pst_file *pf, uint64_t id, pst_holder *h, size_t size) { size_t z, a, b; uint16_t count, y; - unsigned char * buf3 = NULL, *buf2 = NULL, *t; - unsigned char *b_ptr; + char * buf3 = NULL, *buf2 = NULL, *t; + char *b_ptr; pst_block_hdr block_hdr; pst_table3_rec table3_rec; //for type 3 (0x0101) blocks @@ -4370,6 +4385,7 @@ a = pst_ff_getIDblock(pf, id, &buf3); if (!a) { if (buf3) free(buf3); + DEBUG_RET(); return 0; } DEBUG_HEXDUMPC(buf3, a, 0x10); @@ -4409,6 +4425,7 @@ DEBUG_WARN(("call to getIDblock returned zero %i\n", z)); if (buf2) free(buf2); free(buf3); + DEBUG_RET(); return z; } if (h->buf) {
--- a/src/libpst.h Tue Jan 22 14:39:02 2008 -0800 +++ b/src/libpst.h Thu Jan 31 08:03:30 2008 -0800 @@ -480,11 +480,19 @@ } pst_x_attrib_ll; +typedef struct pst_block_recorder { + struct pst_block_recorder *next; + off_t offset; + size_t size; + int readcount; +} pst_block_recorder; + + typedef struct pst_file { pst_index_ll *i_head, *i_tail; - pst_index2_ll *i2_head; - pst_desc_ll *d_head, *d_tail; + pst_desc_ll *d_head, *d_tail; pst_x_attrib_ll *x_head; + pst_block_recorder *block_head; //set this to 0 to read 32-bit pst files (pre Outlook 2003) //set this to 1 to read 64-bit pst files (Outlook 2003 and later) @@ -508,18 +516,18 @@ typedef struct pst_block_offset_pointer { - unsigned char *from; - unsigned char *to; - int needfree; + char *from; + char *to; + int needfree; } pst_block_offset_pointer; typedef struct pst_num_item { - uint32_t id; // not an id1 or id2, this is actually some sort of type code - unsigned char *data; - uint32_t type; - size_t size; - char *extra; + uint32_t id; // not an id1 or id2, this is actually some sort of type code + char *data; + uint32_t type; + size_t size; + char *extra; } pst_num_item; @@ -533,7 +541,7 @@ typedef struct pst_holder { - unsigned char **buf; + char **buf; FILE * fp; int base64; char base64_extra_chars[3]; @@ -542,9 +550,9 @@ typedef struct pst_subblock { - unsigned char *buf; - size_t read_size; - size_t i_offset; + char *buf; + size_t read_size; + size_t i_offset; } pst_subblock; @@ -558,7 +566,7 @@ int pst_open(pst_file *pf, char *name, char *mode); int pst_close(pst_file *pf); pst_desc_ll * pst_getTopOfFolders(pst_file *pf, pst_item *root); -size_t pst_attach_to_mem(pst_file *pf, pst_item_attach *attach, unsigned char **b); +size_t pst_attach_to_mem(pst_file *pf, pst_item_attach *attach, char **b); size_t pst_attach_to_file(pst_file *pf, pst_item_attach *attach, FILE* fp); size_t pst_attach_to_file_base64(pst_file *pf, pst_item_attach *attach, FILE* fp); int pst_load_index (pst_file *pf); @@ -578,7 +586,7 @@ void pst_free_desc (pst_desc_ll *head); void pst_free_xattrib(pst_x_attrib_ll *x); int pst_getBlockOffsetPointer(pst_file *pf, pst_index2_ll *i2_head, pst_subblocks *subblocks, uint32_t offset, pst_block_offset_pointer *p); -int pst_getBlockOffset(unsigned char *buf, size_t read_size, uint32_t i_offset, uint32_t offset, pst_block_offset *p); +int pst_getBlockOffset(char *buf, size_t read_size, uint32_t i_offset, uint32_t offset, pst_block_offset *p); pst_index2_ll* pst_build_id2(pst_file *pf, pst_index_ll* list, pst_index2_ll* head_ptr); pst_index_ll* pst_getID(pst_file* pf, uint64_t id); pst_index_ll* pst_getID2(pst_index2_ll * ptr, uint64_t id); @@ -587,10 +595,10 @@ int pst_decrypt(unsigned char *buf, size_t size, unsigned char type); uint64_t pst_getIntAt(pst_file *pf, char *buf); uint64_t pst_getIntAtPos(pst_file *pf, off_t pos); -int pst_getAtPos(FILE *fp, off_t pos, void* buf, size_t size); -size_t pst_ff_getIDblock_dec(pst_file *pf, uint64_t id, unsigned char **b); -size_t pst_ff_getIDblock(pst_file *pf, uint64_t id, unsigned char** b); -size_t pst_ff_getID2block(pst_file *pf, uint64_t id2, pst_index2_ll *id2_head, unsigned char** buf); +size_t pst_getAtPos(pst_file *pf, off_t pos, void* buf, size_t size); +size_t pst_ff_getIDblock_dec(pst_file *pf, uint64_t id, char **b); +size_t pst_ff_getIDblock(pst_file *pf, uint64_t id, char** b); +size_t pst_ff_getID2block(pst_file *pf, uint64_t id2, pst_index2_ll *id2_head, char** buf); size_t pst_ff_getID2data(pst_file *pf, pst_index_ll *ptr, pst_holder *h); size_t pst_ff_compile_ID(pst_file *pf, uint64_t id, pst_holder *h, size_t size);
--- a/src/lspst.c Tue Jan 22 14:39:02 2008 -0800 +++ b/src/lspst.c Thu Jan 31 08:03:30 2008 -0800 @@ -145,6 +145,7 @@ } } close_enter_dir(&ff); + DEBUG_RET(); }
--- a/src/pst2ldif.cpp Tue Jan 22 14:39:02 2008 -0800 +++ b/src/pst2ldif.cpp Thu Jan 31 08:03:30 2008 -0800 @@ -147,7 +147,7 @@ pst_item *item = NULL; while (d_ptr) { if (d_ptr->desc) { - item = (pst_item*)pst_parse_item(&pstfile, d_ptr); + item = pst_parse_item(&pstfile, d_ptr); DEBUG_INFO(("item pointer is %p\n", item)); if (item) { if (item->message_store) {
--- a/src/readpst.c Tue Jan 22 14:39:02 2008 -0800 +++ b/src/readpst.c Thu Jan 31 08:03:30 2008 -0800 @@ -330,6 +330,7 @@ int l=0; if (NULL == (fp = fopen(fname, "rb"))) { fprintf(stderr, "Couldn't open file %s\n", fname ); + DEBUG_RET(); return 1; } @@ -339,9 +340,11 @@ if (l != fwrite( buf, 1, l, stdout)) { fprintf(stderr, "Couldn't output to stdout?\n"); + DEBUG_RET(); return 1; } } + DEBUG_RET(); return 0; } @@ -662,8 +665,10 @@ // my_stristr varies from strstr in that its searches are case-insensitive char *x=haystack, *y=needle, *z = NULL; DEBUG_ENT("my_stristr"); - if (!haystack || !needle) + if (!haystack || !needle) { + DEBUG_RET(); return NULL; + } while (*y != '\0' && *x != '\0') { if (tolower(*y) == tolower(*x)) { // move y on one @@ -687,6 +692,7 @@ DEBUG_ENT("check_filename"); if (!t) { DEBUG_RET(); + return; } while ((t = strpbrk(t, "/\\:"))) { // while there are characters in the second string that we don't want @@ -767,6 +773,7 @@ enc = base64_encode (current_attach->data, current_attach->size); if (!enc) { DEBUG_EMAIL(("ERROR base64_encode returned NULL. Must have failed\n")); + DEBUG_RET(); return; } }
--- a/src/readpstlog.c Tue Jan 22 14:39:02 2008 -0800 +++ b/src/readpstlog.c Thu Jan 31 08:03:30 2008 -0800 @@ -21,219 +21,223 @@ int is_in(int a, int *b, int c); int main(int argc, char** argv) { - int level = 0; + int identity = 0; + int level = 0; off_t *i = NULL; - int x, ptr, stop=0, flag; - char *fname, *buf, rec_type; - unsigned char version; - int *show_type=NULL, show_size=0; - int *ex_type=NULL, ex_size=0; - unsigned int funcname=0, filename=0, text=0, end=0, dtype=0, line=0, c; - FILE *fp; - struct pst_debug_file_rec_m mfile_rec; - struct pst_debug_file_rec_l lfile_rec; - char format = 'D'; // default - while ((c = getopt(argc, argv, "f:t:x:")) != -1) { - switch(c) { - case 'f': - // change the output format - format = toupper(optarg[0]); - break; - case 't': - //change the type of statements shown - show_size = split_args(optarg, &show_type); - // type = atoi(optarg); - break; - case 'x': - // change the type of statements excluded - ex_size = split_args(optarg, &ex_type); - break; - } - } - if (argc > optind) { - fname = argv[optind++]; - } else { - usage(); - exit(2); - } + int x, ptr, stop=0, flag; + char *fname, *buf, rec_type; + unsigned char version; + int *show_type=NULL, show_size=0; + int *ex_type=NULL, ex_size=0; + unsigned int funcname=0, filename=0, text=0, end=0, dtype=0, line=0, c; + FILE *fp; + struct pst_debug_file_rec_m mfile_rec; + struct pst_debug_file_rec_l lfile_rec; + char format = 'D'; // default + while ((c = getopt(argc, argv, "f:t:x:")) != -1) { + switch(c) { + case 'f': + // change the output format + format = toupper(optarg[0]); + break; + case 't': + //change the type of statements shown + show_size = split_args(optarg, &show_type); + // type = atoi(optarg); + break; + case 'x': + // change the type of statements excluded + ex_size = split_args(optarg, &ex_type); + break; + } + } + if (argc > optind) { + fname = argv[optind++]; + } else { + usage(); + exit(2); + } - fp = fopen(fname, "rb"); - if (fp == NULL) { - printf("Error. couldn't open debug file\n"); - return 2; - } - if (get(&version, sizeof(char), 1, fp)==0) { - printf("Error. could not read version byte from front of file"); - return 3; - } + fp = fopen(fname, "rb"); + if (fp == NULL) { + printf("Error. couldn't open debug file\n"); + return 2; + } + if (get(&version, sizeof(char), 1, fp)==0) { + printf("Error. could not read version byte from front of file"); + return 3; + } - if (version > DEBUG_VERSION) { - printf("Version number is higher than the format I know about."); - return 4; - } + if (version > DEBUG_VERSION) { + printf("Version number is higher than the format I know about."); + return 4; + } - buf = (char*) xmalloc(BUF_SIZE); + buf = (char*) xmalloc(BUF_SIZE); - while (!stop) { + while (!stop) { off_t temp; - if (fread(&temp, sizeof(off_t), 1, fp)<=0) break; + if (fread(&temp, sizeof(off_t), 1, fp)<=0) break; x = (int)temp; - ptr = 0; - if (x > 0) { - if (i) free(i); - i = (off_t*)xmalloc(sizeof(off_t)*(x+1)); - // plus 1 cause we want to read the offset of the next index - if (get(i, sizeof(off_t), x+1, fp)==0) { - // we have reached the end of the debug file - printf("oh dear. we must now end\n"); - break; - } - while (ptr < x) { - fseek(fp, i[ptr++], SEEK_SET); - get(&rec_type, 1, sizeof(char), fp); - if (rec_type == 'L') { - get(&lfile_rec, sizeof(lfile_rec), 1, fp); - funcname=lfile_rec.funcname; - filename=lfile_rec.filename; - text = lfile_rec.text; - end = lfile_rec.end; - dtype = lfile_rec.type; - line = lfile_rec.line; - } else if (rec_type == 'M') { - get(&mfile_rec, sizeof(mfile_rec), 1, fp); - funcname = mfile_rec.funcname; - filename = mfile_rec.filename; - text = mfile_rec.text; - end = mfile_rec.end; - dtype = mfile_rec.type; - line = mfile_rec.line; - } - if (dtype == DEBUG_FUNCENT_NO) level++; - if ((show_type == NULL || is_in(dtype, show_type, show_size)) && - (ex_type == NULL || !is_in(dtype, ex_type, ex_size))) { - c = 0; flag = 0; - while (c < end) { - int ii = (level-1) * 4; - if (ii < 0) ii = 0; - if (ii > 64) ii = 64; - char indent[ii+1]; - memset(indent, ' ', ii); - indent[ii] = '\0'; - if (c + (BUF_SIZE-1) < end) { - get(buf, 1, BUF_SIZE-1, fp); - buf[BUF_SIZE-1] = '\0'; - c += BUF_SIZE-1; - } else { - get(buf, 1, end-c, fp); - buf[end-c] = '\0'; - c = end; - } - if (flag == 0) { - if (format == 'I') { // indented text format - char *b = buf+text; - printf("%s %s/%s[%d]: ", indent, &buf[filename], &buf[funcname], line); - while (b) { - char *p = strchr(b, '\n'); - if (p) { - *p = '\0'; - printf("%s\n%s ", b, indent); - b = p + 1; - } - else { - printf("%s", b); - b = NULL; - } - } - } - else if (format == 'T') { // text format - printf("%s/%s[%d]: %s", &buf[filename], &buf[funcname], line, &buf[text]); - } else { - printf("Type: %d\nFile[line]: %s[%d]\nFunction:%s\nText:%s", dtype, - &buf[filename], line, &buf[funcname], &buf[text]); - } - flag = 1; - } else { - if (format == 'I') { - char *b = buf; - while (b) { - char *p = strchr(b, '\n'); - if (p) { - *p = '\0'; - printf("%s\n%s ", b, indent); - b = p + 1; - } - else { - printf("%s", b); - b = NULL; - } - } - } - else printf("%s", buf); - } - } - printf("\n"); - } - if (dtype == DEBUG_FUNCRET_NO) level--; - } - if (fseek(fp, i[ptr], SEEK_SET)==-1) { - printf("finished\n"); - break; - } - } else { - printf("...no more items\n"); - break; - } - } - free(buf); - fclose(fp); - return 0; + ptr = 0; + if (x > 0) { + if (i) free(i); + i = (off_t*)xmalloc(sizeof(off_t)*(x+1)); + // plus 1 cause we want to read the offset of the next index + if (get(i, sizeof(off_t), x+1, fp)==0) { + // we have reached the end of the debug file + printf("oh dear. we must now end\n"); + break; + } + while (ptr < x) { + fseek(fp, i[ptr++], SEEK_SET); + get(&rec_type, 1, sizeof(char), fp); + if (rec_type == 'L') { + get(&lfile_rec, sizeof(lfile_rec), 1, fp); + funcname=lfile_rec.funcname; + filename=lfile_rec.filename; + text = lfile_rec.text; + end = lfile_rec.end; + dtype = lfile_rec.type; + line = lfile_rec.line; + } else if (rec_type == 'M') { + get(&mfile_rec, sizeof(mfile_rec), 1, fp); + funcname = mfile_rec.funcname; + filename = mfile_rec.filename; + text = mfile_rec.text; + end = mfile_rec.end; + dtype = mfile_rec.type; + line = mfile_rec.line; + } + if (dtype == DEBUG_FUNCENT_NO) level++; + if ((show_type == NULL || is_in(dtype, show_type, show_size)) && + (ex_type == NULL || !is_in(dtype, ex_type, ex_size))) { + c = 0; flag = 0; + while (c < end) { + int ii = (level-1) * 4; + if (ii < 0) ii = 0; + if (ii > 64) ii = 64; + char indent[ii+1]; + memset(indent, ' ', ii); + indent[ii] = '\0'; + if (c + (BUF_SIZE-1) < end) { + get(buf, 1, BUF_SIZE-1, fp); + buf[BUF_SIZE-1] = '\0'; + c += BUF_SIZE-1; + } else { + get(buf, 1, end-c, fp); + buf[end-c] = '\0'; + c = end; + } + if (flag == 0) { + if (format == 'I') { // indented text format + char *b = buf+text; + identity++; + //printf("%s %d %s/%s[%d]: ", indent, identity, &buf[filename], &buf[funcname], line); + printf("%s %s/%s[%d]: ", indent, &buf[filename], &buf[funcname], line); + while (b) { + char *p = strchr(b, '\n'); + if (p) { + *p = '\0'; + printf("%s\n%s ", b, indent); + b = p + 1; + } + else { + printf("%s", b); + b = NULL; + } + } + } + else if (format == 'T') { // text format + printf("%s/%s[%d]: %s", &buf[filename], &buf[funcname], line, &buf[text]); + } else { + printf("Type: %d\nFile[line]: %s[%d]\nFunction:%s\nText:%s", dtype, + &buf[filename], line, &buf[funcname], &buf[text]); + } + flag = 1; + } else { + if (format == 'I') { + char *b = buf; + while (b) { + char *p = strchr(b, '\n'); + if (p) { + *p = '\0'; + printf("%s\n%s ", b, indent); + b = p + 1; + } + else { + printf("%s", b); + b = NULL; + } + } + } + else printf("%s", buf); + } + } + printf("\n"); + } + if (dtype == DEBUG_FUNCRET_NO) level--; + } + if (fseek(fp, i[ptr], SEEK_SET)==-1) { + printf("finished\n"); + break; + } + } else { + printf("...no more items\n"); + break; + } + } + free(buf); + fclose(fp); + if (format == 'I') printf("final indent level = %i\n", level); + return 0; } size_t get(void *buf, int size, unsigned int count, FILE *fp) { - size_t z; - if ((z=fread(buf, size, count, fp)) < count) { - printf("Read Failed! (size=%d, count=%d,z=%ld)\n", size, count, (long)z); - exit(1); - } - return z; + size_t z; + if ((z=fread(buf, size, count, fp)) < count) { + printf("Read Failed! (size=%d, count=%d,z=%ld)\n", size, count, (long)z); + exit(1); + } + return z; } int usage() { - printf("readlog -t[show_type] -x[exclude_type] -f[format] filename\n"); - printf("\tformat:\n\t\tt: text log format\n"); - printf("\t\ti: indented text log format\n"); - printf("\tshow_type:\n\t\tcomma separated list of types to show " - "[ie, 2,4,1,6]\n"); - printf("\texclude_type:\n\t\tcomma separated list of types to exclude " - "[ie, 1,5,3,7]\n"); - return 0; + printf("readlog -t[show_type] -x[exclude_type] -f[format] filename\n"); + printf("\tformat:\n\t\tt: text log format\n"); + printf("\t\ti: indented text log format\n"); + printf("\tshow_type:\n\t\tcomma separated list of types to show " + "[ie, 2,4,1,6]\n"); + printf("\texclude_type:\n\t\tcomma separated list of types to exclude " + "[ie, 1,5,3,7]\n"); + return 0; } int split_args(char *args, int **targ) { - int count = 1, *i, x, z; - char *tmp = args, *y; - if (*targ != NULL) { - free(*targ); - } - // find the number of tokens in the string. Starting - // from 1 cause there will always be one - while ((tmp = strchr(tmp, ',')) != NULL) { - tmp++; count++; - } - *targ = (int*)xmalloc(count * sizeof(int)); - i = *targ; // for convienience - tmp = args; - z = 0; - for (x = 0; x < count; x++) { - y = strtok(tmp, ","); - tmp = NULL; // must be done after first call - if (y != NULL) { - i[x] = atoi(y); - z++; - } - } - return z; + int count = 1, *i, x, z; + char *tmp = args, *y; + if (*targ != NULL) { + free(*targ); + } + // find the number of tokens in the string. Starting + // from 1 cause there will always be one + while ((tmp = strchr(tmp, ',')) != NULL) { + tmp++; count++; + } + *targ = (int*)xmalloc(count * sizeof(int)); + i = *targ; // for convienience + tmp = args; + z = 0; + for (x = 0; x < count; x++) { + y = strtok(tmp, ","); + tmp = NULL; // must be done after first call + if (y != NULL) { + i[x] = atoi(y); + z++; + } + } + return z; } @@ -241,13 +245,13 @@ // the size of which is specified with the third arg. If the second // arg is NULL, then it is obvious that it is not there. int is_in(int a, int *b, int c){ - int d = 0; - if (b == NULL || c == 0) { // no array or no items in array - return 0; - } - while (d < c) { - if (a == b[d]) return 1; - d++; - } - return 0; + int d = 0; + if (b == NULL || c == 0) { // no array or no items in array + return 0; + } + while (d < c) { + if (a == b[d]) return 1; + d++; + } + return 0; }
--- a/xml/libpst.in Tue Jan 22 14:39:02 2008 -0800 +++ b/xml/libpst.in Thu Jan 31 08:03:30 2008 -0800 @@ -23,7 +23,7 @@ <refentry id="readpst.1"> <refentryinfo> - <date>2008-01-19</date> + <date>2008-01-27</date> </refentryinfo> <refmeta> @@ -206,9 +206,9 @@ </refsect1> <refsect1 id='readpst.version.1'> - <title>CVS Version</title> + <title>Version</title> <para> - $Id$ + @VERSION@ </para> </refsect1> </refentry> @@ -216,7 +216,7 @@ <refentry id="lspst.1"> <refentryinfo> - <date>2008-01-19</date> + <date>2008-01-27</date> </refentryinfo> <refmeta> @@ -309,9 +309,9 @@ </refsect1> <refsect1 id='lspst.version.1'> - <title>CVS Version</title> + <title>Version</title> <para> - $Id$ + @VERSION@ </para> </refsect1> </refentry> @@ -319,7 +319,7 @@ <refentry id="readpstlog.1"> <refentryinfo> - <date>2008-01-19</date> + <date>2008-01-27</date> </refentryinfo> <refmeta> @@ -484,9 +484,9 @@ </refsect1> <refsect1 id='readpstlog.version.1'> - <title>CVS Version</title> + <title>Version</title> <para> - $Id$ + @VERSION@ </para> </refsect1> </refentry> @@ -494,7 +494,7 @@ <refentry id="pst2ldif.1"> <refentryinfo> - <date>2008-01-19</date> + <date>2008-01-27</date> </refentryinfo> <refmeta> @@ -608,9 +608,9 @@ </refsect1> <refsect1 id='pst2ldif.version.1'> - <title>CVS Version</title> + <title>Version</title> <para> - $Id$ + @VERSION@ </para> </refsect1> </refentry> @@ -618,7 +618,7 @@ <refentry id="pst.5"> <refentryinfo> - <date>2008-01-19</date> + <date>2008-01-27</date> </refentryinfo> <refmeta> @@ -772,7 +772,7 @@ <refsect1 id='pst.file.node1.32.5'> <title>32 bit Index 1 Node</title> <para> - The 32 bit index1 b-tree nodes are 516 byte blocks with the + The 32 bit index1 b-tree nodes are 512 byte blocks with the following format. </para> <literallayout class="monospaced"><![CDATA[ @@ -818,7 +818,7 @@ 01d4 00 00 00 00 00 00 00 00 00 00 00 00 01e0 00 00 00 00 00 00 00 00 00 00 00 00 01ec 00 00 00 00 02 29 0c 02 80 80 b6 4a -01f8 b4 1e 02 00 27 9c cc 56 58 27 03 00 +01f8 b4 1e 02 00 27 9c cc 56 01f0 itemCount [1 byte] 0x02 in this case 01f1 maxItemCount [1 byte] 0x29 constant @@ -912,7 +912,7 @@ <refsect1 id='pst.file.leaf1.32.5'> <title>32 bit Index 1 Leaf Node</title> <para> - The 32 bit index1 b-tree leaf nodes are 516 byte blocks with the + The 32 bit index1 b-tree leaf nodes are 512 byte blocks with the following format. </para> <literallayout class="monospaced"><![CDATA[ @@ -958,7 +958,7 @@ 01d4 64 02 00 00 80 fb 00 00 bf 07 02 00 01e0 64 02 00 00 80 fb 00 00 bf 07 02 00 01ec 00 00 00 00 1f 29 0c 00 80 80 5b b3 -01f8 5a 67 01 00 4f ae 70 a7 92 06 00 00 +01f8 5a 67 01 00 4f ae 70 a7 01f0 itemCount [1 byte] 0x1f in this case 01f1 maxItemCount [1 byte] 0x29 constant @@ -1058,7 +1058,7 @@ <refsect1 id='pst.file.node2.32.5'> <title>32 bit Index 2 Node</title> <para> - The 32 bit index2 b-tree nodes are 516 byte blocks with the + The 32 bit index2 b-tree nodes are 512 byte blocks with the following format. </para> <literallayout class="monospaced"><![CDATA[ @@ -1104,7 +1104,7 @@ 01d4 00 00 00 00 00 00 00 00 00 00 00 00 01e0 00 00 00 00 00 00 00 00 00 00 00 00 01ec 00 00 00 00 02 29 0c 02 81 81 b2 60 -01f8 bc 1e 02 00 7e 70 dc e3 21 00 00 00 +01f8 bc 1e 02 00 7e 70 dc e3 01f0 itemCount [1 byte] 0x02 in this case 01f1 maxItemCount [1 byte] 0x29 constant @@ -1198,7 +1198,7 @@ <refsect1 id='pst.file.leaf2.32.5'> <title>32 bit Index 2 Leaf Node</title> <para> - The 32 bit index2 b-tree leaf nodes are 516 byte blocks with the + The 32 bit index2 b-tree leaf nodes are 512 byte blocks with the following format. </para> <literallayout class="monospaced"><![CDATA[ @@ -1234,7 +1234,6 @@ 01D0 6d 80 00 00 34 78 02 00 00 00 00 00 00 00 00 00 01E0 6e 80 00 00 08 00 00 00 00 00 00 00 00 00 00 00 01F0 10 1f 10 00 81 81 a0 9a ae 1e 02 00 89 44 6a 0f -0200 b8 b1 03 00 01f0 itemCount [1 byte] 0x10 in this case 01f1 maxItemCount [1 byte] 0x1f constant @@ -1515,8 +1514,8 @@ 0078 Second Recipient Address 007d Email Header. This is the header that was attached to the email 0c17 Reply Requested -0c19 Second sender struct -0c1a Name of second sender struct +0c19 Second sender structure +0c1a Name of second sender structure 0c1d Second outlook name of sender 0c1e Second sender access method (SMTP, EX) 0c1f Second Sender Address