aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Data/PGSQL
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Data/PGSQL')
-rwxr-xr-xOpenSim/Data/PGSQL/PGSQLSimulationData.cs43
-rw-r--r--OpenSim/Data/PGSQL/Resources/RegionStore.migrations13
2 files changed, 56 insertions, 0 deletions
diff --git a/OpenSim/Data/PGSQL/PGSQLSimulationData.cs b/OpenSim/Data/PGSQL/PGSQLSimulationData.cs
index 25e1a7f..e6161a2 100755
--- a/OpenSim/Data/PGSQL/PGSQLSimulationData.cs
+++ b/OpenSim/Data/PGSQL/PGSQLSimulationData.cs
@@ -624,6 +624,49 @@ namespace OpenSim.Data.PGSQL
624 } 624 }
625 625
626 /// <summary> 626 /// <summary>
627 /// Stores the baked terrain map to DB.
628 /// </summary>
629 /// <param name="terrain">terrain map data.</param>
630 /// <param name="regionID">regionID.</param>
631 public void StoreBakedTerrain(TerrainData terrData, UUID regionID)
632 {
633 //Delete old terrain map
634 string sql = @"delete from bakedterrain where ""RegionUUID""=:RegionUUID";
635 using (NpgsqlConnection conn = new NpgsqlConnection(m_connectionString))
636 {
637 using (NpgsqlCommand cmd = new NpgsqlCommand(sql, conn))
638 {
639 cmd.Parameters.Add(_Database.CreateParameter("RegionUUID", regionID));
640 conn.Open();
641 cmd.ExecuteNonQuery();
642
643 _Log.InfoFormat("{0} Deleted bakedterrain id = {1}", LogHeader, regionID);
644 }
645 }
646
647 int terrainDBRevision;
648 Array terrainDBblob;
649 terrData.GetDatabaseBlob(out terrainDBRevision, out terrainDBblob);
650
651 sql = @"insert into bakedterrain(""RegionUUID"", ""Revision"", ""Heightfield"") values(:RegionUUID, :Revision, :Heightfield)";
652
653 using (NpgsqlConnection conn = new NpgsqlConnection(m_connectionString))
654 {
655 using (NpgsqlCommand cmd = new NpgsqlCommand(sql, conn))
656 {
657 cmd.Parameters.Add(_Database.CreateParameter("RegionUUID", regionID));
658 cmd.Parameters.Add(_Database.CreateParameter("Revision", terrainDBRevision));
659 cmd.Parameters.Add(_Database.CreateParameter("Heightfield", terrainDBblob));
660 conn.Open();
661 cmd.ExecuteNonQuery();
662
663 _Log.InfoFormat("{0} Stored bakedterrain id = {1}, terrainSize = <{2},{3}>",
664 LogHeader, regionID, terrData.SizeX, terrData.SizeY);
665 }
666 }
667 }
668
669 /// <summary>
627 /// Loads all the land objects of a region. 670 /// Loads all the land objects of a region.
628 /// </summary> 671 /// </summary>
629 /// <param name="regionUUID">The region UUID.</param> 672 /// <param name="regionUUID">The region UUID.</param>
diff --git a/OpenSim/Data/PGSQL/Resources/RegionStore.migrations b/OpenSim/Data/PGSQL/Resources/RegionStore.migrations
index 9a2c19b..c085939 100644
--- a/OpenSim/Data/PGSQL/Resources/RegionStore.migrations
+++ b/OpenSim/Data/PGSQL/Resources/RegionStore.migrations
@@ -1182,3 +1182,16 @@ BEGIN TRANSACTION;
1182ALTER TABLE prims ADD "RotationAxisLocks" smallint NOT NULL DEFAULT (0); 1182ALTER TABLE prims ADD "RotationAxisLocks" smallint NOT NULL DEFAULT (0);
1183 1183
1184COMMIT; 1184COMMIT;
1185
1186:VERSION 44 #---- add baked terrain store
1187
1188BEGIN TRANSACTION;
1189
1190CREATE TABLE bakedterrain
1191 (
1192 "RegionUUID" uuid NULL,
1193 "Revision" int NULL,
1194 "Heightfield" bytea NULL
1195 );
1196
1197COMMIT;