diff options
author | UbitUmarov | 2016-07-30 01:53:25 +0100 |
---|---|---|
committer | UbitUmarov | 2016-07-30 01:53:25 +0100 |
commit | 18bcacdded30507deea609853837099fcf6c8445 (patch) | |
tree | 407f01e8d0872f7fadff632bd8a66cc012126272 /OpenSim/Region/ScriptEngine/Shared | |
parent | Merge branch 'master' into httptests (diff) | |
parent | in RegionInfoCache, replace lib omv ExpireCaches by a single dedicated one (diff) | |
download | opensim-SC-18bcacdded30507deea609853837099fcf6c8445.zip opensim-SC-18bcacdded30507deea609853837099fcf6c8445.tar.gz opensim-SC-18bcacdded30507deea609853837099fcf6c8445.tar.bz2 opensim-SC-18bcacdded30507deea609853837099fcf6c8445.tar.xz |
Merge branch 'master' into httptests
Diffstat (limited to 'OpenSim/Region/ScriptEngine/Shared')
-rw-r--r-- | OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | 85 |
1 files changed, 41 insertions, 44 deletions
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs index 6d2e2c8..fb35a54 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | |||
@@ -6394,64 +6394,61 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6394 | { | 6394 | { |
6395 | m_host.AddScriptLPS(1); | 6395 | m_host.AddScriptLPS(1); |
6396 | 6396 | ||
6397 | // edge will be used to pass the Region Coordinates offset | 6397 | if(dir.x == 0.0 && dir.y == 0.0) |
6398 | // we want to check for a neighboring sim | 6398 | return 1; // SL wiki |
6399 | LSL_Vector edge = new LSL_Vector(0, 0, 0); | 6399 | |
6400 | float rsx = World.RegionInfo.RegionSizeX; | ||
6401 | float rsy = World.RegionInfo.RegionSizeY; | ||
6402 | |||
6403 | // can understand what sl does if position is not in region, so do something :) | ||
6404 | float px = (float)Util.Clamp(pos.x, 0.5, rsx - 0.5); | ||
6405 | float py = (float)Util.Clamp(pos.y, 0.5, rsy - 0.5); | ||
6406 | |||
6407 | float ex, ey; | ||
6400 | 6408 | ||
6401 | if (dir.x == 0) | 6409 | if (dir.x == 0) |
6402 | { | 6410 | { |
6403 | if (dir.y == 0) | 6411 | ex = px; |
6404 | { | 6412 | ey = dir.y > 0.0 ? rsy + 1.0f : -1.0f; |
6405 | // Direction vector is 0,0 so return | 6413 | } |
6406 | // false since we're staying in the sim | 6414 | else if(dir.y == 0.0f) |
6407 | return 0; | 6415 | { |
6408 | } | 6416 | ex = dir.x > 0 ? rsx + 1.0f : -1.0f; |
6409 | else | 6417 | ey = py; |
6410 | { | ||
6411 | // Y is the only valid direction | ||
6412 | edge.y = dir.y / Math.Abs(dir.y) * (World.RegionInfo.RegionSizeY / Constants.RegionSize); | ||
6413 | } | ||
6414 | } | 6418 | } |
6415 | else | 6419 | else |
6416 | { | 6420 | { |
6417 | LSL_Float mag; | 6421 | float dx = (float) dir.x; |
6418 | if (dir.x > 0) | 6422 | float dy = (float) dir.y; |
6419 | { | ||
6420 | mag = (World.RegionInfo.RegionSizeX - pos.x) / dir.x; | ||
6421 | } | ||
6422 | else | ||
6423 | { | ||
6424 | mag = (pos.x/dir.x); | ||
6425 | } | ||
6426 | 6423 | ||
6427 | mag = Math.Abs(mag); | 6424 | float t1 = dx * dx + dy * dy; |
6425 | dx /= t1; | ||
6426 | dy /= t1; | ||
6428 | 6427 | ||
6429 | edge.y = pos.y + (dir.y * mag); | 6428 | if(dx > 0) |
6430 | 6429 | t1 = (rsx + 1f - px)/dx; | |
6431 | if (edge.y > World.RegionInfo.RegionSizeY || edge.y < 0) | ||
6432 | { | ||
6433 | // Y goes out of bounds first | ||
6434 | edge.y = dir.y / Math.Abs(dir.y) * (World.RegionInfo.RegionSizeY / Constants.RegionSize); | ||
6435 | } | ||
6436 | else | 6430 | else |
6437 | { | 6431 | t1 = -(px + 1f)/dx; |
6438 | // X goes out of bounds first or its a corner exit | ||
6439 | edge.y = 0; | ||
6440 | edge.x = dir.x / Math.Abs(dir.x) * (World.RegionInfo.RegionSizeY / Constants.RegionSize); | ||
6441 | } | ||
6442 | } | ||
6443 | 6432 | ||
6444 | List<GridRegion> neighbors = World.GridService.GetNeighbours(World.RegionInfo.ScopeID, World.RegionInfo.RegionID); | ||
6445 | 6433 | ||
6446 | uint neighborX = World.RegionInfo.RegionLocX + (uint)edge.x; | 6434 | float t2; |
6447 | uint neighborY = World.RegionInfo.RegionLocY + (uint)edge.y; | 6435 | if(dy > 0) |
6436 | t2 = (rsy + 1f - py)/dy; | ||
6437 | else | ||
6438 | t2 = -(py + 1f)/dy; | ||
6448 | 6439 | ||
6449 | foreach (GridRegion sri in neighbors) | 6440 | if(t1 > t2) |
6450 | { | 6441 | t1 = t2; |
6451 | if (sri.RegionCoordX == neighborX && sri.RegionCoordY == neighborY) | 6442 | |
6452 | return 0; | 6443 | ex = px + t1 * dx; |
6444 | ey = py + t1 * dy; | ||
6453 | } | 6445 | } |
6454 | 6446 | ||
6447 | ex += World.RegionInfo.WorldLocX; | ||
6448 | ey += World.RegionInfo.WorldLocY; | ||
6449 | |||
6450 | if(World.GridService.GetRegionByPosition(World.RegionInfo.ScopeID, (int)ex, (int)ey) != null) | ||
6451 | return 0; | ||
6455 | return 1; | 6452 | return 1; |
6456 | } | 6453 | } |
6457 | 6454 | ||