diff options
author | Sean Dague | 2008-07-03 16:37:44 +0000 |
---|---|---|
committer | Sean Dague | 2008-07-03 16:37:44 +0000 |
commit | b9bba13c39bc4e22886631d24865ca6274b1137b (patch) | |
tree | 4b9ff8ee57bbf3be7f38e0e33d53417518cd8315 /OpenSim | |
parent | Mantis#1654. Thank you kindly, Matth for a patch that: (diff) | |
download | opensim-SC-b9bba13c39bc4e22886631d24865ca6274b1137b.zip opensim-SC-b9bba13c39bc4e22886631d24865ca6274b1137b.tar.gz opensim-SC-b9bba13c39bc4e22886631d24865ca6274b1137b.tar.bz2 opensim-SC-b9bba13c39bc4e22886631d24865ca6274b1137b.tar.xz |
playing with multicolumn mapping of vectors using a custom type
Diffstat (limited to 'OpenSim')
-rw-r--r-- | OpenSim/Data/NHibernate/LLVector3UserType.cs | 107 | ||||
-rw-r--r-- | OpenSim/Data/NHibernate/Resources/RegionStore.hbm.xml | 62 | ||||
-rw-r--r-- | OpenSim/Data/NHibernate/TextureUserType.cs | 2 |
3 files changed, 170 insertions, 1 deletions
diff --git a/OpenSim/Data/NHibernate/LLVector3UserType.cs b/OpenSim/Data/NHibernate/LLVector3UserType.cs new file mode 100644 index 0000000..b040ca7d --- /dev/null +++ b/OpenSim/Data/NHibernate/LLVector3UserType.cs | |||
@@ -0,0 +1,107 @@ | |||
1 | /* | ||
2 | * Copyright (c) Contributors, http://opensimulator.org/ | ||
3 | * See CONTRIBUTORS.TXT for a full list of copyright holders. | ||
4 | * | ||
5 | * Redistribution and use in source and binary forms, with or without | ||
6 | * modification, are permitted provided that the following conditions are met: | ||
7 | * * Redistributions of source code must retain the above copyright | ||
8 | * notice, this list of conditions and the following disclaimer. | ||
9 | * * Redistributions in binary form must reproduce the above copyright | ||
10 | * notice, this list of conditions and the following disclaimer in the | ||
11 | * documentation and/or other materials provided with the distribution. | ||
12 | * * Neither the name of the OpenSim Project nor the | ||
13 | * names of its contributors may be used to endorse or promote products | ||
14 | * derived from this software without specific prior written permission. | ||
15 | * | ||
16 | * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY | ||
17 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||
18 | * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
19 | * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY | ||
20 | * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||
21 | * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||
22 | * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||
23 | * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
24 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||
25 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
26 | */ | ||
27 | |||
28 | using System; | ||
29 | using System.Data; | ||
30 | using libsecondlife; | ||
31 | using NHibernate; | ||
32 | using NHibernate.SqlTypes; | ||
33 | using NHibernate.UserTypes; | ||
34 | |||
35 | namespace OpenSim.Data.NHibernate | ||
36 | { | ||
37 | [Serializable] | ||
38 | public class LLVector3UserType: IUserType | ||
39 | { | ||
40 | public object Assemble(object cached, object owner) | ||
41 | { | ||
42 | return cached; | ||
43 | } | ||
44 | |||
45 | bool IUserType.Equals(object vector1, object vector2) | ||
46 | { | ||
47 | return vector1.Equals(vector2); | ||
48 | } | ||
49 | |||
50 | public object DeepCopy(object vector) | ||
51 | { | ||
52 | return new LLVector3((LLVector3) vector); | ||
53 | } | ||
54 | |||
55 | public object Disassemble(object vector) | ||
56 | { | ||
57 | return vector; | ||
58 | } | ||
59 | |||
60 | public int GetHashCode(object vector) | ||
61 | { | ||
62 | return (vector == null) ? 0 : vector.GetHashCode(); | ||
63 | } | ||
64 | |||
65 | public bool IsMutable | ||
66 | { | ||
67 | get { return false; } | ||
68 | } | ||
69 | |||
70 | public object NullSafeGet(IDataReader rs, string[] names, object owner) | ||
71 | { | ||
72 | object vector = null; | ||
73 | |||
74 | int x = rs.GetOrdinal(names[0]); | ||
75 | int y = rs.GetOrdinal(names[1]); | ||
76 | int z = rs.GetOrdinal(names[2]); | ||
77 | if (!rs.IsDBNull(x)) | ||
78 | { | ||
79 | vector = new LLVector3((Single)rs[x], (Single)rs[y], (Single)rs[z]); | ||
80 | } | ||
81 | return vector; | ||
82 | } | ||
83 | |||
84 | public void NullSafeSet(IDbCommand cmd, object obj, int index) | ||
85 | { | ||
86 | LLVector3 vector = (LLVector3)obj; | ||
87 | ((IDataParameter)cmd.Parameters[index]).Value = vector.X; | ||
88 | ((IDataParameter)cmd.Parameters[index + 1]).Value = vector.Y; | ||
89 | ((IDataParameter)cmd.Parameters[index + 2]).Value = vector.Z; | ||
90 | } | ||
91 | |||
92 | public object Replace(object original, object target, object owner) | ||
93 | { | ||
94 | return original; | ||
95 | } | ||
96 | |||
97 | public Type ReturnedType | ||
98 | { | ||
99 | get { return typeof(LLVector3); } | ||
100 | } | ||
101 | |||
102 | public SqlType[] SqlTypes | ||
103 | { | ||
104 | get { return new SqlType [] { NHibernateUtil.Single.SqlType, NHibernateUtil.Single.SqlType, NHibernateUtil.Single.SqlType }; } | ||
105 | } | ||
106 | } | ||
107 | } | ||
diff --git a/OpenSim/Data/NHibernate/Resources/RegionStore.hbm.xml b/OpenSim/Data/NHibernate/Resources/RegionStore.hbm.xml new file mode 100644 index 0000000..17f7a49 --- /dev/null +++ b/OpenSim/Data/NHibernate/Resources/RegionStore.hbm.xml | |||
@@ -0,0 +1,62 @@ | |||
1 | <?xml version="1.0" encoding="utf-8" ?> | ||
2 | <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"> | ||
3 | <class name="OpenSim.Region.Environment.Scenes.SceneObjectPart, OpenSim.Region.Environment" table="Prims" lazy="false"> | ||
4 | <id name="UUID" column="ID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate"> | ||
5 | <generator class="assigned" /> | ||
6 | </id> | ||
7 | <property name="ParentID" type="System.UInt32" /> | ||
8 | <property name="CreationDate" type="System.Int32" /> | ||
9 | <property name="Name" type="String" length="255" /> | ||
10 | <property name="Text" type="String" length="255" /> | ||
11 | <property name="Description" type="String" length="255" /> | ||
12 | <property name="SitName" type="String" length="255" /> | ||
13 | <property name="TouchName" type="String" length="255" /> | ||
14 | |||
15 | <property name="ObjectFlags" type="System.UInt32" /> | ||
16 | <property name="CreatorID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate" /> | ||
17 | <property name="OwnerID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate" /> | ||
18 | <property name="GroupID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate" /> | ||
19 | <property name="LastOwnerID" type="OpenSim.Data.NHibernate.LLUUIDUserType, OpenSim.Data.NHibernate" /> | ||
20 | |||
21 | <property name="OwnerMask" type="System.UInt32" /> | ||
22 | <property name="NextOwnerMask" type="System.UInt32" /> | ||
23 | <property name="GroupMask" type="System.UInt32" /> | ||
24 | <property name="EveryoneMask" type="System.UInt32" /> | ||
25 | <property name="BaseMask" type="System.UInt32" /> | ||
26 | |||
27 | <property name="OffsetPosition" type="OpenSim.Data.NHibernate.LLVector3UserType, OpenSim.Data.NHibernate" > | ||
28 | <column name="PositionX" /> | ||
29 | <column name="PositionY" /> | ||
30 | <column name="PositionZ" /> | ||
31 | </property> | ||
32 | |||
33 | <property name="GroupPosition.X" column="GroupPositionX" type="Single" /> | ||
34 | <property name="GroupPosition.Y" column="GroupPositionY" type="Single" /> | ||
35 | <property name="GroupPosition.Z" column="GroupPositionZ" type="Single" /> | ||
36 | |||
37 | <property name="Velocity.X" column="VelocityX" type="Single" /> | ||
38 | <property name="Velocity.Y" column="VelocityY" type="Single" /> | ||
39 | <property name="Velocity.Z" column="VelocityZ" type="Single" /> | ||
40 | |||
41 | <property name="AngularVelocity.X" column="AngularVelocityX" type="Single" /> | ||
42 | <property name="AngularVelocity.Y" column="AngularVelocityY" type="Single" /> | ||
43 | <property name="AngularVelocity.Z" column="AngularVelocityZ" type="Single" /> | ||
44 | |||
45 | <property name="Acceleration.X" column="AccelerationX" type="Single" /> | ||
46 | <property name="Acceleration.Y" column="AccelerationY" type="Single" /> | ||
47 | <property name="Acceleration.Z" column="AccelerationZ" type="Single" /> | ||
48 | |||
49 | <property name="Rotation.X" column="RotationX" type="Single" /> | ||
50 | <property name="Rotation.Y" column="RotationY" type="Single" /> | ||
51 | <property name="Rotation.Z" column="RotationZ" type="Single" /> | ||
52 | <property name="Rotation.W" column="RotationW" type="Single" /> | ||
53 | |||
54 | <property name="sitTargetPos.X" column="sitTargetPosX" type="Single" /> | ||
55 | <property name="sitTargetPos.Y" column="sitTargetPosY" type="Single" /> | ||
56 | <property name="sitTargetPos.Z" column="sitTargetPosZ" type="Single" /> | ||
57 | <property name="SiteTargetOrient.X" column="SiteTargetOrientX" type="Single" /> | ||
58 | <property name="SiteTargetOrient.Y" column="SiteTargetOrientY" type="Single" /> | ||
59 | <property name="SiteTargetOrient.Z" column="SiteTargetOrientZ" type="Single" /> | ||
60 | <property name="SiteTargetOrient.W" column="SiteTargetOrientW" type="Single" /> | ||
61 | </class> | ||
62 | </hibernate-mapping> \ No newline at end of file | ||
diff --git a/OpenSim/Data/NHibernate/TextureUserType.cs b/OpenSim/Data/NHibernate/TextureUserType.cs index 18a8166..dac7c75 100644 --- a/OpenSim/Data/NHibernate/TextureUserType.cs +++ b/OpenSim/Data/NHibernate/TextureUserType.cs | |||
@@ -95,7 +95,7 @@ namespace OpenSim.Data.NHibernate | |||
95 | 95 | ||
96 | public Type ReturnedType | 96 | public Type ReturnedType |
97 | { | 97 | { |
98 | get { return typeof(LLUUID); } | 98 | get { return typeof(LLObject.TextureEntry); } |
99 | } | 99 | } |
100 | 100 | ||
101 | public SqlType[] SqlTypes | 101 | public SqlType[] SqlTypes |