playing with multicolumn mapping of vectors using a custom type
parent
103093cf11
commit
b9bba13c39
|
@ -0,0 +1,107 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * 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.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``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 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.Data;
|
||||
using libsecondlife;
|
||||
using NHibernate;
|
||||
using NHibernate.SqlTypes;
|
||||
using NHibernate.UserTypes;
|
||||
|
||||
namespace OpenSim.Data.NHibernate
|
||||
{
|
||||
[Serializable]
|
||||
public class LLVector3UserType: IUserType
|
||||
{
|
||||
public object Assemble(object cached, object owner)
|
||||
{
|
||||
return cached;
|
||||
}
|
||||
|
||||
bool IUserType.Equals(object vector1, object vector2)
|
||||
{
|
||||
return vector1.Equals(vector2);
|
||||
}
|
||||
|
||||
public object DeepCopy(object vector)
|
||||
{
|
||||
return new LLVector3((LLVector3) vector);
|
||||
}
|
||||
|
||||
public object Disassemble(object vector)
|
||||
{
|
||||
return vector;
|
||||
}
|
||||
|
||||
public int GetHashCode(object vector)
|
||||
{
|
||||
return (vector == null) ? 0 : vector.GetHashCode();
|
||||
}
|
||||
|
||||
public bool IsMutable
|
||||
{
|
||||
get { return false; }
|
||||
}
|
||||
|
||||
public object NullSafeGet(IDataReader rs, string[] names, object owner)
|
||||
{
|
||||
object vector = null;
|
||||
|
||||
int x = rs.GetOrdinal(names[0]);
|
||||
int y = rs.GetOrdinal(names[1]);
|
||||
int z = rs.GetOrdinal(names[2]);
|
||||
if (!rs.IsDBNull(x))
|
||||
{
|
||||
vector = new LLVector3((Single)rs[x], (Single)rs[y], (Single)rs[z]);
|
||||
}
|
||||
return vector;
|
||||
}
|
||||
|
||||
public void NullSafeSet(IDbCommand cmd, object obj, int index)
|
||||
{
|
||||
LLVector3 vector = (LLVector3)obj;
|
||||
((IDataParameter)cmd.Parameters[index]).Value = vector.X;
|
||||
((IDataParameter)cmd.Parameters[index + 1]).Value = vector.Y;
|
||||
((IDataParameter)cmd.Parameters[index + 2]).Value = vector.Z;
|
||||
}
|
||||
|
||||
public object Replace(object original, object target, object owner)
|
||||
{
|
||||
return original;
|
||||
}
|
||||
|
||||
public Type ReturnedType
|
||||
{
|
||||
get { return typeof(LLVector3); }
|
||||
}
|
||||
|
||||
public SqlType[] SqlTypes
|
||||
{
|
||||
get { return new SqlType [] { NHibernateUtil.Single.SqlType, NHibernateUtil.Single.SqlType, NHibernateUtil.Single.SqlType }; }
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,62 @@
|
|||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
|
||||
<class name="OpenSim.Region.Environment.Scenes.SceneObjectPart, OpenSim.Region.Environment" table="Prims" lazy="false">
|
||||
<id name="UUID" column="ID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate">
|
||||
<generator class="assigned" />
|
||||
</id>
|
||||
<property name="ParentID" type="System.UInt32" />
|
||||
<property name="CreationDate" type="System.Int32" />
|
||||
<property name="Name" type="String" length="255" />
|
||||
<property name="Text" type="String" length="255" />
|
||||
<property name="Description" type="String" length="255" />
|
||||
<property name="SitName" type="String" length="255" />
|
||||
<property name="TouchName" type="String" length="255" />
|
||||
|
||||
<property name="ObjectFlags" type="System.UInt32" />
|
||||
<property name="CreatorID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate" />
|
||||
<property name="OwnerID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate" />
|
||||
<property name="GroupID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate" />
|
||||
<property name="LastOwnerID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate" />
|
||||
|
||||
<property name="OwnerMask" type="System.UInt32" />
|
||||
<property name="NextOwnerMask" type="System.UInt32" />
|
||||
<property name="GroupMask" type="System.UInt32" />
|
||||
<property name="EveryoneMask" type="System.UInt32" />
|
||||
<property name="BaseMask" type="System.UInt32" />
|
||||
|
||||
<property name="OffsetPosition" type="OpenSim.Data.NHibernate.LLVector3UserType, OpenSim.Data.NHibernate" >
|
||||
<column name="PositionX" />
|
||||
<column name="PositionY" />
|
||||
<column name="PositionZ" />
|
||||
</property>
|
||||
|
||||
<property name="GroupPosition.X" column="GroupPositionX" type="Single" />
|
||||
<property name="GroupPosition.Y" column="GroupPositionY" type="Single" />
|
||||
<property name="GroupPosition.Z" column="GroupPositionZ" type="Single" />
|
||||
|
||||
<property name="Velocity.X" column="VelocityX" type="Single" />
|
||||
<property name="Velocity.Y" column="VelocityY" type="Single" />
|
||||
<property name="Velocity.Z" column="VelocityZ" type="Single" />
|
||||
|
||||
<property name="AngularVelocity.X" column="AngularVelocityX" type="Single" />
|
||||
<property name="AngularVelocity.Y" column="AngularVelocityY" type="Single" />
|
||||
<property name="AngularVelocity.Z" column="AngularVelocityZ" type="Single" />
|
||||
|
||||
<property name="Acceleration.X" column="AccelerationX" type="Single" />
|
||||
<property name="Acceleration.Y" column="AccelerationY" type="Single" />
|
||||
<property name="Acceleration.Z" column="AccelerationZ" type="Single" />
|
||||
|
||||
<property name="Rotation.X" column="RotationX" type="Single" />
|
||||
<property name="Rotation.Y" column="RotationY" type="Single" />
|
||||
<property name="Rotation.Z" column="RotationZ" type="Single" />
|
||||
<property name="Rotation.W" column="RotationW" type="Single" />
|
||||
|
||||
<property name="sitTargetPos.X" column="sitTargetPosX" type="Single" />
|
||||
<property name="sitTargetPos.Y" column="sitTargetPosY" type="Single" />
|
||||
<property name="sitTargetPos.Z" column="sitTargetPosZ" type="Single" />
|
||||
<property name="SiteTargetOrient.X" column="SiteTargetOrientX" type="Single" />
|
||||
<property name="SiteTargetOrient.Y" column="SiteTargetOrientY" type="Single" />
|
||||
<property name="SiteTargetOrient.Z" column="SiteTargetOrientZ" type="Single" />
|
||||
<property name="SiteTargetOrient.W" column="SiteTargetOrientW" type="Single" />
|
||||
</class>
|
||||
</hibernate-mapping>
|
|
@ -95,7 +95,7 @@ namespace OpenSim.Data.NHibernate
|
|||
|
||||
public Type ReturnedType
|
||||
{
|
||||
get { return typeof(LLUUID); }
|
||||
get { return typeof(LLObject.TextureEntry); }
|
||||
}
|
||||
|
||||
public SqlType[] SqlTypes
|
||||
|
|
Loading…
Reference in New Issue