Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
C
cpython
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
cpython
Commits
e0b9261a
Kaydet (Commit)
e0b9261a
authored
Haz 11, 2008
tarafından
Gregory P. Smith
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
swap stringobject.h and bytesobject.h contents to make sense. PyString in
stringobject and PyBytes defines in bytesobject.
üst
190d56e0
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
233 additions
and
233 deletions
+233
-233
bytesobject.h
Include/bytesobject.h
+33
-200
stringobject.h
Include/stringobject.h
+200
-33
No files found.
Include/bytesobject.h
Dosyayı görüntüle @
e0b9261a
#define PyBytesObject PyStringObject
/* String (Bytes) object interface */
#define PyBytes_Type PyString_Type
#ifndef Py_BYTESOBJECT_H
#define PyBytes_Check PyString_Check
#define Py_BYTESOBJECT_H
#define PyBytes_CheckExact PyString_CheckExact
#ifdef __cplusplus
#define PyBytes_CHECK_INTERNED PyString_CHECK_INTERNED
extern
"C"
{
#define PyBytes_AS_STRING PyString_AS_STRING
#endif
#define PyBytes_GET_SIZE PyString_GET_SIZE
#define Py_TPFLAGS_BYTES_SUBCLASS Py_TPFLAGS_STRING_SUBCLASS
#include <stdarg.h>
#define PyBytes_FromStringAndSize PyString_FromStringAndSize
/*
#define PyBytes_FromString PyString_FromString
Type PyStringObject represents a character string. An extra zero byte is
#define PyBytes_FromFormatV PyString_FromFormatV
reserved at the end to ensure it is zero-terminated, but a size is
#define PyBytes_FromFormat PyString_FromFormat
present so strings with null bytes in them can be represented. This
#define PyBytes_Size PyString_Size
is an immutable object type.
#define PyBytes_AsString PyString_AsString
#define PyBytes_Repr PyString_Repr
There are functions to create new string objects, to test
#define PyBytes_Concat PyString_Concat
an object for string-ness, and to get the
#define PyBytes_ConcatAndDel PyString_ConcatAndDel
string value. The latter function returns a null pointer
#define _PyBytes_Resize _PyString_Resize
if the object is not of the proper type.
#define _PyBytes_Eq _PyString_Eq
There is a variant that takes an explicit size as well as a
#define PyBytes_Format PyString_Format
variant that assumes a zero-terminated string. Note that none of the
#define _PyBytes_FormatLong _PyString_FormatLong
functions should be applied to nil objects.
#define PyBytes_DecodeEscape PyString_DecodeEscape
*/
#define _PyBytes_Join _PyString_Join
#define PyBytes_Decode PyString_Decode
/* Caching the hash (ob_shash) saves recalculation of a string's hash value.
#define PyBytes_Encode PyString_Encode
Interning strings (ob_sstate) tries to ensure that only one string
#define PyBytes_AsEncodedObject PyString_AsEncodedObject
object with a given value exists, so equality tests can be one pointer
#define PyBytes_AsEncodedString PyString_AsEncodedString
comparison. This is generally restricted to strings that "look like"
#define PyBytes_AsDecodedObject PyString_AsDecodedObject
Python identifiers, although the intern() builtin can be used to force
#define PyBytes_AsDecodedString PyString_AsDecodedString
interning of any string.
#define PyBytes_AsStringAndSize PyString_AsStringAndSize
Together, these sped the interpreter by up to 20%. */
#define _PyBytes_InsertThousandsGrouping _PyString_InsertThousandsGrouping
typedef
struct
{
PyObject_VAR_HEAD
long
ob_shash
;
int
ob_sstate
;
char
ob_sval
[
1
];
/* Invariants:
* ob_sval contains space for 'ob_size+1' elements.
* ob_sval[ob_size] == 0.
* ob_shash is the hash of the string or -1 if not computed yet.
* ob_sstate != 0 iff the string object is in stringobject.c's
* 'interned' dictionary; in this case the two references
* from 'interned' to this object are *not counted* in ob_refcnt.
*/
}
PyStringObject
;
#define SSTATE_NOT_INTERNED 0
#define SSTATE_INTERNED_MORTAL 1
#define SSTATE_INTERNED_IMMORTAL 2
PyAPI_DATA
(
PyTypeObject
)
PyBaseString_Type
;
PyAPI_DATA
(
PyTypeObject
)
PyString_Type
;
#define PyString_Check(op) \
PyType_FastSubclass(Py_TYPE(op), Py_TPFLAGS_STRING_SUBCLASS)
#define PyString_CheckExact(op) (Py_TYPE(op) == &PyString_Type)
PyAPI_FUNC
(
PyObject
*
)
PyString_FromStringAndSize
(
const
char
*
,
Py_ssize_t
);
PyAPI_FUNC
(
PyObject
*
)
PyString_FromString
(
const
char
*
);
PyAPI_FUNC
(
PyObject
*
)
PyString_FromFormatV
(
const
char
*
,
va_list
)
Py_GCC_ATTRIBUTE
((
format
(
printf
,
1
,
0
)));
PyAPI_FUNC
(
PyObject
*
)
PyString_FromFormat
(
const
char
*
,
...)
Py_GCC_ATTRIBUTE
((
format
(
printf
,
1
,
2
)));
PyAPI_FUNC
(
Py_ssize_t
)
PyString_Size
(
PyObject
*
);
PyAPI_FUNC
(
char
*
)
PyString_AsString
(
PyObject
*
);
PyAPI_FUNC
(
PyObject
*
)
PyString_Repr
(
PyObject
*
,
int
);
PyAPI_FUNC
(
void
)
PyString_Concat
(
PyObject
**
,
PyObject
*
);
PyAPI_FUNC
(
void
)
PyString_ConcatAndDel
(
PyObject
**
,
PyObject
*
);
PyAPI_FUNC
(
int
)
_PyString_Resize
(
PyObject
**
,
Py_ssize_t
);
PyAPI_FUNC
(
int
)
_PyString_Eq
(
PyObject
*
,
PyObject
*
);
PyAPI_FUNC
(
PyObject
*
)
PyString_Format
(
PyObject
*
,
PyObject
*
);
PyAPI_FUNC
(
PyObject
*
)
_PyString_FormatLong
(
PyObject
*
,
int
,
int
,
int
,
char
**
,
int
*
);
PyAPI_FUNC
(
PyObject
*
)
PyString_DecodeEscape
(
const
char
*
,
Py_ssize_t
,
const
char
*
,
Py_ssize_t
,
const
char
*
);
PyAPI_FUNC
(
void
)
PyString_InternInPlace
(
PyObject
**
);
PyAPI_FUNC
(
void
)
PyString_InternImmortal
(
PyObject
**
);
PyAPI_FUNC
(
PyObject
*
)
PyString_InternFromString
(
const
char
*
);
PyAPI_FUNC
(
void
)
_Py_ReleaseInternedStrings
(
void
);
/* Use only if you know it's a string */
#define PyString_CHECK_INTERNED(op) (((PyStringObject *)(op))->ob_sstate)
/* Macro, trading safety for speed */
#define PyString_AS_STRING(op) (((PyStringObject *)(op))->ob_sval)
#define PyString_GET_SIZE(op) Py_SIZE(op)
/* _PyString_Join(sep, x) is like sep.join(x). sep must be PyStringObject*,
x must be an iterable object. */
PyAPI_FUNC
(
PyObject
*
)
_PyString_Join
(
PyObject
*
sep
,
PyObject
*
x
);
/* --- Generic Codecs ----------------------------------------------------- */
/* Create an object by decoding the encoded string s of the
given size. */
PyAPI_FUNC
(
PyObject
*
)
PyString_Decode
(
const
char
*
s
,
/* encoded string */
Py_ssize_t
size
,
/* size of buffer */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Encodes a char buffer of the given size and returns a
Python object. */
PyAPI_FUNC
(
PyObject
*
)
PyString_Encode
(
const
char
*
s
,
/* string char buffer */
Py_ssize_t
size
,
/* number of chars to encode */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Encodes a string object and returns the result as Python
object. */
PyAPI_FUNC
(
PyObject
*
)
PyString_AsEncodedObject
(
PyObject
*
str
,
/* string object */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Encodes a string object and returns the result as Python string
object.
If the codec returns an Unicode object, the object is converted
back to a string using the default encoding.
DEPRECATED - use PyString_AsEncodedObject() instead. */
PyAPI_FUNC
(
PyObject
*
)
PyString_AsEncodedString
(
PyObject
*
str
,
/* string object */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Decodes a string object and returns the result as Python
object. */
PyAPI_FUNC
(
PyObject
*
)
PyString_AsDecodedObject
(
PyObject
*
str
,
/* string object */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Decodes a string object and returns the result as Python string
object.
If the codec returns an Unicode object, the object is converted
back to a string using the default encoding.
DEPRECATED - use PyString_AsDecodedObject() instead. */
PyAPI_FUNC
(
PyObject
*
)
PyString_AsDecodedString
(
PyObject
*
str
,
/* string object */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Provides access to the internal data buffer and size of a string
object or the default encoded version of an Unicode object. Passing
NULL as *len parameter will force the string buffer to be
0-terminated (passing a string with embedded NULL characters will
cause an exception). */
PyAPI_FUNC
(
int
)
PyString_AsStringAndSize
(
register
PyObject
*
obj
,
/* string or Unicode object */
register
char
**
s
,
/* pointer to buffer variable */
register
Py_ssize_t
*
len
/* pointer to length variable or NULL
(only possible for 0-terminated
strings) */
);
/* Using the current locale, insert the thousands grouping
into the string pointed to by buffer. For the argument descriptions,
see Objects/stringlib/localeutil.h */
PyAPI_FUNC
(
int
)
_PyString_InsertThousandsGrouping
(
char
*
buffer
,
Py_ssize_t
len
,
char
*
plast
,
Py_ssize_t
buf_size
,
Py_ssize_t
*
count
,
int
append_zero_char
);
/* Format the object based on the format_spec, as defined in PEP 3101
(Advanced String Formatting). */
PyAPI_FUNC
(
PyObject
*
)
_PyBytes_FormatAdvanced
(
PyObject
*
obj
,
char
*
format_spec
,
Py_ssize_t
format_spec_len
);
#ifdef __cplusplus
}
#endif
#endif
/* !Py_BYTESOBJECT_H */
Include/stringobject.h
Dosyayı görüntüle @
e0b9261a
#define PyBytesObject PyStringObject
#define PyBytes_Type PyString_Type
/* String (str/bytes) object interface */
#define PyBytes_Check PyString_Check
#ifndef Py_STRINGOBJECT_H
#define PyBytes_CheckExact PyString_CheckExact
#define Py_STRINGOBJECT_H
#define PyBytes_CHECK_INTERNED PyString_CHECK_INTERNED
#ifdef __cplusplus
#define PyBytes_AS_STRING PyString_AS_STRING
extern
"C"
{
#define PyBytes_GET_SIZE PyString_GET_SIZE
#endif
#define Py_TPFLAGS_BYTES_SUBCLASS Py_TPFLAGS_STRING_SUBCLASS
#include <stdarg.h>
#define PyBytes_FromStringAndSize PyString_FromStringAndSize
#define PyBytes_FromString PyString_FromString
/*
#define PyBytes_FromFormatV PyString_FromFormatV
Type PyStringObject represents a character string. An extra zero byte is
#define PyBytes_FromFormat PyString_FromFormat
reserved at the end to ensure it is zero-terminated, but a size is
#define PyBytes_Size PyString_Size
present so strings with null bytes in them can be represented. This
#define PyBytes_AsString PyString_AsString
is an immutable object type.
#define PyBytes_Repr PyString_Repr
#define PyBytes_Concat PyString_Concat
There are functions to create new string objects, to test
#define PyBytes_ConcatAndDel PyString_ConcatAndDel
an object for string-ness, and to get the
#define _PyBytes_Resize _PyString_Resize
string value. The latter function returns a null pointer
#define _PyBytes_Eq _PyString_Eq
if the object is not of the proper type.
#define PyBytes_Format PyString_Format
There is a variant that takes an explicit size as well as a
#define _PyBytes_FormatLong _PyString_FormatLong
variant that assumes a zero-terminated string. Note that none of the
#define PyBytes_DecodeEscape PyString_DecodeEscape
functions should be applied to nil objects.
#define _PyBytes_Join _PyString_Join
*/
#define PyBytes_Decode PyString_Decode
#define PyBytes_Encode PyString_Encode
/* Caching the hash (ob_shash) saves recalculation of a string's hash value.
#define PyBytes_AsEncodedObject PyString_AsEncodedObject
Interning strings (ob_sstate) tries to ensure that only one string
#define PyBytes_AsEncodedString PyString_AsEncodedString
object with a given value exists, so equality tests can be one pointer
#define PyBytes_AsDecodedObject PyString_AsDecodedObject
comparison. This is generally restricted to strings that "look like"
#define PyBytes_AsDecodedString PyString_AsDecodedString
Python identifiers, although the intern() builtin can be used to force
#define PyBytes_AsStringAndSize PyString_AsStringAndSize
interning of any string.
#define _PyBytes_InsertThousandsGrouping _PyString_InsertThousandsGrouping
Together, these sped the interpreter by up to 20%. */
typedef
struct
{
PyObject_VAR_HEAD
long
ob_shash
;
int
ob_sstate
;
char
ob_sval
[
1
];
/* Invariants:
* ob_sval contains space for 'ob_size+1' elements.
* ob_sval[ob_size] == 0.
* ob_shash is the hash of the string or -1 if not computed yet.
* ob_sstate != 0 iff the string object is in stringobject.c's
* 'interned' dictionary; in this case the two references
* from 'interned' to this object are *not counted* in ob_refcnt.
*/
}
PyStringObject
;
#define SSTATE_NOT_INTERNED 0
#define SSTATE_INTERNED_MORTAL 1
#define SSTATE_INTERNED_IMMORTAL 2
PyAPI_DATA
(
PyTypeObject
)
PyBaseString_Type
;
PyAPI_DATA
(
PyTypeObject
)
PyString_Type
;
#define PyString_Check(op) \
PyType_FastSubclass(Py_TYPE(op), Py_TPFLAGS_STRING_SUBCLASS)
#define PyString_CheckExact(op) (Py_TYPE(op) == &PyString_Type)
PyAPI_FUNC
(
PyObject
*
)
PyString_FromStringAndSize
(
const
char
*
,
Py_ssize_t
);
PyAPI_FUNC
(
PyObject
*
)
PyString_FromString
(
const
char
*
);
PyAPI_FUNC
(
PyObject
*
)
PyString_FromFormatV
(
const
char
*
,
va_list
)
Py_GCC_ATTRIBUTE
((
format
(
printf
,
1
,
0
)));
PyAPI_FUNC
(
PyObject
*
)
PyString_FromFormat
(
const
char
*
,
...)
Py_GCC_ATTRIBUTE
((
format
(
printf
,
1
,
2
)));
PyAPI_FUNC
(
Py_ssize_t
)
PyString_Size
(
PyObject
*
);
PyAPI_FUNC
(
char
*
)
PyString_AsString
(
PyObject
*
);
PyAPI_FUNC
(
PyObject
*
)
PyString_Repr
(
PyObject
*
,
int
);
PyAPI_FUNC
(
void
)
PyString_Concat
(
PyObject
**
,
PyObject
*
);
PyAPI_FUNC
(
void
)
PyString_ConcatAndDel
(
PyObject
**
,
PyObject
*
);
PyAPI_FUNC
(
int
)
_PyString_Resize
(
PyObject
**
,
Py_ssize_t
);
PyAPI_FUNC
(
int
)
_PyString_Eq
(
PyObject
*
,
PyObject
*
);
PyAPI_FUNC
(
PyObject
*
)
PyString_Format
(
PyObject
*
,
PyObject
*
);
PyAPI_FUNC
(
PyObject
*
)
_PyString_FormatLong
(
PyObject
*
,
int
,
int
,
int
,
char
**
,
int
*
);
PyAPI_FUNC
(
PyObject
*
)
PyString_DecodeEscape
(
const
char
*
,
Py_ssize_t
,
const
char
*
,
Py_ssize_t
,
const
char
*
);
PyAPI_FUNC
(
void
)
PyString_InternInPlace
(
PyObject
**
);
PyAPI_FUNC
(
void
)
PyString_InternImmortal
(
PyObject
**
);
PyAPI_FUNC
(
PyObject
*
)
PyString_InternFromString
(
const
char
*
);
PyAPI_FUNC
(
void
)
_Py_ReleaseInternedStrings
(
void
);
/* Use only if you know it's a string */
#define PyString_CHECK_INTERNED(op) (((PyStringObject *)(op))->ob_sstate)
/* Macro, trading safety for speed */
#define PyString_AS_STRING(op) (((PyStringObject *)(op))->ob_sval)
#define PyString_GET_SIZE(op) Py_SIZE(op)
/* _PyString_Join(sep, x) is like sep.join(x). sep must be PyStringObject*,
x must be an iterable object. */
PyAPI_FUNC
(
PyObject
*
)
_PyString_Join
(
PyObject
*
sep
,
PyObject
*
x
);
/* --- Generic Codecs ----------------------------------------------------- */
/* Create an object by decoding the encoded string s of the
given size. */
PyAPI_FUNC
(
PyObject
*
)
PyString_Decode
(
const
char
*
s
,
/* encoded string */
Py_ssize_t
size
,
/* size of buffer */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Encodes a char buffer of the given size and returns a
Python object. */
PyAPI_FUNC
(
PyObject
*
)
PyString_Encode
(
const
char
*
s
,
/* string char buffer */
Py_ssize_t
size
,
/* number of chars to encode */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Encodes a string object and returns the result as Python
object. */
PyAPI_FUNC
(
PyObject
*
)
PyString_AsEncodedObject
(
PyObject
*
str
,
/* string object */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Encodes a string object and returns the result as Python string
object.
If the codec returns an Unicode object, the object is converted
back to a string using the default encoding.
DEPRECATED - use PyString_AsEncodedObject() instead. */
PyAPI_FUNC
(
PyObject
*
)
PyString_AsEncodedString
(
PyObject
*
str
,
/* string object */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Decodes a string object and returns the result as Python
object. */
PyAPI_FUNC
(
PyObject
*
)
PyString_AsDecodedObject
(
PyObject
*
str
,
/* string object */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Decodes a string object and returns the result as Python string
object.
If the codec returns an Unicode object, the object is converted
back to a string using the default encoding.
DEPRECATED - use PyString_AsDecodedObject() instead. */
PyAPI_FUNC
(
PyObject
*
)
PyString_AsDecodedString
(
PyObject
*
str
,
/* string object */
const
char
*
encoding
,
/* encoding */
const
char
*
errors
/* error handling */
);
/* Provides access to the internal data buffer and size of a string
object or the default encoded version of an Unicode object. Passing
NULL as *len parameter will force the string buffer to be
0-terminated (passing a string with embedded NULL characters will
cause an exception). */
PyAPI_FUNC
(
int
)
PyString_AsStringAndSize
(
register
PyObject
*
obj
,
/* string or Unicode object */
register
char
**
s
,
/* pointer to buffer variable */
register
Py_ssize_t
*
len
/* pointer to length variable or NULL
(only possible for 0-terminated
strings) */
);
/* Using the current locale, insert the thousands grouping
into the string pointed to by buffer. For the argument descriptions,
see Objects/stringlib/localeutil.h */
PyAPI_FUNC
(
int
)
_PyString_InsertThousandsGrouping
(
char
*
buffer
,
Py_ssize_t
len
,
char
*
plast
,
Py_ssize_t
buf_size
,
Py_ssize_t
*
count
,
int
append_zero_char
);
/* Format the object based on the format_spec, as defined in PEP 3101
(Advanced String Formatting). */
PyAPI_FUNC
(
PyObject
*
)
_PyBytes_FormatAdvanced
(
PyObject
*
obj
,
char
*
format_spec
,
Py_ssize_t
format_spec_len
);
#ifdef __cplusplus
}
#endif
#endif
/* !Py_STRINGOBJECT_H */
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment