jas_tvp.h 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. /*
  2. * Copyright (c) 2001-2002 Michael David Adams.
  3. * All rights reserved.
  4. */
  5. /* __START_OF_JASPER_LICENSE__
  6. *
  7. * JasPer License Version 2.0
  8. *
  9. * Copyright (c) 2001-2006 Michael David Adams
  10. * Copyright (c) 1999-2000 Image Power, Inc.
  11. * Copyright (c) 1999-2000 The University of British Columbia
  12. *
  13. * All rights reserved.
  14. *
  15. * Permission is hereby granted, free of charge, to any person (the
  16. * "User") obtaining a copy of this software and associated documentation
  17. * files (the "Software"), to deal in the Software without restriction,
  18. * including without limitation the rights to use, copy, modify, merge,
  19. * publish, distribute, and/or sell copies of the Software, and to permit
  20. * persons to whom the Software is furnished to do so, subject to the
  21. * following conditions:
  22. *
  23. * 1. The above copyright notices and this permission notice (which
  24. * includes the disclaimer below) shall be included in all copies or
  25. * substantial portions of the Software.
  26. *
  27. * 2. The name of a copyright holder shall not be used to endorse or
  28. * promote products derived from the Software without specific prior
  29. * written permission.
  30. *
  31. * THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS
  32. * LICENSE. NO USE OF THE SOFTWARE IS AUTHORIZED HEREUNDER EXCEPT UNDER
  33. * THIS DISCLAIMER. THE SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS
  34. * "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
  35. * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
  36. * PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN NO
  37. * EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL
  38. * INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING
  39. * FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
  40. * NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
  41. * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. NO ASSURANCES ARE
  42. * PROVIDED BY THE COPYRIGHT HOLDERS THAT THE SOFTWARE DOES NOT INFRINGE
  43. * THE PATENT OR OTHER INTELLECTUAL PROPERTY RIGHTS OF ANY OTHER ENTITY.
  44. * EACH COPYRIGHT HOLDER DISCLAIMS ANY LIABILITY TO THE USER FOR CLAIMS
  45. * BROUGHT BY ANY OTHER ENTITY BASED ON INFRINGEMENT OF INTELLECTUAL
  46. * PROPERTY RIGHTS OR OTHERWISE. AS A CONDITION TO EXERCISING THE RIGHTS
  47. * GRANTED HEREUNDER, EACH USER HEREBY ASSUMES SOLE RESPONSIBILITY TO SECURE
  48. * ANY OTHER INTELLECTUAL PROPERTY RIGHTS NEEDED, IF ANY. THE SOFTWARE
  49. * IS NOT FAULT-TOLERANT AND IS NOT INTENDED FOR USE IN MISSION-CRITICAL
  50. * SYSTEMS, SUCH AS THOSE USED IN THE OPERATION OF NUCLEAR FACILITIES,
  51. * AIRCRAFT NAVIGATION OR COMMUNICATION SYSTEMS, AIR TRAFFIC CONTROL
  52. * SYSTEMS, DIRECT LIFE SUPPORT MACHINES, OR WEAPONS SYSTEMS, IN WHICH
  53. * THE FAILURE OF THE SOFTWARE OR SYSTEM COULD LEAD DIRECTLY TO DEATH,
  54. * PERSONAL INJURY, OR SEVERE PHYSICAL OR ENVIRONMENTAL DAMAGE ("HIGH
  55. * RISK ACTIVITIES"). THE COPYRIGHT HOLDERS SPECIFICALLY DISCLAIM ANY
  56. * EXPRESS OR IMPLIED WARRANTY OF FITNESS FOR HIGH RISK ACTIVITIES.
  57. *
  58. * __END_OF_JASPER_LICENSE__
  59. */
  60. /*
  61. * Tag/Value Parser
  62. *
  63. * $Id: jas_tvp.h,v 1.2 2008-05-26 09:41:51 vp153 Exp $
  64. */
  65. #ifndef JAS_TVP_H
  66. #define JAS_TVP_H
  67. /******************************************************************************\
  68. * Includes.
  69. \******************************************************************************/
  70. #include <jasper/jas_config.h>
  71. #ifdef __cplusplus
  72. extern "C" {
  73. #endif
  74. /******************************************************************************\
  75. * Types.
  76. \******************************************************************************/
  77. /* Tag information type. */
  78. typedef struct {
  79. int id;
  80. /* The ID for the tag. */
  81. char *name;
  82. /* The name of the tag. */
  83. } jas_taginfo_t;
  84. /* Tag-value parser type. */
  85. typedef struct {
  86. char *buf;
  87. /* The parsing buffer. */
  88. char *tag;
  89. /* The current tag name. */
  90. char *val;
  91. /* The current value. */
  92. char *pos;
  93. /* The current position in the parsing buffer. */
  94. } jas_tvparser_t;
  95. /******************************************************************************\
  96. * Tag information functions.
  97. \******************************************************************************/
  98. /* Lookup a tag by name. */
  99. jas_taginfo_t *jas_taginfos_lookup(jas_taginfo_t *taginfos, const char *name);
  100. /* This function returns a pointer to the specified taginfo object if it
  101. exists (i.e., the pointer is nonnull); otherwise, a pointer to a dummy
  102. object is returned. This is useful in some situations to avoid checking
  103. for a null pointer. */
  104. jas_taginfo_t *jas_taginfo_nonull(jas_taginfo_t *taginfo);
  105. /******************************************************************************\
  106. * Tag-value parser functions.
  107. \******************************************************************************/
  108. /* Create a tag-value parser for the specified string. */
  109. jas_tvparser_t *jas_tvparser_create(const char *s);
  110. /* Destroy a tag-value parser. */
  111. void jas_tvparser_destroy(jas_tvparser_t *tvparser);
  112. /* Get the next tag-value pair. */
  113. int jas_tvparser_next(jas_tvparser_t *tvparser);
  114. /* Get the tag name for the current tag-value pair. */
  115. char *jas_tvparser_gettag(jas_tvparser_t *tvparser);
  116. /* Get the value for the current tag-value pair. */
  117. char *jas_tvparser_getval(jas_tvparser_t *tvparser);
  118. #ifdef __cplusplus
  119. }
  120. #endif
  121. #endif