forked from pythonnet/pythonnet
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpyansistring.cs
More file actions
63 lines (56 loc) · 1.71 KB
/
pyansistring.cs
File metadata and controls
63 lines (56 loc) · 1.71 KB
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
using System;
namespace Python.Runtime
{
public class PyAnsiString : PySequence
{
/// <summary>
/// PyAnsiString Constructor
/// </summary>
/// <remarks>
/// Creates a new PyAnsiString from an existing object reference. Note
/// that the instance assumes ownership of the object reference.
/// The object reference is not checked for type-correctness.
/// </remarks>
public PyAnsiString(IntPtr ptr) : base(ptr)
{
}
/// <summary>
/// PyString Constructor
/// </summary>
/// <remarks>
/// Copy constructor - obtain a PyAnsiString from a generic PyObject.
/// An ArgumentException will be thrown if the given object is not
/// a Python string object.
/// </remarks>
public PyAnsiString(PyObject o)
{
if (!IsStringType(o))
{
throw new ArgumentException("object is not a string");
}
Runtime.XIncref(o.obj);
obj = o.obj;
}
/// <summary>
/// PyAnsiString Constructor
/// </summary>
/// <remarks>
/// Creates a Python string from a managed string.
/// </remarks>
public PyAnsiString(string s)
{
obj = Runtime.PyString_FromString(s);
Runtime.CheckExceptionOccurred();
}
/// <summary>
/// IsStringType Method
/// </summary>
/// <remarks>
/// Returns true if the given object is a Python string.
/// </remarks>
public static bool IsStringType(PyObject value)
{
return Runtime.PyString_Check(value.obj);
}
}
}