2013-06-24 13:41:48 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) Citrix Systems, Inc.
|
|
|
|
* All rights reserved.
|
2018-02-16 17:27:30 +01:00
|
|
|
*
|
2013-06-24 13:41:48 +02:00
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
2018-02-16 17:27:30 +01:00
|
|
|
*
|
2013-06-24 13:41:48 +02:00
|
|
|
* 1) Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
2018-02-16 17:27:30 +01:00
|
|
|
*
|
2013-06-24 13:41:48 +02:00
|
|
|
* 2) Redistributions in binary form must reproduce the above
|
|
|
|
* copyright notice, this list of conditions and the following
|
|
|
|
* disclaimer in the documentation and/or other materials
|
|
|
|
* provided with the distribution.
|
2018-02-16 17:27:30 +01:00
|
|
|
*
|
2013-06-24 13:41:48 +02:00
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
* COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
|
|
|
|
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
|
|
|
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Collections;
|
2018-02-16 17:27:30 +01:00
|
|
|
|
2013-06-24 13:41:48 +02:00
|
|
|
|
|
|
|
namespace XenAPI
|
|
|
|
{
|
|
|
|
public class Marshalling
|
|
|
|
{
|
|
|
|
/// <summary>
|
2018-02-16 17:27:30 +01:00
|
|
|
/// Takes a Hashtable, creates a new t, and populates the fields of
|
2013-06-24 13:41:48 +02:00
|
|
|
/// that t with the values from the Hashtable.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="t">A XenAPI type, VM for example. t must have an associated XenAPI.Proxy_t.</param>
|
|
|
|
/// <param name="table"></param>
|
|
|
|
/// <returns></returns>
|
|
|
|
public static object convertStruct(Type t, Hashtable table)
|
|
|
|
{
|
2018-02-16 17:27:30 +01:00
|
|
|
return t.GetConstructor(new Type[] {typeof(Hashtable)}).Invoke(new object[] {table});
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static Type GetXenAPIType(string name)
|
|
|
|
{
|
|
|
|
return Type.GetType(string.Format("XenAPI.{0}", name), false, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static bool ParseBool(Hashtable table, string key)
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
var val = table[key];
|
|
|
|
return val == null ? false : (bool)table[key];
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static DateTime ParseDateTime(Hashtable table, string key)
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
var val = table[key];
|
|
|
|
return val == null ? DateTime.MinValue : (DateTime)table[key];
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static double ParseDouble(Hashtable table, string key)
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
var val = table[key];
|
|
|
|
return val == null ? 0.0 : (double)table[key];
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static Hashtable ParseHashTable(Hashtable table, string key)
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
return (Hashtable)table[key];
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static long ParseLong(Hashtable table, string key)
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
long result;
|
|
|
|
long.TryParse((string)table[key], out result);
|
|
|
|
return result;
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static string ParseString(Hashtable table, string key)
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
return (string)table[key];
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static string[] ParseStringArray(Hashtable table, string key)
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
var val = (object[])table[key];
|
|
|
|
return val == null ? new string[0] : Array.ConvertAll(val, o => o.ToString());
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
2015-04-23 15:16:53 +02:00
|
|
|
public static long[] ParseLongArray(Hashtable table, string key)
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
var val = (object[])table[key];
|
|
|
|
return val == null ? new long[0] : Array.ConvertAll(val, o => long.Parse(o.ToString()));
|
2015-04-23 15:16:53 +02:00
|
|
|
}
|
|
|
|
|
2013-06-24 13:41:48 +02:00
|
|
|
public static XenRef<T> ParseRef<T>(Hashtable table, string key) where T : XenObject<T>
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
var val = (string)table[key];
|
|
|
|
return val == null ? null : XenRef<T>.Create(val);
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static List<XenRef<T>> ParseSetRef<T>(Hashtable table, string key) where T : XenObject<T>
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
var rs = (object[])table[key];
|
|
|
|
return rs == null ? null : XenRef<T>.Create(rs);
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static Dictionary<XenRef<T>, T> ParseMapRefRecord<T, U>(Hashtable table, string key) where T : XenObject<T>
|
|
|
|
{
|
2018-02-23 17:06:32 +01:00
|
|
|
Hashtable map = ParseHashTable(table, key);
|
|
|
|
return map == null ? null : XenRef<T>.Create<U>(map);
|
2013-06-24 13:41:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|