/usr/include/ncbi/ncbimisc.h is in libncbi6-dev 6.1.20170106-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 | /* ncbimisc.h
* ===========================================================================
*
* PUBLIC DOMAIN NOTICE
* National Center for Biotechnology Information
*
* This software/database is a "United States Government Work" under the
* terms of the United States Copyright Act. It was written as part of
* the author's official duties as a United States Government employee and
* thus cannot be copyrighted. This software/database is freely available
* to the public for use. The National Library of Medicine and the U.S.
* Government have not placed any restriction on its use or reproduction.
*
* Although all reasonable efforts have been taken to ensure the accuracy
* and reliability of the software and data, the NLM and the U.S.
* Government do not and cannot warrant the performance or results that
* may be obtained by using this software or data. The NLM and the U.S.
* Government disclaim all warranties, express or implied, including
* warranties of performance, merchantability or fitness for any particular
* purpose.
*
* Please cite the author in any work or product based on this material.
*
* ===========================================================================
*
* File Name: ncbimisc.h
*
* Author: Gish, Kans, Ostell, Schuler
*
* Version Creation Date: 10/23/91
*
* $Revision: 6.45 $
*
* File Description:
* prototypes of miscellaneous functions
*
* Modifications:
* --------------------------------------------------------------------------
* Date Name Description of modification
* ------- ---------- -----------------------------------------------------
*
* ==========================================================================
*/
#ifndef _NCBIMISC_
#define _NCBIMISC_
#undef NLM_EXTERN
#ifdef NLM_IMPORT
#define NLM_EXTERN NLM_IMPORT
#else
#define NLM_EXTERN extern
#endif
#ifdef __cplusplus
extern "C" {
#endif
/* Obtain length of ASCII representation of signed and unsigned long integers */
/* opts&1 ==> use commas before thousands, millions, etc. when |value| >=10000*/
/* opts&2 ==> use commas before thousands, millions, etc. when |value| >=1000 */
/* opts&4 ==> prepend + sign to any positive values */
NLM_EXTERN int LIBCALL Nlm_Lwidth PROTO((long x, int opts));
NLM_EXTERN int LIBCALL Nlm_Ulwidth PROTO((unsigned long x, int opts));
/* convert integers to ASCII in static storage */
/* Same 1,2,4 opts as Nlm_Lwidth and Nlm_Ulwidth */
NLM_EXTERN char * LIBCALL Nlm_Ltostr PROTO((long x, int opts));
NLM_EXTERN char * LIBCALL Nlm_Ultostr PROTO((unsigned long x, int opts));
/* Nlm_Int8tostr -- convert a signed long integer to ASCII */
NLM_EXTERN CharPtr LIBCALL Nlm_Int8tostr PROTO((Nlm_Int8 value, int opts));
/* Sorting */
NLM_EXTERN void LIBCALL Nlm_HeapSort PROTO((VoidPtr base, size_t nel, size_t width, int (LIBCALLBACK *cmp) (VoidPtr, VoidPtr) ));
/* Stable Sorting */
NLM_EXTERN void LIBCALL Nlm_StableMergeSort PROTO((VoidPtr base, size_t nel, size_t width, int (LIBCALLBACK *cmp) (VoidPtr, VoidPtr) ));
/* Platform name */
NLM_EXTERN const Nlm_Char* Nlm_PlatformName(void);
/*****************************************************************************
*
* DataVal = a universal data type
* ValNode = a linked list of DataVal
*
*****************************************************************************/
typedef union dataval {
Nlm_VoidPtr ptrvalue;
Nlm_Int8 intvalue;
Nlm_FloatHi realvalue;
Nlm_Boolean boolvalue;
Nlm_FnPtr funcvalue;
Nlm_Int8 bigintvalue;
} DataVal, PNTR DataValPtr;
typedef struct valnode {
Nlm_Uint1 choice; /* to pick a choice */
Nlm_Uint1 extended; /* extra fields reserved to NCBI allocated in structure */
DataVal data; /* attached data */
Nlm_Boolean fatal;
struct valnode PNTR next; /* next in linked list */
} ValNode, PNTR ValNodePtr;
/*****************************************************************************
*
* ValNodeNew(vnp)
* adds after last node in list if vnp not NULL
*
* ValNodeLen(vnp)
* returns the number of nodes in the linked list
*
* ValNodeAdd(head)
* adds after last node in list if *head not NULL
* If *head is NULL, sets it to the new ValNode
* returns pointer to the NEW node added
*
* ValNodeLink(head, newnode)
* adds newnode at end of chain
* if (*head == NULL) *head = newnode
* ALWAYS returns pointer to START of chain
*
* ValNodeAddStr (head, choice, str)
* adds like ValNodeAdd()
* sets newnode->choice = choice (if choice does not matter, use 0)
* sets newnode->data.ptrvalue = str
* does NOT copy str
* if str == NULL, does NOT add a ValNode
*
* ValNodeCopyStr (head, choice, str)
* adds like ValNodeAdd()
* sets newnode->choice = choice (if choice does not matter, use 0)
* sets newnode->data.ptrvalue = str
* makes a COPY of str
* if str == NULL, does NOT add a ValNode
*
* ValNodeAddInt (head, choice, value)
* adds like ValNodeAdd()
* sets newnode->choice = choice (if choice does not matter, use 0)
* sets newnode->data.intvalue = value
*
* ValNodeAddBigInt (head, choice, value)
* adds like ValNodeAdd()
* sets newnode->choice = choice (if choice does not matter, use 0)
* sets newnode->data.bigintvalue = value
*
* ValNodeAddBoolean (head, choice, value)
* adds like ValNodeAdd()
* sets newnode->choice = choice (if choice does not matter, use 0)
* sets newnode->data.boolvalue = value
*
* ValNodeAddFloat (head, choice, value)
* adds like ValNodeAdd()
* sets newnode->choice = choice (if choice does not matter, use 0)
* sets newnode->data.realvalue = value
*
* ValNodeAddPointer (head, choice, value)
* adds like ValNodeAdd()
* sets newnode->choice = choice (if choice does not matter, use 0)
* sets newnode->data.ptrvalue = value
*
* ValNodeAddFunction (head, choice, value)
* adds like ValNodeAdd()
* sets newnode->choice = choice (if choice does not matter, use 0)
* sets newnode->data.funcvalue = value
*
* ValNodeFree(vnp)
* frees whole chain of ValNodes
* Does NOT free associated data pointers
*
* ValNodeFreeData(vnp)
* frees whole chain of ValNodes
* frees associated data pointers - BEWARE of this if these are not
* allocated single memory block structures.
*
* ValNodePtr ValNodeExtract(headptr, choice)
* removes first node in chain where ->choice == choice
* rejoins chain after removing the node
* sets node->next to NULL
*
* ValNodePtr ValNodeExtractList(headptr, choice)
* removes ALL nodes in chain where ->choice == choice
* rejoins chain after removing the nodes
* returns independent chain of extracted nodes
*
* ValNodeFindNext (head, curr, choice)
* Finds next ValNode with vnp->choice == choice after curr
* If curr == NULL, starts at head of list
* If choice < 0 , returns all ValNodes
* Returns NULL, when no more found
*
* ValNodeSort (list, compar)
* Copied from SortValNode in jzcoll, renamed, for more general access
* Makes array from ValNode list, calls HeapSort, reconnects ValNode list
*
* ValNodeMergeStrs(list)
* Merges chain of val node strings into a single character array
*
*****************************************************************************/
NLM_EXTERN ValNodePtr LIBCALL ValNodeNew PROTO((ValNodePtr vnp));
NLM_EXTERN Nlm_Int4 LIBCALL ValNodeLen PROTO((ValNodePtr vnp));
NLM_EXTERN ValNodePtr LIBCALL ValNodeAdd PROTO((ValNodePtr PNTR head));
NLM_EXTERN ValNodePtr LIBCALL ValNodeLink PROTO((ValNodePtr PNTR head, ValNodePtr newnode));
NLM_EXTERN ValNodePtr LIBCALL ValNodeAddStr PROTO((ValNodePtr PNTR head, Nlm_Int2 choice, Nlm_CharPtr str));
NLM_EXTERN ValNodePtr LIBCALL ValNodeCopyStr PROTO((ValNodePtr PNTR head, Nlm_Int2 choice, const char* str));
NLM_EXTERN ValNodePtr LIBCALL ValNodeCopyStrEx PROTO((ValNodePtr PNTR head, ValNodePtr PNTR tail, Nlm_Int2 choice, const char* str));
NLM_EXTERN ValNodePtr LIBCALL ValNodeCopyStrExEx PROTO((ValNodePtr PNTR head, ValNodePtr PNTR tail, Nlm_Int2 choice, const char* str, const char* pfx, const char* sfx));
NLM_EXTERN ValNodePtr LIBCALL ValNodeAddInt PROTO((ValNodePtr PNTR head, Nlm_Int2 choice, Nlm_Int4 value));
NLM_EXTERN ValNodePtr LIBCALL ValNodeAddBigInt (ValNodePtr PNTR head, Nlm_Int2 choice, Nlm_Int8 value);
NLM_EXTERN ValNodePtr LIBCALL ValNodeAddBoolean PROTO((ValNodePtr PNTR head, Nlm_Int2 choice, Nlm_Boolean value));
NLM_EXTERN ValNodePtr LIBCALL ValNodeAddFloat PROTO((ValNodePtr PNTR head, Nlm_Int2 choice, Nlm_FloatHi value));
NLM_EXTERN ValNodePtr LIBCALL ValNodeAddPointer PROTO((ValNodePtr PNTR head, Nlm_Int2 choice, Nlm_VoidPtr value));
NLM_EXTERN ValNodePtr LIBCALL ValNodeAddPointerEx PROTO((ValNodePtr PNTR head, ValNodePtr PNTR tail, Nlm_Int2 choice, Nlm_VoidPtr value));
NLM_EXTERN ValNodePtr LIBCALL ValNodeAddFunction PROTO((ValNodePtr PNTR head, Nlm_Int2 choice, Nlm_FnPtr value));
NLM_EXTERN ValNodePtr LIBCALL ValNodeFree PROTO((ValNodePtr vnp));
NLM_EXTERN ValNodePtr LIBCALL ValNodeFreeData PROTO((ValNodePtr vnp));
NLM_EXTERN ValNodePtr LIBCALL ValNodeExtract PROTO((ValNodePtr PNTR headptr, Nlm_Int2 choice));
NLM_EXTERN ValNodePtr LIBCALL ValNodeExtractList PROTO((ValNodePtr PNTR headptr, Nlm_Int2 choice));
NLM_EXTERN ValNodePtr LIBCALL ValNodeFindNext PROTO((ValNodePtr head, ValNodePtr curr, Nlm_Int2 choice));
NLM_EXTERN ValNodePtr LIBCALL ValNodeSort PROTO((ValNodePtr list, int (LIBCALLBACK *compar) (VoidPtr, VoidPtr)));
NLM_EXTERN Nlm_Boolean LIBCALL ValNodeIsSorted PROTO((ValNodePtr list, int (LIBCALLBACK *compar) (VoidPtr, VoidPtr)));
NLM_EXTERN void LIBCALL ValNodeUnique PROTO ((ValNodePtr PNTR list, int (LIBCALLBACK *compar )PROTO ((Nlm_VoidPtr, Nlm_VoidPtr )), ValNodePtr (LIBCALLBACK *valnodefree ) PROTO ((ValNodePtr))));
NLM_EXTERN ValNodePtr LIBCALL ValNodeDupList PROTO((ValNodePtr orig, ValNodePtr (LIBCALLBACK *copy )PROTO ((ValNodePtr))));
NLM_EXTERN void LIBCALL ValNodePurge PROTO ((ValNodePtr PNTR list, Nlm_Boolean (LIBCALLBACK *do_remove ) PROTO ((ValNodePtr)), ValNodePtr (LIBCALLBACK *valnodefree ) PROTO ((ValNodePtr))));
NLM_EXTERN void LIBCALL ValNodeInsert PROTO ((ValNodePtr PNTR list, ValNodePtr new_item, int (LIBCALLBACK *compar )PROTO ((Nlm_VoidPtr, Nlm_VoidPtr ))));
NLM_EXTERN int LIBCALL ValNodeCompare PROTO ((ValNodePtr vnp1, ValNodePtr vnp2, int (LIBCALLBACK *compar) (VoidPtr, VoidPtr)));
NLM_EXTERN Nlm_CharPtr LIBCALL ValNodeMergeStrs PROTO((ValNodePtr list));
NLM_EXTERN Nlm_CharPtr LIBCALL ValNodeMergeStrsEx PROTO((ValNodePtr list, Nlm_CharPtr separator));
NLM_EXTERN Nlm_CharPtr LIBCALL ValNodeMergeStrsExEx PROTO((ValNodePtr list, Nlm_CharPtr separator, Nlm_CharPtr pfx, Nlm_CharPtr sfx));
NLM_EXTERN Nlm_CharPtr LIBCALL MergeStringArray PROTO((Nlm_CharPtr PNTR local, size_t numitems));
/* convenience structure for holding head and tail of ValNode list for efficient tail insertion */
typedef struct valnodeblock {
ValNodePtr head;
ValNodePtr tail;
} ValNodeBlock, PNTR ValNodeBlockPtr;
/*** old prototypes ******
NLM_EXTERN ValNodePtr LIBCALL ValNodeLink PROTO((ValNodePtr vnp, ValNodePtr newnode));
NLM_EXTERN ValNodePtr LIBCALL ValNodeExtract PROTO((ValNodePtr PNTR headptr, Nlm_Uint1 choice));
**************************/
NLM_EXTERN ValNodePtr LIBCALL NodeListNew PROTO((void));
NLM_EXTERN ValNodePtr LIBCALL NodeListFree PROTO((ValNodePtr head));
NLM_EXTERN Nlm_Int2 LIBCALL NodeListLen PROTO((ValNodePtr head));
NLM_EXTERN ValNodePtr LIBCALL NodeListFind PROTO((ValNodePtr head, Nlm_Int2 item, Nlm_Boolean extend));
NLM_EXTERN Nlm_Boolean LIBCALL NodeListRead PROTO((ValNodePtr head, Nlm_Int2 item, Nlm_VoidPtr ptr, size_t size));
NLM_EXTERN Nlm_Boolean LIBCALL NodeListWrite PROTO((ValNodePtr head, Nlm_Int2 item, Nlm_VoidPtr ptr, size_t size));
NLM_EXTERN Nlm_Boolean LIBCALL NodeListAppend PROTO((ValNodePtr head, Nlm_VoidPtr ptr, size_t size));
NLM_EXTERN Nlm_Boolean LIBCALL NodeListInsert PROTO((ValNodePtr head, Nlm_Int2 item, Nlm_VoidPtr ptr, size_t size));
NLM_EXTERN Nlm_Boolean LIBCALL NodeListReplace PROTO((ValNodePtr head, Nlm_Int2 item, Nlm_VoidPtr ptr, size_t size));
NLM_EXTERN Nlm_Boolean LIBCALL NodeListDelete PROTO((ValNodePtr head, Nlm_Int2 item));
/* doubly-linked lists */
typedef struct Node PNTR NodePtr;
typedef struct Node {
VoidPtr elem; /* pointer to the element */
NodePtr last; /* previous element */
NodePtr next; /* next element */
} Node;
#define ASCEND 0 /* order for ListSort */
#define DESCEND 1
/* functions for doubly-linked lists */
NLM_EXTERN NodePtr LIBCALL ListInsert PROTO((VoidPtr elem, NodePtr after));
NLM_EXTERN NodePtr LIBCALL ListInsertPrev PROTO((VoidPtr elem, NodePtr before));
NLM_EXTERN NodePtr LIBCALL ListDelete PROTO((NodePtr node));
NLM_EXTERN NodePtr LIBCALL ListGetNext PROTO((NodePtr after));
NLM_EXTERN void LIBCALL ListSwapAdj PROTO((NodePtr priornode, NodePtr nextnode));
NLM_EXTERN NodePtr LIBCALL ListSort PROTO((NodePtr sl, int (*cmpfunc)(NodePtr, NodePtr), int order));
NLM_EXTERN void LIBCALL ListBreakRing PROTO((NodePtr np));
NLM_EXTERN void LIBCALL ListConnectRing PROTO((NodePtr np));
NLM_EXTERN NodePtr LIBCALL ListStrCopy PROTO((NodePtr strlist));
NLM_EXTERN void LIBCALL ListStrDel PROTO((NodePtr np));
/****** Choice is a compact variant of ValNode **********/
typedef union _IntPnt_ {
Int4 intvalue;
Pointer ptrvalue;
} IntPnt;
typedef struct _Choice_ {
Uint1 choice;
IntPnt value;
} Choice, PNTR ChoicePtr;
#define Lwidth Nlm_Lwidth
#define Ulwidth Nlm_Ulwidth
#define Ltostr Nlm_Ltostr
#define Ultostr Nlm_Ultostr
#define HeapSort Nlm_HeapSort
#define StableMergeSort Nlm_StableMergeSort
#if defined(OS_MAC) || defined(OS_UNIX_DARWIN)
NLM_EXTERN void Nlm_CtoPstr PROTO((Nlm_CharPtr str));
NLM_EXTERN void Nlm_PtoCstr PROTO((Nlm_CharPtr str));
#endif
/* these functions reverse byte order in integers
calling the same function a second time switches it back
the native ENDIAN nature of the machine is not considered
*/
NLM_EXTERN Uint2 Nlm_SwitchUint2 PROTO ((Uint2 value));
NLM_EXTERN void Nlm_SwitchUint2Buff PROTO ((Uint2 *buff, int count));
NLM_EXTERN unsigned long Nlm_SwitchLong PROTO ((unsigned long value));
NLM_EXTERN void Nlm_SwitchLongBuff PROTO ((unsigned long *buff, int count));
NLM_EXTERN Uint4 Nlm_SwitchUint4 PROTO ((Uint4 value));
NLM_EXTERN void Nlm_SwitchUint4Buff PROTO ((Uint4 *buff, int count));
#define SwitchUint2 Nlm_SwitchUint2
#define SwitchUint2Buff Nlm_SwitchUint2Buff
#define SwitchLong Nlm_SwitchLong
#define SwitchLongBuff Nlm_SwitchLongBuff
#define SwitchUint4 Nlm_SwitchUint4
#define SwitchUint4Buff Nlm_SwitchUint4Buff
/** The following defines ALWAYS assume the value to switched is
BIG_ENDIAN. This is used to allow portable use of binary integers
in some NCBI applications such as BLAST and some indexes ****/
#ifdef IS_LITTLE_ENDIAN
#define Nlm_SwapUint2(value) Nlm_SwitchUint2(value)
#define Nlm_SwapUint2Buff(buff, count) Nlm_SwitchUint2Buff(buff, count)
#define Nlm_SwapLong(value) Nlm_SwitchLong(value)
#define Nlm_SwapLongBuff(buff, count) Nlm_SwitchLongBuff(buff, count)
#define Nlm_SwapUint4(value) Nlm_SwitchUint4(value)
#define Nlm_SwapUint4Buff(buff, count) Nlm_SwitchUint4Buff(buff, count)
#else
#define Nlm_SwapUint2(value) (value)
#define Nlm_SwapUint2Buff(buff, count)
#define Nlm_SwapLong(value) (value)
#define Nlm_SwapLongBuff(buff, count)
#define Nlm_SwapUint4(value) (value)
#define Nlm_SwapUint4Buff(buff, count)
#endif
#define SwapUint2 Nlm_SwapUint2
#define SwapUint2Buff Nlm_SwapUint2Buff
#define SwapLong Nlm_SwapLong
#define SwapLongBuff Nlm_SwapLongBuff
#define SwapUint4 Nlm_SwapUint4
#define SwapUint4Buff Nlm_SwapUint4Buff
/**
* MD5 stuff
*/
typedef struct md5context_ {
Nlm_Uint4 buf[4];
Nlm_Uint4 bits[2];
Nlm_Uchar in[64];
} Nlm_MD5Context, PNTR Nlm_MD5ContextPtr;
NLM_EXTERN void LIBCALL Nlm_MD5Init PROTO((Nlm_MD5ContextPtr context));
NLM_EXTERN void LIBCALL Nlm_MD5Update PROTO((Nlm_MD5ContextPtr context, Nlm_UcharPtr buf, Nlm_Uint4 len));
NLM_EXTERN void LIBCALL Nlm_MD5Final PROTO((Nlm_MD5ContextPtr context, Nlm_Uchar digest[16]));
NLM_EXTERN void LIBCALL Nlm_MD5Transform PROTO((Nlm_Uint4 buf[4], Nlm_Uint4 in[16]));
#define MD5Context Nlm_MD5Context
#define MD5ContextPtr Nlm_MD5ContextPtr
#define MD5Init Nlm_MD5Init
#define MD5Update Nlm_MD5Update
#define MD5Final Nlm_MD5Final
#define MD5Transform Nlm_MD5Transform
/* Error codes for the CTX_NCBIMISC context */
Uint4 Nlm_GetChecksum(CharPtr p);
/* Simple XML Parsing */
typedef struct xmlobj {
Nlm_CharPtr name;
Nlm_CharPtr contents;
Nlm_Int2 level;
struct xmlobj *attributes;
struct xmlobj *children;
struct xmlobj *next;
struct xmlobj *parent;
struct xmlobj *successor; /* linearizes a recursive exploration */
} Nlm_XmlObj, PNTR Nlm_XmlObjPtr;
#define XmlObj Nlm_XmlObj
#define XmlObjPtr Nlm_XmlObjPtr
NLM_EXTERN Nlm_XmlObjPtr ParseXmlString (
Nlm_CharPtr str
);
NLM_EXTERN void WriteXmlObject (
Nlm_XmlObjPtr xop,
FILE *fp
);
NLM_EXTERN void WriteXmlObjectEx (
Nlm_XmlObjPtr xop,
FILE *fp,
Nlm_Boolean useTabs,
Nlm_Boolean altSelfClose
);
NLM_EXTERN Nlm_XmlObjPtr FreeXmlObject (
Nlm_XmlObjPtr xop
);
NLM_EXTERN Nlm_CharPtr DecodeXml (
Nlm_CharPtr str
);
NLM_EXTERN Nlm_CharPtr EncodeXml (
Nlm_CharPtr str
);
NLM_EXTERN Nlm_CharPtr EncodeXmlEx (
Nlm_CharPtr str
);
typedef void (*VisitXmlNodeFunc) (Nlm_XmlObjPtr xop, Nlm_XmlObjPtr parent, Nlm_Int2 level, Nlm_VoidPtr userdata);
/* VisitXmlNodes does a recursive exploration from the root node */
NLM_EXTERN Nlm_Int4 VisitXmlNodes (
Nlm_XmlObjPtr xop,
Nlm_VoidPtr userdata,
VisitXmlNodeFunc callback,
Nlm_CharPtr nodeFilter,
Nlm_CharPtr parentFilter,
Nlm_CharPtr attrTagFilter,
Nlm_CharPtr attrValFilter,
Nlm_Int2 maxDepth
);
/* VisitXmlAttributes just scans attributes on the current node */
NLM_EXTERN Nlm_Int4 VisitXmlAttributes (
Nlm_XmlObjPtr xop,
Nlm_VoidPtr userdata,
VisitXmlNodeFunc callback,
Nlm_CharPtr attrTagFilter,
Nlm_CharPtr attrValFilter
);
/* XmlPathSuffixIs allows /parent/node path check to be done in the callback */
NLM_EXTERN Nlm_Boolean XmlPathSuffixIs (
Nlm_XmlObjPtr xop,
Nlm_CharPtr suffix
);
/*
Note: Use <urlquery.h> QUERY_CopyResultsToString (conn) to get XML string
directly from network connection without going through file intermediate.
*/
NLM_EXTERN Nlm_CharPtr XmlFileToString (
FILE *ifp
);
#ifdef __cplusplus
}
#endif
#undef NLM_EXTERN
#ifdef NLM_EXPORT
#define NLM_EXTERN NLM_EXPORT
#else
#define NLM_EXTERN
#endif
#endif /* !_NCBIMISC_ */
|