180 lines
4.0 KiB
C#
180 lines
4.0 KiB
C#
/*
|
|
Copyright (c) Microsoft Corporation
|
|
|
|
All rights reserved.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in
|
|
compliance with the License. You may obtain a copy of the License
|
|
at http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER
|
|
EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OR CONDITIONS OF
|
|
TITLE, FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABLITY OR NON-INFRINGEMENT.
|
|
|
|
|
|
See the Apache Version 2.0 License for specific language governing permissions and
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
using System;
|
|
using System.Collections;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using System.Globalization;
|
|
using System.Reflection;
|
|
using System.Linq;
|
|
using Microsoft.Research.DryadLinq.Internal;
|
|
|
|
namespace Microsoft.Research.DryadLinq
|
|
{
|
|
interface IForkValue
|
|
{
|
|
bool HasValue { get; }
|
|
object Value { get; }
|
|
}
|
|
|
|
[Serializable]
|
|
public struct ForkValue<T> : IForkValue
|
|
{
|
|
private T m_x;
|
|
private bool m_hasX;
|
|
|
|
public ForkValue(T x)
|
|
{
|
|
this.m_x = x;
|
|
this.m_hasX = true;
|
|
}
|
|
|
|
public bool HasValue
|
|
{
|
|
get { return this.m_hasX; }
|
|
}
|
|
|
|
object IForkValue.Value
|
|
{
|
|
get { return this.m_x; }
|
|
}
|
|
|
|
public T Value
|
|
{
|
|
get { return this.m_x; }
|
|
set { this.m_x = value; this.m_hasX = true; }
|
|
}
|
|
}
|
|
|
|
[Serializable]
|
|
public struct ForkTuple<T1, T2>
|
|
{
|
|
private T1 m_x;
|
|
private T2 m_y;
|
|
private bool m_hasX;
|
|
private bool m_hasY;
|
|
|
|
public ForkTuple(T1 x, T2 y)
|
|
{
|
|
this.m_x = x;
|
|
this.m_y = y;
|
|
this.m_hasX = true;
|
|
this.m_hasY = true;
|
|
}
|
|
|
|
public bool HasFirst
|
|
{
|
|
get { return this.m_hasX; }
|
|
}
|
|
|
|
public bool HasSecond
|
|
{
|
|
get { return this.m_hasY; }
|
|
}
|
|
|
|
public T1 First
|
|
{
|
|
get { return this.m_x; }
|
|
set { this.m_x = value; this.m_hasX = true; }
|
|
}
|
|
|
|
public T2 Second
|
|
{
|
|
get { return this.m_y; }
|
|
set { this.m_y = value; this.m_hasY = true; }
|
|
}
|
|
}
|
|
|
|
[Serializable]
|
|
public struct ForkTuple<T1, T2, T3>
|
|
{
|
|
private T1 m_x;
|
|
private T2 m_y;
|
|
private T3 m_z;
|
|
private bool m_hasX;
|
|
private bool m_hasY;
|
|
private bool m_hasZ;
|
|
|
|
public ForkTuple(T1 x, T2 y, T3 z)
|
|
{
|
|
this.m_x = x;
|
|
this.m_y = y;
|
|
this.m_z = z;
|
|
this.m_hasX = true;
|
|
this.m_hasY = true;
|
|
this.m_hasZ = true;
|
|
}
|
|
|
|
public bool HasFirst
|
|
{
|
|
get { return this.m_hasX; }
|
|
}
|
|
|
|
public bool HasSecond
|
|
{
|
|
get { return this.m_hasY; }
|
|
}
|
|
|
|
public bool HasThird
|
|
{
|
|
get { return this.m_hasZ; }
|
|
}
|
|
|
|
public T1 First
|
|
{
|
|
get { return this.m_x; }
|
|
set { this.m_x = value; this.m_hasX = true; }
|
|
}
|
|
|
|
public T2 Second
|
|
{
|
|
get { return this.m_y; }
|
|
set { this.m_y = value; this.m_hasY = true; }
|
|
}
|
|
|
|
public T3 Third
|
|
{
|
|
get { return this.m_z; }
|
|
set { this.m_z = value; this.m_hasZ = true; }
|
|
}
|
|
}
|
|
|
|
internal struct ForkTuple
|
|
{
|
|
private IForkValue[] m_values;
|
|
|
|
public ForkTuple(params IForkValue[] values)
|
|
{
|
|
this.m_values = values;
|
|
}
|
|
|
|
public bool HasValue(int index)
|
|
{
|
|
return this.m_values[index].HasValue;
|
|
}
|
|
|
|
public object Value(int index)
|
|
{
|
|
return this.m_values[index].Value;
|
|
}
|
|
}
|
|
}
|