mirror of
https://github.com/microsoft/PowerToys.git
synced 2024-12-13 11:09:28 +08:00
173 lines
4.7 KiB
C#
173 lines
4.7 KiB
C#
|
// ==========================================================================
|
||
|
// This software is subject to the provisions of the Zope Public License,
|
||
|
// Version 2.0 (ZPL). A copy of the ZPL should accompany this distribution.
|
||
|
// THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
|
||
|
// WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||
|
// WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
|
||
|
// FOR A PARTICULAR PURPOSE.
|
||
|
// ==========================================================================
|
||
|
|
||
|
using System;
|
||
|
using System.Collections;
|
||
|
|
||
|
namespace Python.Runtime {
|
||
|
|
||
|
/// <summary>
|
||
|
/// Represents a generic Python sequence. The methods of this class are
|
||
|
/// equivalent to the Python "abstract sequence API". See
|
||
|
/// http://www.python.org/doc/current/api/sequence.html for details.
|
||
|
/// </summary>
|
||
|
|
||
|
public class PySequence : PyObject, IEnumerable {
|
||
|
|
||
|
protected PySequence(IntPtr ptr) : base(ptr) {}
|
||
|
|
||
|
protected PySequence() : base() {}
|
||
|
|
||
|
|
||
|
/// <summary>
|
||
|
/// IsSequenceType Method
|
||
|
/// </summary>
|
||
|
///
|
||
|
/// <remarks>
|
||
|
/// Returns true if the given object implements the sequence protocol.
|
||
|
/// </remarks>
|
||
|
|
||
|
public static bool IsSequenceType(PyObject value) {
|
||
|
return Runtime.PySequence_Check(value.obj);
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <summary>
|
||
|
/// GetSlice Method
|
||
|
/// </summary>
|
||
|
///
|
||
|
/// <remarks>
|
||
|
/// Return the slice of the sequence with the given indices.
|
||
|
/// </remarks>
|
||
|
|
||
|
public PyObject GetSlice(int i1, int i2) {
|
||
|
IntPtr op = Runtime.PySequence_GetSlice(obj, i1, i2);
|
||
|
if (op == IntPtr.Zero) {
|
||
|
throw new PythonException();
|
||
|
}
|
||
|
return new PyObject(op);
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <summary>
|
||
|
/// SetSlice Method
|
||
|
/// </summary>
|
||
|
///
|
||
|
/// <remarks>
|
||
|
/// Sets the slice of the sequence with the given indices.
|
||
|
/// </remarks>
|
||
|
|
||
|
public void SetSlice(int i1, int i2, PyObject v) {
|
||
|
int r = Runtime.PySequence_SetSlice(obj, i1, i2, v.obj);
|
||
|
if (r < 0) {
|
||
|
throw new PythonException();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <summary>
|
||
|
/// DelSlice Method
|
||
|
/// </summary>
|
||
|
///
|
||
|
/// <remarks>
|
||
|
/// Deletes the slice of the sequence with the given indices.
|
||
|
/// </remarks>
|
||
|
|
||
|
public void DelSlice(int i1, int i2) {
|
||
|
int r = Runtime.PySequence_DelSlice(obj, i1, i2);
|
||
|
if (r < 0) {
|
||
|
throw new PythonException();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <summary>
|
||
|
/// Index Method
|
||
|
/// </summary>
|
||
|
///
|
||
|
/// <remarks>
|
||
|
/// Return the index of the given item in the sequence, or -1 if
|
||
|
/// the item does not appear in the sequence.
|
||
|
/// </remarks>
|
||
|
|
||
|
public int Index(PyObject item) {
|
||
|
int r = Runtime.PySequence_Index(obj, item.obj);
|
||
|
if (r < 0) {
|
||
|
Runtime.PyErr_Clear();
|
||
|
return -1;
|
||
|
}
|
||
|
return r;
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <summary>
|
||
|
/// Contains Method
|
||
|
/// </summary>
|
||
|
///
|
||
|
/// <remarks>
|
||
|
/// Return true if the sequence contains the given item. This method
|
||
|
/// throws a PythonException if an error occurs during the check.
|
||
|
/// </remarks>
|
||
|
|
||
|
public bool Contains(PyObject item) {
|
||
|
int r = Runtime.PySequence_Contains(obj, item.obj);
|
||
|
if (r < 0) {
|
||
|
throw new PythonException();
|
||
|
}
|
||
|
return (r != 0);
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <summary>
|
||
|
/// Concat Method
|
||
|
/// </summary>
|
||
|
///
|
||
|
/// <remarks>
|
||
|
/// Return the concatenation of the sequence object with the passed in
|
||
|
/// sequence object.
|
||
|
/// </remarks>
|
||
|
|
||
|
public PyObject Concat(PyObject other) {
|
||
|
IntPtr op = Runtime.PySequence_Concat(obj, other.obj);
|
||
|
if (op == IntPtr.Zero) {
|
||
|
throw new PythonException();
|
||
|
}
|
||
|
return new PyObject(op);
|
||
|
}
|
||
|
|
||
|
|
||
|
/// <summary>
|
||
|
/// Repeat Method
|
||
|
/// </summary>
|
||
|
///
|
||
|
/// <remarks>
|
||
|
/// Return the sequence object repeated N times. This is equivalent
|
||
|
/// to the Python expression "object * count".
|
||
|
/// </remarks>
|
||
|
|
||
|
public PyObject Repeat(int count) {
|
||
|
IntPtr op = Runtime.PySequence_Repeat(obj, count);
|
||
|
if (op == IntPtr.Zero) {
|
||
|
throw new PythonException();
|
||
|
}
|
||
|
return new PyObject(op);
|
||
|
}
|
||
|
|
||
|
#region IEnumerable Members
|
||
|
|
||
|
public IEnumerator GetEnumerator()
|
||
|
{
|
||
|
return new PyIter(this);
|
||
|
}
|
||
|
|
||
|
#endregion
|
||
|
}
|
||
|
|
||
|
}
|