listener: use protected members instead of public and use base.x to access them
This commit is contained in:
parent
7a9871ce9d
commit
c7f5545886
|
@ -60,21 +60,26 @@ namespace SparkleLib {
|
||||||
public abstract void Dispose ();
|
public abstract void Dispose ();
|
||||||
|
|
||||||
public abstract bool IsConnected { get; }
|
public abstract bool IsConnected { get; }
|
||||||
public string Server;
|
|
||||||
public string Channel;
|
|
||||||
|
|
||||||
// Announcements that weren't sent off
|
// Announcements that weren't sent off
|
||||||
// because we were disconnected
|
// because we were disconnected
|
||||||
public List<string> AnnounceQueue = new List<string> ();
|
protected List<string> announce_queue = new List<string> ();
|
||||||
|
|
||||||
// Announcements of remote changes that we've received
|
// Announcements of remote changes that we've received
|
||||||
public int ChangesQueue = 0;
|
public int ChangesQueue {
|
||||||
|
get {
|
||||||
|
return this.changes_queue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected string server;
|
||||||
|
protected string channel;
|
||||||
|
protected int changes_queue = 0;
|
||||||
|
|
||||||
public SparkleListenerBase (string server, string folder_identifier, NotificationServerType type) { }
|
public SparkleListenerBase (string server, string folder_identifier, NotificationServerType type) { }
|
||||||
|
|
||||||
public void DecrementChangesQueue ()
|
public void DecrementChangesQueue ()
|
||||||
{
|
{
|
||||||
ChangesQueue--;
|
this.changes_queue--;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void OnConnected ()
|
public void OnConnected ()
|
||||||
|
|
|
@ -35,14 +35,14 @@ namespace SparkleLib {
|
||||||
NotificationServerType type) : base (server, folder_identifier, type)
|
NotificationServerType type) : base (server, folder_identifier, type)
|
||||||
{
|
{
|
||||||
if (type == NotificationServerType.Own) {
|
if (type == NotificationServerType.Own) {
|
||||||
Server = server;
|
base.server = server;
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
// This is SparkleShare's centralized notification service.
|
// This is SparkleShare's centralized notification service.
|
||||||
// Don't worry, we only use this server as a backup if you
|
// Don't worry, we only use this server as a backup if you
|
||||||
// don't have your own. All data needed to connect is hashed and
|
// don't have your own. All data needed to connect is hashed and
|
||||||
// we don't store any personal information ever
|
// we don't store any personal information ever
|
||||||
Server = "204.62.14.135";
|
base.server = "204.62.14.135";
|
||||||
}
|
}
|
||||||
|
|
||||||
// Try to get a uniqueish nickname
|
// Try to get a uniqueish nickname
|
||||||
|
@ -54,7 +54,7 @@ namespace SparkleLib {
|
||||||
|
|
||||||
// Hash and salt the folder identifier, so
|
// Hash and salt the folder identifier, so
|
||||||
// nobody knows any possible folder details
|
// nobody knows any possible folder details
|
||||||
Channel = "#" + SHA1 (folder_identifier + "sparkles");
|
base.channel = "#" + SHA1 (folder_identifier + "sparkles");
|
||||||
|
|
||||||
this.client = new IrcClient () {
|
this.client = new IrcClient () {
|
||||||
PingTimeout = 180,
|
PingTimeout = 180,
|
||||||
|
@ -62,13 +62,13 @@ namespace SparkleLib {
|
||||||
};
|
};
|
||||||
|
|
||||||
this.client.OnConnected += delegate {
|
this.client.OnConnected += delegate {
|
||||||
SparkleHelpers.DebugInfo ("ListenerIrc", "Connected to " + Channel + " on " + Server);
|
SparkleHelpers.DebugInfo ("ListenerIrc", "Connected to " + base.channel + " on " + base.server);
|
||||||
|
|
||||||
OnConnected ();
|
OnConnected ();
|
||||||
|
|
||||||
if (AnnounceQueue.Count > 0) {
|
if (base.announce_queue.Count > 0) {
|
||||||
string message = AnnounceQueue [AnnounceQueue.Count - 1];
|
string message = base.announce_queue [base.announce_queue.Count - 1];
|
||||||
AnnounceQueue = new List<string> ();
|
base.announce_queue = new List<string> ();
|
||||||
|
|
||||||
SparkleHelpers.DebugInfo ("ListenerIrc", "Delivering queued messages...");
|
SparkleHelpers.DebugInfo ("ListenerIrc", "Delivering queued messages...");
|
||||||
Announce (message);
|
Announce (message);
|
||||||
|
@ -76,15 +76,15 @@ namespace SparkleLib {
|
||||||
};
|
};
|
||||||
|
|
||||||
this.client.OnDisconnected += delegate {
|
this.client.OnDisconnected += delegate {
|
||||||
SparkleHelpers.DebugInfo ("ListenerIrc", "Disconnected from " + Channel + " on " + Server);
|
SparkleHelpers.DebugInfo ("ListenerIrc", "Disconnected from " + base.channel + " on " + base.server);
|
||||||
|
|
||||||
OnDisconnected ();
|
OnDisconnected ();
|
||||||
};
|
};
|
||||||
|
|
||||||
this.client.OnChannelMessage += delegate (object o, IrcEventArgs args) {
|
this.client.OnChannelMessage += delegate (object o, IrcEventArgs args) {
|
||||||
SparkleHelpers.DebugInfo ("ListenerIrc", "Got message from " + Channel + " on " + Server);
|
SparkleHelpers.DebugInfo ("ListenerIrc", "Got message from " + base.channel + " on " + base.server);
|
||||||
string message = args.Data.Message.Trim ();
|
string message = args.Data.Message.Trim ();
|
||||||
ChangesQueue++;
|
base.changes_queue++;
|
||||||
|
|
||||||
OnRemoteChange (message);
|
OnRemoteChange (message);
|
||||||
};
|
};
|
||||||
|
@ -94,16 +94,16 @@ namespace SparkleLib {
|
||||||
// Starts a new thread and listens to the channel
|
// Starts a new thread and listens to the channel
|
||||||
public override void Connect ()
|
public override void Connect ()
|
||||||
{
|
{
|
||||||
SparkleHelpers.DebugInfo ("ListenerIrc", "Connecting to " + Channel + " on " + Server);
|
SparkleHelpers.DebugInfo ("ListenerIrc", "Connecting to " + base.channel + " on " + base.server);
|
||||||
|
|
||||||
this.thread = new Thread (
|
this.thread = new Thread (
|
||||||
new ThreadStart (delegate {
|
new ThreadStart (delegate {
|
||||||
try {
|
try {
|
||||||
|
|
||||||
// Connect, login, and join the channel
|
// Connect, login, and join the channel
|
||||||
this.client.Connect (new string [] {Server}, 6667);
|
this.client.Connect (new string [] {base.server}, 6667);
|
||||||
this.client.Login (this.nick, this.nick);
|
this.client.Login (this.nick, this.nick);
|
||||||
this.client.RfcJoin (Channel);
|
this.client.RfcJoin (base.channel);
|
||||||
|
|
||||||
// List to the channel, this blocks the thread
|
// List to the channel, this blocks the thread
|
||||||
this.client.Listen ();
|
this.client.Listen ();
|
||||||
|
@ -123,11 +123,11 @@ namespace SparkleLib {
|
||||||
public override void Announce (string message)
|
public override void Announce (string message)
|
||||||
{
|
{
|
||||||
if (IsConnected) {
|
if (IsConnected) {
|
||||||
SparkleHelpers.DebugInfo ("ListenerIrc", "Announcing to " + Channel + " on " + Server);
|
SparkleHelpers.DebugInfo ("ListenerIrc", "Announcing to " + base.channel + " on " + base.server);
|
||||||
this.client.SendMessage (SendType.Message, Channel, message);
|
this.client.SendMessage (SendType.Message, base.channel, message);
|
||||||
} else {
|
} else {
|
||||||
SparkleHelpers.DebugInfo ("ListenerIrc", "Not connected. Queuing message");
|
SparkleHelpers.DebugInfo ("ListenerIrc", "Not connected. Queuing message");
|
||||||
AnnounceQueue.Add (message);
|
base.announce_queue.Add (message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue