Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

110 lines
5.3 KiB

  1. #include <stdlib.h>
  2. #if !defined(_M_I86)
  3. // The 32-bit compiler
  4. #define __far
  5. #define __near
  6. #define __pascal
  7. #define __loadds
  8. #endif
  9. typedef char * pchar_t;
  10. typedef const char * pcchar_t;
  11. typedef void * ( __cdecl * Alloc_t )( size_t );
  12. typedef void ( __cdecl * Free_t )( void * );
  13. typedef char * ( __cdecl * GetParameter_t )( long );
  14. #ifdef __cplusplus
  15. extern "C"
  16. #endif
  17. #ifdef _CRTBLD
  18. _CRTIMP pchar_t __cdecl __unDName (
  19. #else
  20. pchar_t __cdecl unDName (
  21. #endif
  22. pchar_t, // User supplied buffer (or NULL)
  23. pcchar_t, // Input decorated name
  24. int, // Maximum length of user buffer
  25. Alloc_t, // Address of heap allocator
  26. Free_t, // Address of heap deallocator
  27. unsigned short // Feature disable flags
  28. );
  29. #ifdef __cplusplus
  30. extern "C"
  31. #endif
  32. #ifdef _CRTBLD
  33. _CRTIMP pchar_t __cdecl __unDNameEx (
  34. #else
  35. pchar_t __cdecl unDNameEx (
  36. #endif
  37. pchar_t, // User supplied buffer (or NULL)
  38. pcchar_t, // Input decorated name
  39. int, // Maximum length of user buffer
  40. Alloc_t, // Address of heap allocator
  41. Free_t, // Address of heap deallocator
  42. GetParameter_t, // Function to get any template parameters
  43. unsigned long // Feature disable flags
  44. );
  45. /*
  46. * The user may provide a buffer into which the undecorated declaration
  47. * is to be placed, in which case, the length field must be specified.
  48. * The length is the maximum number of characters (including the terminating
  49. * NULL character) which may be written into the user buffer.
  50. *
  51. * If the output buffer is NULL, the length field is ignored, and the
  52. * undecorator will allocate a buffer exactly large enough to hold the
  53. * resulting declaration. It is the users responsibility to deallocate
  54. * this buffer.
  55. *
  56. * The user may also supply the allocator and deallocator functions if
  57. * they wish. If they do, then all heap actions performed by the routine
  58. * will use the provided heap functions.
  59. *
  60. * If the allocator address is NULL, then the routine will default to using
  61. * the standard allocator and deallocator functions, 'malloc' and 'free'.
  62. *
  63. * If an error occurs internally, then the routine will return NULL. If
  64. * it was successful, it will return the buffer address provided by the
  65. * user, or the address of the buffer allocated on their behalf, if they
  66. * specified a NULL buffer address.
  67. *
  68. * If a given name does not have a valid undecoration, the original name
  69. * is returned in the output buffer.
  70. *
  71. * Fine selection of a number of undecorator attributes is possible, by
  72. * specifying flags (bit-fields) to disable the production of parts of the
  73. * complete declaration. The flags may be OR'ed together to select multiple
  74. * disabling of selected fields. The fields and flags are as follows :-
  75. */
  76. #define UNDNAME_COMPLETE (0x0000) // Enable full undecoration
  77. #define UNDNAME_NO_LEADING_UNDERSCORES (0x0001) // Remove leading underscores from MS extended keywords
  78. #define UNDNAME_NO_MS_KEYWORDS (0x0002) // Disable expansion of MS extended keywords
  79. #define UNDNAME_NO_FUNCTION_RETURNS (0x0004) // Disable expansion of return type for primary declaration
  80. #define UNDNAME_NO_ALLOCATION_MODEL (0x0008) // Disable expansion of the declaration model
  81. #define UNDNAME_NO_ALLOCATION_LANGUAGE (0x0010) // Disable expansion of the declaration language specifier
  82. #define UNDNAME_NO_MS_THISTYPE (0x0020) /* NYI */ // Disable expansion of MS keywords on the 'this' type for primary declaration
  83. #define UNDNAME_NO_CV_THISTYPE (0x0040) /* NYI */ // Disable expansion of CV modifiers on the 'this' type for primary declaration
  84. #define UNDNAME_NO_THISTYPE (0x0060) // Disable all modifiers on the 'this' type
  85. #define UNDNAME_NO_ACCESS_SPECIFIERS (0x0080) // Disable expansion of access specifiers for members
  86. #define UNDNAME_NO_THROW_SIGNATURES (0x0100) // Disable expansion of 'throw-signatures' for functions and pointers to functions
  87. #define UNDNAME_NO_MEMBER_TYPE (0x0200) // Disable expansion of 'static' or 'virtual'ness of members
  88. #define UNDNAME_NO_RETURN_UDT_MODEL (0x0400) // Disable expansion of MS model for UDT returns
  89. #define UNDNAME_32_BIT_DECODE (0x0800) // Undecorate 32-bit decorated names
  90. #define UNDNAME_NAME_ONLY (0x1000) // Crack only the name for primary declaration;
  91. // return just [scope::]name. Does expand template params
  92. #define UNDNAME_TYPE_ONLY (0x2000) // Input is just a type encoding; compose an abstract declarator
  93. #define UNDNAME_HAVE_PARAMETERS (0x4000) // The real templates parameters are available
  94. #define UNDNAME_NO_ECSU (0x8000) // Suppress enum/class/struct/union
  95. #define UNDNAME_NO_IDENT_CHAR_CHECK (0x10000) // Suppress check for IsValidIdentChar
  96. #define UNDNAME_NO_PTR64 (0x20000) // disable just ptr64 in output