Files
harbour-core/harbour/external/libhpdf/hpdfdict.c
Viktor Szakats 2cc4903d82 2009-09-10 09:52 UTC+0200 Viktor Szakats (harbour.01 syenar.hu)
* external/libhpdf/Makefile
    + Enabled for all dos platforms (dos/watcom currently and
      probably all dos builds done on MS-DOS hosts).

  + external/libhpdf/ori_dst
  + external/libhpdf/ori_src
  + external/libhpdf/cnv_hb2o.bat
  + external/libhpdf/cnv_o2hb.bat
  - external/libhpdf/hpdf_annotation.c
  - external/libhpdf/hpdf_annotation.h
  - external/libhpdf/hpdf_array.c
  - external/libhpdf/hpdf_binary.c
  - external/libhpdf/hpdf_boolean.c
  - external/libhpdf/hpdf_catalog.c
  - external/libhpdf/hpdf_catalog.h
  - external/libhpdf/hpdf_conf.h
  - external/libhpdf/hpdf_config.h
  - external/libhpdf/hpdf_consts.h
  - external/libhpdf/hpdf_destination.c
  - external/libhpdf/hpdf_destination.h
  - external/libhpdf/hpdf_dict.c
  - external/libhpdf/hpdf_doc.c
  - external/libhpdf/hpdf_doc.h
  - external/libhpdf/hpdf_doc_png.c
  - external/libhpdf/hpdf_encoder.c
  - external/libhpdf/hpdf_encoder.h
  - external/libhpdf/hpdf_encoder_cns.c
  - external/libhpdf/hpdf_encoder_cnt.c
  - external/libhpdf/hpdf_encoder_jp.c
  - external/libhpdf/hpdf_encoder_kr.c
  - external/libhpdf/hpdf_encrypt.c
  - external/libhpdf/hpdf_encrypt.h
  - external/libhpdf/hpdf_encryptdict.c
  - external/libhpdf/hpdf_encryptdict.h
  - external/libhpdf/hpdf_error.c
  - external/libhpdf/hpdf_error.h
  - external/libhpdf/hpdf_ext_gstate.c
  - external/libhpdf/hpdf_ext_gstate.h
  - external/libhpdf/hpdf_font.c
  - external/libhpdf/hpdf_font.h
  - external/libhpdf/hpdf_font_cid.c
  - external/libhpdf/hpdf_font_tt.c
  - external/libhpdf/hpdf_font_type1.c
  - external/libhpdf/hpdf_fontdef.c
  - external/libhpdf/hpdf_fontdef.h
  - external/libhpdf/hpdf_fontdef_base14.c
  - external/libhpdf/hpdf_fontdef_cid.c
  - external/libhpdf/hpdf_fontdef_cns.c
  - external/libhpdf/hpdf_fontdef_cnt.c
  - external/libhpdf/hpdf_fontdef_jp.c
  - external/libhpdf/hpdf_fontdef_kr.c
  - external/libhpdf/hpdf_fontdef_tt.c
  - external/libhpdf/hpdf_fontdef_type1.c
  - external/libhpdf/hpdf_gstate.c
  - external/libhpdf/hpdf_gstate.h
  - external/libhpdf/hpdf_image.c
  - external/libhpdf/hpdf_image.h
  - external/libhpdf/hpdf_image_png.c
  - external/libhpdf/hpdf_info.c
  - external/libhpdf/hpdf_info.h
  - external/libhpdf/hpdf_list.c
  - external/libhpdf/hpdf_list.h
  - external/libhpdf/hpdf_mmgr.c
  - external/libhpdf/hpdf_mmgr.h
  - external/libhpdf/hpdf_name.c
  - external/libhpdf/hpdf_null.c
  - external/libhpdf/hpdf_number.c
  - external/libhpdf/hpdf_objects.c
  - external/libhpdf/hpdf_objects.h
  - external/libhpdf/hpdf_outline.c
  - external/libhpdf/hpdf_outline.h
  - external/libhpdf/hpdf_page_label.c
  - external/libhpdf/hpdf_page_label.h
  - external/libhpdf/hpdf_page_operator.c
  - external/libhpdf/hpdf_pages.c
  - external/libhpdf/hpdf_pages.h
  - external/libhpdf/hpdf_real.c
  - external/libhpdf/hpdf_streams.c
  - external/libhpdf/hpdf_streams.h
  - external/libhpdf/hpdf_string.c
  - external/libhpdf/hpdf_types.h
  - external/libhpdf/hpdf_u3d.c
  - external/libhpdf/hpdf_u3d.h
  - external/libhpdf/hpdf_utils.c
  - external/libhpdf/hpdf_utils.h
  - external/libhpdf/hpdf_version.h
  - external/libhpdf/hpdf_xref.c
  + external/libhpdf/hpdfanno.c
  + external/libhpdf/hpdfanno.h
  + external/libhpdf/hpdfarra.c
  + external/libhpdf/hpdfbina.c
  + external/libhpdf/hpdfbool.c
  + external/libhpdf/hpdfcata.c
  + external/libhpdf/hpdfcata.h
  + external/libhpdf/hpdfcfg.h
  + external/libhpdf/hpdfconf.h
  + external/libhpdf/hpdfcons.h
  + external/libhpdf/hpdfdest.c
  + external/libhpdf/hpdfdest.h
  + external/libhpdf/hpdfdict.c
  + external/libhpdf/hpdfdoc.c
  + external/libhpdf/hpdfdoc.h
  + external/libhpdf/hpdfdocp.c
  + external/libhpdf/hpdfecy.c
  + external/libhpdf/hpdfecyd.c
  + external/libhpdf/hpdfencc.c
  + external/libhpdf/hpdfencj.c
  + external/libhpdf/hpdfenck.c
  + external/libhpdf/hpdfencn.c
  + external/libhpdf/hpdfenco.c
  + external/libhpdf/hpdfenco.h
  + external/libhpdf/hpdfencr.h
  + external/libhpdf/hpdfency.h
  + external/libhpdf/hpdferro.c
  + external/libhpdf/hpdferro.h
  + external/libhpdf/hpdfextg.c
  + external/libhpdf/hpdfextg.h
  + external/libhpdf/hpdffdf.c
  + external/libhpdf/hpdffdf1.c
  + external/libhpdf/hpdffdfb.c
  + external/libhpdf/hpdffdfc.c
  + external/libhpdf/hpdffdfi.c
  + external/libhpdf/hpdffdfj.c
  + external/libhpdf/hpdffdfk.c
  + external/libhpdf/hpdffdfn.c
  + external/libhpdf/hpdffdft.c
  + external/libhpdf/hpdffon1.c
  + external/libhpdf/hpdffonc.c
  + external/libhpdf/hpdffond.h
  + external/libhpdf/hpdffont.c
  + external/libhpdf/hpdffont.h
  + external/libhpdf/hpdffott.c
  + external/libhpdf/hpdfgsta.c
  + external/libhpdf/hpdfgsta.h
  + external/libhpdf/hpdfimag.c
  + external/libhpdf/hpdfimag.h
  + external/libhpdf/hpdfimap.c
  + external/libhpdf/hpdfinfo.c
  + external/libhpdf/hpdfinfo.h
  + external/libhpdf/hpdflist.c
  + external/libhpdf/hpdflist.h
  + external/libhpdf/hpdfmmgr.c
  + external/libhpdf/hpdfmmgr.h
  + external/libhpdf/hpdfname.c
  + external/libhpdf/hpdfnull.c
  + external/libhpdf/hpdfnumb.c
  + external/libhpdf/hpdfobje.c
  + external/libhpdf/hpdfobje.h
  + external/libhpdf/hpdfoutl.c
  + external/libhpdf/hpdfoutl.h
  + external/libhpdf/hpdfpage.c
  + external/libhpdf/hpdfpage.h
  + external/libhpdf/hpdfpago.c
  + external/libhpdf/hpdfpags.c
  + external/libhpdf/hpdfpags.h
  + external/libhpdf/hpdfreal.c
  + external/libhpdf/hpdfstre.c
  + external/libhpdf/hpdfstre.h
  + external/libhpdf/hpdfstri.c
  + external/libhpdf/hpdftype.h
  + external/libhpdf/hpdfu3d.c
  + external/libhpdf/hpdfu3d.h
  + external/libhpdf/hpdfutil.c
  + external/libhpdf/hpdfutil.h
  + external/libhpdf/hpdfvers.h
  + external/libhpdf/hpdfxref.c
  * external/libhpdf/hpdf.h
  * external/libhpdf/Makefile
    * Converted to short filenames. Added converted scripts.

  * source/hbpcre/cnv_hb2o.bat
  * source/hbpcre/cnv_o2hb.bat
    ! Fixed typo in prev.
    * Removed PCRE references from comment texts.
2009-09-10 08:02:45 +00:00

492 lines
13 KiB
C

/*
* << Haru Free PDF Library >> -- hpdf_dict.c
*
* URL: http://libharu.org
*
* Copyright (c) 1999-2006 Takeshi Kanno <takeshi_kanno@est.hi-ho.ne.jp>
* Copyright (c) 2007-2008 Antony Dovgal <tony@daylessday.org>
*
* Permission to use, copy, modify, distribute and sell this software
* and its documentation for any purpose is hereby granted without fee,
* provided that the above copyright notice appear in all copies and
* that both that copyright notice and this permission notice appear
* in supporting documentation.
* It is provided "as is" without express or implied warranty.
*
*/
#include "hpdfconf.h"
#include "hpdfutil.h"
#include "hpdfobje.h"
HPDF_DictElement
GetElement (HPDF_Dict dict,
const char *key);
/*--------------------------------------------------------------------------*/
HPDF_Dict
HPDF_Dict_New (HPDF_MMgr mmgr)
{
HPDF_Dict obj;
obj = (HPDF_Dict)HPDF_GetMem (mmgr, sizeof(HPDF_Dict_Rec));
if (obj) {
HPDF_MemSet (obj, 0, sizeof(HPDF_Dict_Rec));
obj->header.obj_class = HPDF_OCLASS_DICT;
obj->mmgr = mmgr;
obj->error = mmgr->error;
obj->list = HPDF_List_New (mmgr, HPDF_DEF_ITEMS_PER_BLOCK);
obj->filter = HPDF_STREAM_FILTER_NONE;
if (!obj->list) {
HPDF_FreeMem (mmgr, obj);
obj = NULL;
}
}
return obj;
}
HPDF_Dict
HPDF_DictStream_New (HPDF_MMgr mmgr,
HPDF_Xref xref)
{
HPDF_Dict obj;
HPDF_Number length;
HPDF_STATUS ret = 0;
obj = HPDF_Dict_New (mmgr);
if (!obj)
return NULL;
/* only stream object is added to xref automatically */
ret += HPDF_Xref_Add (xref, obj);
if (ret != HPDF_OK)
return NULL;
length = HPDF_Number_New (mmgr, 0);
if (!length)
return NULL;
ret = HPDF_Xref_Add (xref, length);
if (ret != HPDF_OK)
return NULL;
ret = HPDF_Dict_Add (obj, "Length", length);
if (ret != HPDF_OK)
return NULL;
obj->stream = HPDF_MemStream_New (mmgr, HPDF_STREAM_BUF_SIZ);
if (!obj->stream)
return NULL;
return obj;
}
void
HPDF_Dict_Free (HPDF_Dict dict)
{
HPDF_UINT i;
if (!dict)
return;
if (dict->free_fn)
dict->free_fn (dict);
for (i = 0; i < dict->list->count; i++) {
HPDF_DictElement element =
(HPDF_DictElement)HPDF_List_ItemAt (dict->list, i);
if (element) {
HPDF_Obj_Free (dict->mmgr, element->value);
HPDF_FreeMem (dict->mmgr, element);
}
}
if (dict->stream)
HPDF_Stream_Free (dict->stream);
HPDF_List_Free (dict->list);
dict->header.obj_class = 0;
HPDF_FreeMem (dict->mmgr, dict);
}
HPDF_STATUS
HPDF_Dict_Write (HPDF_Dict dict,
HPDF_Stream stream,
HPDF_Encrypt e)
{
HPDF_UINT i;
HPDF_STATUS ret;
ret = HPDF_Stream_WriteStr (stream, "<<\012");
if (ret != HPDF_OK)
return ret;
if (dict->before_write_fn) {
if ((ret = dict->before_write_fn (dict)) != HPDF_OK)
return ret;
}
/* encrypt-dict must not be encrypted. */
if (dict->header.obj_class == (HPDF_OCLASS_DICT | HPDF_OSUBCLASS_ENCRYPT))
e = NULL;
if (dict->stream) {
/* set filter element */
if (dict->filter == HPDF_STREAM_FILTER_NONE)
HPDF_Dict_RemoveElement (dict, "Filter");
else {
HPDF_Array array = HPDF_Dict_GetItem (dict, "Filter",
HPDF_OCLASS_ARRAY);
if (!array) {
array = HPDF_Array_New (dict->mmgr);
if (!array)
return HPDF_Error_GetCode (dict->error);
ret = HPDF_Dict_Add (dict, "Filter", array);
if (ret != HPDF_OK)
return ret;
}
HPDF_Array_Clear (array);
#ifndef HPDF_NOZLIB
if (dict->filter & HPDF_STREAM_FILTER_FLATE_DECODE)
HPDF_Array_AddName (array, "FlateDecode");
#endif /* HPDF_NOZLIB */
if (dict->filter & HPDF_STREAM_FILTER_DCT_DECODE)
HPDF_Array_AddName (array, "DCTDecode");
}
}
for (i = 0; i < dict->list->count; i++) {
HPDF_DictElement element =
(HPDF_DictElement)HPDF_List_ItemAt (dict->list, i);
HPDF_Obj_Header *header = (HPDF_Obj_Header *)(element->value);
if (!element->value)
return HPDF_SetError (dict->error, HPDF_INVALID_OBJECT, 0);
if (header->obj_id & HPDF_OTYPE_HIDDEN) {
HPDF_PTRACE((" HPDF_Dict_Write obj=%p skipped obj_id=0x%08X\n",
element->value, (HPDF_UINT)header->obj_id));
} else {
ret = HPDF_Stream_WriteEscapeName (stream, element->key);
if (ret != HPDF_OK)
return ret;
ret = HPDF_Stream_WriteChar (stream, ' ');
if (ret != HPDF_OK)
return ret;
ret = HPDF_Obj_Write (element->value, stream, e);
if (ret != HPDF_OK)
return ret;
ret = HPDF_Stream_WriteStr (stream, "\012");
if (ret != HPDF_OK)
return ret;
}
}
if (dict->write_fn) {
if ((ret = dict->write_fn (dict, stream)) != HPDF_OK)
return ret;
}
if ((ret = HPDF_Stream_WriteStr (stream, ">>")) != HPDF_OK)
return ret;
if (dict->stream) {
HPDF_UINT32 strptr;
HPDF_Number length;
/* get "length" element */
length = (HPDF_Number)HPDF_Dict_GetItem (dict, "Length",
HPDF_OCLASS_NUMBER);
if (!length)
return HPDF_SetError (dict->error,
HPDF_DICT_STREAM_LENGTH_NOT_FOUND, 0);
/* "length" element must be indirect-object */
if (!(length->header.obj_id & HPDF_OTYPE_INDIRECT)) {
return HPDF_SetError (dict->error, HPDF_DICT_ITEM_UNEXPECTED_TYPE,
0);
}
if ((ret = HPDF_Stream_WriteStr (stream, "\012stream\015\012"))
!= HPDF_OK)
return ret;
strptr = stream->size;
if (e)
HPDF_Encrypt_Reset (e);
if ((ret = HPDF_Stream_WriteToStream (dict->stream, stream,
dict->filter, e)) != HPDF_OK)
return ret;
HPDF_Number_SetValue (length, stream->size - strptr);
ret = HPDF_Stream_WriteStr (stream, "\012endstream");
}
/* 2006.08.13 add. */
if (dict->after_write_fn) {
if ((ret = dict->after_write_fn (dict)) != HPDF_OK)
return ret;
}
return ret;
}
HPDF_STATUS
HPDF_Dict_Add (HPDF_Dict dict,
const char *key,
void *obj)
{
HPDF_Obj_Header *header;
HPDF_STATUS ret = HPDF_OK;
HPDF_DictElement element;
if (!obj) {
if (HPDF_Error_GetCode (dict->error) == HPDF_OK)
return HPDF_SetError (dict->error, HPDF_INVALID_OBJECT, 0);
else
return HPDF_INVALID_OBJECT;
}
header = (HPDF_Obj_Header *)obj;
if (header->obj_id & HPDF_OTYPE_DIRECT)
return HPDF_SetError (dict->error, HPDF_INVALID_OBJECT, 0);
if (!key) {
HPDF_Obj_Free (dict->mmgr, obj);
return HPDF_SetError (dict->error, HPDF_INVALID_OBJECT, 0);
}
if (dict->list->count >= HPDF_LIMIT_MAX_DICT_ELEMENT) {
HPDF_PTRACE((" HPDF_Dict_Add exceed limitatin of dict count(%d)\n",
HPDF_LIMIT_MAX_DICT_ELEMENT));
HPDF_Obj_Free (dict->mmgr, obj);
return HPDF_SetError (dict->error, HPDF_DICT_COUNT_ERR, 0);
}
/* check whether there is an object which has same name */
element = GetElement (dict, key);
if (element) {
HPDF_Obj_Free (dict->mmgr, element->value);
element->value = NULL;
} else {
element = (HPDF_DictElement)HPDF_GetMem (dict->mmgr,
sizeof(HPDF_DictElement_Rec));
if (!element) {
/* cannot create element object */
if (!(header->obj_id & HPDF_OTYPE_INDIRECT))
HPDF_Obj_Free (dict->mmgr, obj);
return HPDF_Error_GetCode (dict->error);
}
HPDF_StrCpy (element->key, key, element->key +
HPDF_LIMIT_MAX_NAME_LEN + 1);
element->value = NULL;
ret = HPDF_List_Add (dict->list, element);
if (ret != HPDF_OK) {
if (!(header->obj_id & HPDF_OTYPE_INDIRECT))
HPDF_Obj_Free (dict->mmgr, obj);
HPDF_FreeMem (dict->mmgr, element);
return HPDF_Error_GetCode (dict->error);
}
}
if (header->obj_id & HPDF_OTYPE_INDIRECT) {
HPDF_Proxy proxy = HPDF_Proxy_New (dict->mmgr, obj);
if (!proxy)
return HPDF_Error_GetCode (dict->error);
element->value = proxy;
proxy->header.obj_id |= HPDF_OTYPE_DIRECT;
} else {
element->value = obj;
header->obj_id |= HPDF_OTYPE_DIRECT;
}
return ret;
}
HPDF_STATUS
HPDF_Dict_AddName (HPDF_Dict dict,
const char *key,
const char *value)
{
HPDF_Name name = HPDF_Name_New (dict->mmgr, value);
if (!name)
return HPDF_Error_GetCode (dict->error);
return HPDF_Dict_Add (dict, key, name);
}
HPDF_STATUS
HPDF_Dict_AddNumber (HPDF_Dict dict,
const char *key,
HPDF_INT32 value)
{
HPDF_Number number = HPDF_Number_New (dict->mmgr, value);
if (!number)
return HPDF_Error_GetCode (dict->error);
return HPDF_Dict_Add (dict, key, number);
}
HPDF_STATUS
HPDF_Dict_AddReal (HPDF_Dict dict,
const char *key,
HPDF_REAL value)
{
HPDF_Real real = HPDF_Real_New (dict->mmgr, value);
if (!real)
return HPDF_Error_GetCode (dict->error);
return HPDF_Dict_Add (dict, key, real);
}
HPDF_STATUS
HPDF_Dict_AddBoolean (HPDF_Dict dict,
const char *key,
HPDF_BOOL value)
{
HPDF_Boolean obj = HPDF_Boolean_New (dict->mmgr, value);
if (!obj)
return HPDF_Error_GetCode (dict->error);
return HPDF_Dict_Add (dict, key, obj);
}
void*
HPDF_Dict_GetItem (HPDF_Dict dict,
const char *key,
HPDF_UINT16 obj_class)
{
HPDF_DictElement element = GetElement (dict, key);
void *obj;
if (element && HPDF_StrCmp(key, element->key) == 0) {
HPDF_Obj_Header *header = (HPDF_Obj_Header *)element->value;
if (header->obj_class == HPDF_OCLASS_PROXY) {
HPDF_Proxy p = element->value;
header = (HPDF_Obj_Header *)p->obj;
obj = p->obj;
} else
obj = element->value;
if ((header->obj_class & HPDF_OCLASS_ANY) != obj_class) {
HPDF_PTRACE((" HPDF_Dict_GetItem dict=%p key=%s obj_class=0x%08X\n",
dict, key, (HPDF_UINT)header->obj_class));
HPDF_SetError (dict->error, HPDF_DICT_ITEM_UNEXPECTED_TYPE, 0);
return NULL;
}
return obj;
}
return NULL;
}
HPDF_DictElement
GetElement (HPDF_Dict dict,
const char *key)
{
HPDF_UINT i;
for (i = 0; i < dict->list->count; i++) {
HPDF_DictElement element =
(HPDF_DictElement)HPDF_List_ItemAt (dict->list, i);
if (HPDF_StrCmp (key, element->key) == 0)
return element;
}
return NULL;
}
HPDF_STATUS
HPDF_Dict_RemoveElement (HPDF_Dict dict,
const char *key)
{
HPDF_UINT i;
for (i = 0; i < dict->list->count; i++) {
HPDF_DictElement element =
(HPDF_DictElement)HPDF_List_ItemAt (dict->list, i);
if (HPDF_StrCmp (key, element->key) == 0) {
HPDF_List_Remove (dict->list, element);
HPDF_Obj_Free (dict->mmgr, element->value);
HPDF_FreeMem (dict->mmgr, element);
return HPDF_OK;
}
}
return HPDF_DICT_ITEM_NOT_FOUND;
}
const char*
HPDF_Dict_GetKeyByObj (HPDF_Dict dict,
void *obj)
{
HPDF_UINT i;
for (i = 0; i < dict->list->count; i++) {
HPDF_Obj_Header *header;
HPDF_DictElement element =
(HPDF_DictElement)HPDF_List_ItemAt (dict->list, i);
header = (HPDF_Obj_Header *)(element->value);
if (header->obj_class == HPDF_OCLASS_PROXY) {
HPDF_Proxy p = element->value;
if (p->obj == obj)
return element->key;
} else {
if (element->value == obj)
return element->key;
}
}
return NULL;
}