aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim.RegionServer/SimClient.cs
diff options
context:
space:
mode:
authorMW2007-03-31 15:54:16 +0000
committerMW2007-03-31 15:54:16 +0000
commitaf93263a3bf033188a18f0f49050393a612d2831 (patch)
tree74c0e035bd10d2dc5a0695038a7c329078c9c7d9 /OpenSim.RegionServer/SimClient.cs
parent* fixed some Framework refs (diff)
downloadopensim-SC_OLD-af93263a3bf033188a18f0f49050393a612d2831.zip
opensim-SC_OLD-af93263a3bf033188a18f0f49050393a612d2831.tar.gz
opensim-SC_OLD-af93263a3bf033188a18f0f49050393a612d2831.tar.bz2
opensim-SC_OLD-af93263a3bf033188a18f0f49050393a612d2831.tar.xz
Can now Rez and DeRez objects (take to and from inventory).
Very much a work in progress and likely to be a number of bugs.
Diffstat (limited to 'OpenSim.RegionServer/SimClient.cs')
-rw-r--r--OpenSim.RegionServer/SimClient.cs64
1 files changed, 62 insertions, 2 deletions
diff --git a/OpenSim.RegionServer/SimClient.cs b/OpenSim.RegionServer/SimClient.cs
index f8affb9..52cb067 100644
--- a/OpenSim.RegionServer/SimClient.cs
+++ b/OpenSim.RegionServer/SimClient.cs
@@ -112,6 +112,7 @@ namespace OpenSim
112 protected virtual void ProcessInPacket(Packet Pack) 112 protected virtual void ProcessInPacket(Packet Pack)
113 { 113 {
114 ack_pack(Pack); 114 ack_pack(Pack);
115 System.Text.Encoding _enc = System.Text.Encoding.ASCII;
115 if (debug) 116 if (debug)
116 { 117 {
117 if (Pack.Type != PacketType.AgentUpdate) 118 if (Pack.Type != PacketType.AgentUpdate)
@@ -166,7 +167,6 @@ namespace OpenSim
166 cachedresp.WearableData[i].TextureID = LLUUID.Zero; 167 cachedresp.WearableData[i].TextureID = LLUUID.Zero;
167 cachedresp.WearableData[i].HostName = new byte[0]; 168 cachedresp.WearableData[i].HostName = new byte[0];
168 } 169 }
169
170 this.OutPacket(cachedresp); 170 this.OutPacket(cachedresp);
171 break; 171 break;
172 case PacketType.ObjectAdd: 172 case PacketType.ObjectAdd:
@@ -293,7 +293,7 @@ namespace OpenSim
293 ChatFromViewerPacket inchatpack = (ChatFromViewerPacket)Pack; 293 ChatFromViewerPacket inchatpack = (ChatFromViewerPacket)Pack;
294 if (Helpers.FieldToString(inchatpack.ChatData.Message) == "") break; 294 if (Helpers.FieldToString(inchatpack.ChatData.Message) == "") break;
295 295
296 System.Text.Encoding _enc = System.Text.Encoding.ASCII; 296
297 libsecondlife.Packets.ChatFromSimulatorPacket reply = new ChatFromSimulatorPacket(); 297 libsecondlife.Packets.ChatFromSimulatorPacket reply = new ChatFromSimulatorPacket();
298 reply.ChatData.Audible = 1; 298 reply.ChatData.Audible = 1;
299 reply.ChatData.Message = inchatpack.ChatData.Message; 299 reply.ChatData.Message = inchatpack.ChatData.Message;
@@ -363,6 +363,7 @@ namespace OpenSim
363 } 363 }
364 else 364 else
365 { 365 {
366 Console.Write(Pack.ToString());
366 this.CreateInventoryItem(createItem); 367 this.CreateInventoryItem(createItem);
367 } 368 }
368 break; 369 break;
@@ -424,6 +425,10 @@ namespace OpenSim
424 //OpenSim.Framework.Console.MainConsole.Instance.WriteLine("Received DeRezObject packet"); 425 //OpenSim.Framework.Console.MainConsole.Instance.WriteLine("Received DeRezObject packet");
425 m_world.DeRezObject((DeRezObjectPacket)Pack, this); 426 m_world.DeRezObject((DeRezObjectPacket)Pack, this);
426 break; 427 break;
428 case PacketType.RezObject:
429 //Console.WriteLine(Pack.ToString());
430 m_world.RezObject(this, (RezObjectPacket)Pack);
431 break;
427 case PacketType.ModifyLand: 432 case PacketType.ModifyLand:
428 ModifyLandPacket modify = (ModifyLandPacket)Pack; 433 ModifyLandPacket modify = (ModifyLandPacket)Pack;
429 //Console.WriteLine("terraform: number of parcel data blocks" + modify.ParcelData.Length); 434 //Console.WriteLine("terraform: number of parcel data blocks" + modify.ParcelData.Length);
@@ -464,6 +469,61 @@ namespace OpenSim
464 break; 469 break;
465 } 470 }
466 break; 471 break;
472 case PacketType.RequestTaskInventory:
473 // Console.WriteLine(Pack.ToString());
474 RequestTaskInventoryPacket requesttask = (RequestTaskInventoryPacket)Pack;
475 ReplyTaskInventoryPacket replytask = new ReplyTaskInventoryPacket();
476 bool foundent = false;
477 foreach (Entity ent in m_world.Entities.Values)
478 {
479 if (ent.localid == requesttask.InventoryData.LocalID)
480 {
481 replytask.InventoryData.TaskID = ent.uuid;
482 replytask.InventoryData.Serial = 0;
483 replytask.InventoryData.Filename = new byte[0];
484 foundent = true;
485 }
486 }
487 if (foundent)
488 {
489 this.OutPacket(replytask);
490 }
491 break;
492 case PacketType.UUIDNameRequest:
493 //System.Text.Encoding _enc = System.Text.Encoding.ASCII;
494 Console.WriteLine(Pack.ToString());
495 UUIDNameRequestPacket nameRequest = (UUIDNameRequestPacket)Pack;
496 UUIDNameReplyPacket nameReply = new UUIDNameReplyPacket();
497 nameReply.UUIDNameBlock = new UUIDNameReplyPacket.UUIDNameBlockBlock[nameRequest.UUIDNameBlock.Length];
498
499 for (int i = 0; i < nameRequest.UUIDNameBlock.Length; i++)
500 {
501 nameReply.UUIDNameBlock[i] = new UUIDNameReplyPacket.UUIDNameBlockBlock();
502 nameReply.UUIDNameBlock[i].ID = nameRequest.UUIDNameBlock[i].ID;
503 nameReply.UUIDNameBlock[i].FirstName = _enc.GetBytes("Who\0"); //for now send any name
504 nameReply.UUIDNameBlock[i].LastName = _enc.GetBytes("Knows\0"); //in future need to look it up
505 }
506 this.OutPacket(nameReply);
507 break;
508 case PacketType.AgentAnimation:
509 //Console.WriteLine(Pack.ToString());
510 break;
511 case PacketType.ObjectSelect:
512 ObjectSelectPacket incomingselect = (ObjectSelectPacket)Pack;
513 for (int i = 0; i < incomingselect.ObjectData.Length; i++)
514 {
515 foreach (Entity ent in m_world.Entities.Values)
516 {
517 if (ent.localid == incomingselect.ObjectData[i].ObjectLocalID)
518 {
519 ((OpenSim.world.Primitive)ent).GetProperites(this);
520 break;
521 }
522 }
523 }
524 break;
525
526
467 } 527 }
468 } 528 }
469 529