few small changes (all work in progress).

afrisby
MW 2007-08-29 19:09:45 +00:00
parent 9c0a855088
commit a7f7dfc0dc
2 changed files with 33 additions and 8 deletions

View File

@ -13,7 +13,7 @@ using OpenSim.Framework.Utilities;
namespace OpenSim.Region.Environment.Modules namespace OpenSim.Region.Environment.Modules
{ {
public class ChatModule :IRegionModule public class ChatModule : IRegionModule
{ {
private Scene m_scene; private Scene m_scene;
@ -21,7 +21,7 @@ namespace OpenSim.Region.Environment.Modules
private int m_port = 6668; private int m_port = 6668;
private string m_user = "USER OpenSimBot 8 * :I'm a OpenSim to irc bot"; private string m_user = "USER OpenSimBot 8 * :I'm a OpenSim to irc bot";
private string m_nick = "OpenSimBot"; private string m_nick = "OSimBot";
private string m_channel = "#opensim"; private string m_channel = "#opensim";
private NetworkStream m_stream; private NetworkStream m_stream;
@ -30,12 +30,13 @@ namespace OpenSim.Region.Environment.Modules
private StreamReader m_ircReader; private StreamReader m_ircReader;
private Thread pingSender; private Thread pingSender;
private Thread listener;
private bool connected = false; private bool connected = false;
public ChatModule() public ChatModule()
{ {
m_nick = "OSimBot" + Util.RandomClass.Next(1, 99);
} }
public void Initialise(Scene scene) public void Initialise(Scene scene)
@ -58,6 +59,9 @@ namespace OpenSim.Region.Environment.Modules
pingSender = new Thread(new ThreadStart(this.PingRun)); pingSender = new Thread(new ThreadStart(this.PingRun));
pingSender.Start(); pingSender.Start();
listener = new Thread(new ThreadStart(this.ListenerRun));
listener.Start();
m_ircWriter.WriteLine(m_user); m_ircWriter.WriteLine(m_user);
m_ircWriter.Flush(); m_ircWriter.Flush();
m_ircWriter.WriteLine("NICK " + m_nick); m_ircWriter.WriteLine("NICK " + m_nick);
@ -99,6 +103,28 @@ namespace OpenSim.Region.Environment.Modules
} }
} }
public void ListenerRun()
{
string inputLine;
LLVector3 pos = new LLVector3(128, 128, 20);
while (true)
{
while ((inputLine = m_ircReader.ReadLine()) != null)
{
Console.WriteLine(inputLine);
if (inputLine.Contains(m_channel))
{
string mess = inputLine.Substring(inputLine.IndexOf(m_channel));
m_scene.ForEachScenePresence(delegate(ScenePresence presence)
{
presence.ControllingClient.SendChatMessage(Helpers.StringToField(mess), 255, pos, "IRC:",
LLUUID.Zero);
});
}
}
}
}
public void SimChat(byte[] message, byte type, LLVector3 fromPos, string fromName, LLUUID fromAgentID) public void SimChat(byte[] message, byte type, LLVector3 fromPos, string fromName, LLUUID fromAgentID)
{ {
ScenePresence avatar = null; ScenePresence avatar = null;
@ -112,7 +138,7 @@ namespace OpenSim.Region.Environment.Modules
if (connected) if (connected)
{ {
m_ircWriter.WriteLine("MSG " + m_channel +" :" + fromName + ", " + Util.FieldToString(message)); m_ircWriter.WriteLine("PRIVMSG " + m_channel + " :" + "<" + fromName + ">: " + Util.FieldToString(message));
m_ircWriter.Flush(); m_ircWriter.Flush();
} }

View File

@ -249,8 +249,7 @@ namespace OpenSim.Region.Environment.Scenes
m_folderID = LLUUID.Random(); m_folderID = LLUUID.Random();
m_flags = 0; m_flags = 0;
m_flags |= LLObject.ObjectFlags.Physics | m_flags |= LLObject.ObjectFlags.ObjectModify |
LLObject.ObjectFlags.ObjectModify |
LLObject.ObjectFlags.ObjectCopy | LLObject.ObjectFlags.ObjectCopy |
LLObject.ObjectFlags.ObjectYouOwner | LLObject.ObjectFlags.ObjectYouOwner |
LLObject.ObjectFlags.Touch | LLObject.ObjectFlags.Touch |