18public partial class IntervalVarVector : global::System.IDisposable, global::System.Collections.IEnumerable, global::System.Collections.Generic.IList<IntervalVar>
25 swigCPtr =
new global::System.Runtime.InteropServices.HandleRef(
this, cPtr);
28 internal static global::System.Runtime.InteropServices.HandleRef getCPtr(
IntervalVarVector obj) {
29 return (obj ==
null) ?
new global::System.Runtime.InteropServices.HandleRef(
null, global::System.IntPtr.Zero) : obj.swigCPtr;
32 internal static global::System.Runtime.InteropServices.HandleRef swigRelease(
IntervalVarVector obj) {
35 throw new global::System.ApplicationException(
"Cannot release ownership as memory is not owned");
36 global::System.Runtime.InteropServices.HandleRef ptr = obj.swigCPtr;
37 obj.swigCMemOwn =
false;
41 return new global::System.Runtime.InteropServices.HandleRef(
null, global::System.IntPtr.Zero);
45 ~IntervalVarVector() {
51 global::System.GC.SuppressFinalize(
this);
54 protected virtual void Dispose(
bool disposing) {
56 if (swigCPtr.Handle != global::System.IntPtr.Zero) {
61 swigCPtr =
new global::System.Runtime.InteropServices.HandleRef(
null, global::System.IntPtr.Zero);
68 throw new global::System.ArgumentNullException(
"c");
74 public IntervalVarVector(global::System.Collections.Generic.IEnumerable<IntervalVar> c) : this() {
76 throw new global::System.ArgumentNullException(
"c");
94 public IntervalVar
this[
int index] {
96 return getitem(index);
99 setitem(index, value);
105 return (
int)capacity();
108 if (value < 0 || (uint)value < size())
109 throw new global::System.ArgumentOutOfRangeException(
"Capacity");
110 reserve((uint)value);
132 public void CopyTo(IntervalVar[] array)
145 throw new global::System.ArgumentNullException(
"array");
147 throw new global::System.ArgumentOutOfRangeException(
"index",
"Value is less than zero");
149 throw new global::System.ArgumentOutOfRangeException(
"arrayIndex",
"Value is less than zero");
151 throw new global::System.ArgumentOutOfRangeException(
"count",
"Value is less than zero");
153 throw new global::System.ArgumentException(
"Multi dimensional array.",
"array");
154 if (index+count > this.
Count || arrayIndex+count > array.Length)
155 throw new global::System.ArgumentException(
"Number of elements to copy is too large.");
156 for (
int i=0; i<count; i++)
157 array.SetValue(getitemcopy(index+i), arrayIndex+i);
166 global::System.Collections.Generic.IEnumerator<
IntervalVar> global::System.Collections.Generic.IEnumerable<
IntervalVar>.GetEnumerator() {
167 return new IntervalVarVectorEnumerator(
this);
170 global::System.Collections.IEnumerator global::System.Collections.IEnumerable.GetEnumerator() {
171 return new IntervalVarVectorEnumerator(
this);
174 public IntervalVarVectorEnumerator GetEnumerator() {
175 return new IntervalVarVectorEnumerator(
this);
183 public sealed class IntervalVarVectorEnumerator : global::System.Collections.IEnumerator
184 , global::System.Collections.Generic.IEnumerator<IntervalVar>
187 private int currentIndex;
188 private object currentObject;
189 private int currentSize;
192 collectionRef = collection;
194 currentObject =
null;
195 currentSize = collectionRef.Count;
201 if (currentIndex == -1)
202 throw new global::System.InvalidOperationException(
"Enumeration not started.");
203 if (currentIndex > currentSize - 1)
204 throw new global::System.InvalidOperationException(
"Enumeration finished.");
205 if (currentObject ==
null)
206 throw new global::System.InvalidOperationException(
"Collection modified.");
212 object global::System.Collections.IEnumerator.Current {
219 int size = collectionRef.Count;
220 bool moveOkay = (currentIndex+1 < size) && (size == currentSize);
223 currentObject = collectionRef[currentIndex];
225 currentObject =
null;
230 public void Reset() {
232 currentObject =
null;
233 if (collectionRef.Count != currentSize) {
234 throw new global::System.InvalidOperationException(
"Collection modified.");
240 currentObject =
null;
251 public void Clear() {
259 private uint size() {
264 private bool empty() {
265 bool ret = operations_research_constraint_solverPINVOKE.IntervalVarVector_empty(swigCPtr);
269 private uint capacity() {
270 uint ret = operations_research_constraint_solverPINVOKE.IntervalVarVector_capacity(swigCPtr);
274 private void reserve(uint n) {
275 operations_research_constraint_solverPINVOKE.IntervalVarVector_reserve(swigCPtr, n);
278 public IntervalVarVector(
int capacity) : this(operations_research_constraint_solverPINVOKE.new_IntervalVarVector__SWIG_2(capacity), true) {
279 if (operations_research_constraint_solverPINVOKE.SWIGPendingException.Pending)
throw operations_research_constraint_solverPINVOKE.SWIGPendingException.Retrieve();
289 private IntervalVar getitem(
int index) {
290 global::System.IntPtr cPtr = operations_research_constraint_solverPINVOKE.IntervalVarVector_getitem(swigCPtr, index);
291 IntervalVar ret = (cPtr == global::System.IntPtr.Zero) ?
null : new IntervalVar(cPtr, false);
292 if (operations_research_constraint_solverPINVOKE.SWIGPendingException.Pending)
throw operations_research_constraint_solverPINVOKE.SWIGPendingException.Retrieve();
296 private void setitem(
int index, IntervalVar val) {
297 operations_research_constraint_solverPINVOKE.IntervalVarVector_setitem(swigCPtr, index, IntervalVar.getCPtr(val));
298 if (operations_research_constraint_solverPINVOKE.SWIGPendingException.Pending)
throw operations_research_constraint_solverPINVOKE.SWIGPendingException.Retrieve();
302 operations_research_constraint_solverPINVOKE.IntervalVarVector_AddRange(swigCPtr,
IntervalVarVector.getCPtr(values));
344 public void Reverse(
int index,
int count) {