| 
									
										
										
										
											1993-07-28 09:05:47 +00:00
										 |  |  | #ifndef Py_STRINGOBJECT_H
 | 
					
						
							|  |  |  | #define Py_STRINGOBJECT_H
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | /***********************************************************
 | 
					
						
							| 
									
										
										
										
											2000-06-30 23:50:40 +00:00
										 |  |  | Copyright (c) 2000, BeOpen.com. | 
					
						
							|  |  |  | Copyright (c) 1995-2000, Corporation for National Research Initiatives. | 
					
						
							|  |  |  | Copyright (c) 1990-1995, Stichting Mathematisch Centrum. | 
					
						
							|  |  |  | All rights reserved. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | See the file "Misc/COPYRIGHT" for information on usage and | 
					
						
							|  |  |  | redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES. | 
					
						
							| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | ******************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | /* String object interface */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											1995-01-12 11:45:45 +00:00
										 |  |  | Type PyStringObject represents a character string.  An extra zero byte is | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | reserved at the end to ensure it is zero-terminated, but a size is | 
					
						
							|  |  |  | present so strings with null bytes in them can be represented.  This | 
					
						
							|  |  |  | is an immutable object type. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | There are functions to create new string objects, to test | 
					
						
							|  |  |  | an object for string-ness, and to get the | 
					
						
							|  |  |  | string value.  The latter function returns a null pointer | 
					
						
							|  |  |  | if the object is not of the proper type. | 
					
						
							|  |  |  | There is a variant that takes an explicit size as well as a | 
					
						
							|  |  |  | variant that assumes a zero-terminated string.  Note that none of the | 
					
						
							|  |  |  | functions should be applied to nil objects. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-18 07:53:23 +00:00
										 |  |  | /* Two speedup hacks.  Caching the hash saves recalculation of a
 | 
					
						
							|  |  |  |    string's hash value.  Interning strings (which requires hash | 
					
						
							|  |  |  |    caching) tries to ensure that only one string object with a given | 
					
						
							|  |  |  |    value exists, so equality tests are one pointer comparison. | 
					
						
							|  |  |  |    Together, these can speed the interpreter up by as much as 20%. | 
					
						
							|  |  |  |    Each costs the size of a long or pointer per string object.  In | 
					
						
							|  |  |  |    addition, interned strings live until the end of times.  If you are | 
					
						
							|  |  |  |    concerned about memory footprint, simply comment the #define out | 
					
						
							|  |  |  |    here (and rebuild everything!). */ | 
					
						
							| 
									
										
										
										
											1996-07-30 16:42:03 +00:00
										 |  |  | #define CACHE_HASH
 | 
					
						
							| 
									
										
										
										
											1997-01-18 07:53:23 +00:00
										 |  |  | #ifdef CACHE_HASH
 | 
					
						
							|  |  |  | #define INTERN_STRINGS
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											1996-07-30 16:42:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											1995-01-12 11:45:45 +00:00
										 |  |  | 	PyObject_VAR_HEAD | 
					
						
							| 
									
										
										
										
											1993-10-22 12:04:32 +00:00
										 |  |  | #ifdef CACHE_HASH
 | 
					
						
							|  |  |  | 	long ob_shash; | 
					
						
							| 
									
										
										
										
											1997-01-18 07:53:23 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef INTERN_STRINGS
 | 
					
						
							|  |  |  | 	PyObject *ob_sinterned; | 
					
						
							| 
									
										
										
										
											1993-10-22 12:04:32 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 	char ob_sval[1]; | 
					
						
							| 
									
										
										
										
											1995-01-12 11:45:45 +00:00
										 |  |  | } PyStringObject; | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-02-27 10:17:52 +00:00
										 |  |  | extern DL_IMPORT(PyTypeObject) PyString_Type; | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-01-12 11:45:45 +00:00
										 |  |  | #define PyString_Check(op) ((op)->ob_type == &PyString_Type)
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-12-04 18:48:25 +00:00
										 |  |  | extern DL_IMPORT(PyObject *) PyString_FromStringAndSize Py_PROTO((const char *, int)); | 
					
						
							|  |  |  | extern DL_IMPORT(PyObject *) PyString_FromString Py_PROTO((const char *)); | 
					
						
							|  |  |  | extern DL_IMPORT(int) PyString_Size Py_PROTO((PyObject *)); | 
					
						
							|  |  |  | extern DL_IMPORT(char *) PyString_AsString Py_PROTO((PyObject *)); | 
					
						
							|  |  |  | extern DL_IMPORT(void) PyString_Concat Py_PROTO((PyObject **, PyObject *)); | 
					
						
							|  |  |  | extern DL_IMPORT(void) PyString_ConcatAndDel Py_PROTO((PyObject **, PyObject *)); | 
					
						
							|  |  |  | extern DL_IMPORT(int) _PyString_Resize Py_PROTO((PyObject **, int)); | 
					
						
							|  |  |  | extern DL_IMPORT(PyObject *) PyString_Format Py_PROTO((PyObject *, PyObject *)); | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-18 07:53:23 +00:00
										 |  |  | #ifdef INTERN_STRINGS
 | 
					
						
							| 
									
										
										
										
											1998-12-04 18:48:25 +00:00
										 |  |  | extern DL_IMPORT(void) PyString_InternInPlace Py_PROTO((PyObject **)); | 
					
						
							|  |  |  | extern DL_IMPORT(PyObject *) PyString_InternFromString Py_PROTO((const char *)); | 
					
						
							| 
									
										
										
										
											1997-01-18 07:53:23 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define PyString_InternInPlace(p)
 | 
					
						
							|  |  |  | #define PyString_InternFromString(cp) PyString_FromString(cp)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | /* Macro, trading safety for speed */ | 
					
						
							| 
									
										
										
										
											1997-01-06 22:42:50 +00:00
										 |  |  | #define PyString_AS_STRING(op) (((PyStringObject *)(op))->ob_sval)
 | 
					
						
							|  |  |  | #define PyString_GET_SIZE(op)  (((PyStringObject *)(op))->ob_size)
 | 
					
						
							| 
									
										
										
										
											1993-07-28 09:05:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* !Py_STRINGOBJECT_H */
 |