playing with multicolumn mapping of vectors using a custom type

0.6.0-stable
Sean Dague 2008-07-03 16:37:44 +00:00
parent 103093cf11
commit b9bba13c39
3 changed files with 170 additions and 1 deletions

View File

@ -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 }; }
}
}
}

View File

@ -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>

View File

@ -95,7 +95,7 @@ namespace OpenSim.Data.NHibernate
public Type ReturnedType
{
get { return typeof(LLUUID); }
get { return typeof(LLObject.TextureEntry); }
}
public SqlType[] SqlTypes