projects
/
spider.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
a mostly working send message implementation
[spider.git]
/
perl
/
DXChannel.pm
diff --git
a/perl/DXChannel.pm
b/perl/DXChannel.pm
index 5a9ca3b2de56c41bfae40ef7f480c28e840a8f4f..6ca2fc2c540a82a0ee31a6faa5ed6309f9cc198c 100644
(file)
--- a/
perl/DXChannel.pm
+++ b/
perl/DXChannel.pm
@@
-26,8
+26,8
@@
package DXChannel;
use Msg;
package DXChannel;
use Msg;
-use DXUtil;
use DXM;
use DXM;
+use DXUtil;
use DXDebug;
use Carp;
use DXDebug;
use Carp;
@@
-58,6
+58,8
@@
use vars qw(%channels %valid);
dx => '0,DX Spots,yesno',
redirect => '0,Redirect messages to',
lang => '0,Language',
dx => '0,DX Spots,yesno',
redirect => '0,Redirect messages to',
lang => '0,Language',
+ func => '9,Function',
+ loc => '9,Local Vars', # used by func to store local variables in
);
# create a new channel object [$obj = DXChannel->new($call, $msg_conn_obj, $user_obj)]
);
# create a new channel object [$obj = DXChannel->new($call, $msg_conn_obj, $user_obj)]
@@
-124,6
+126,13
@@
sub is_user
return $self->{sort} eq 'U';
}
return $self->{sort} eq 'U';
}
+# is it a connect type
+sub is_connect
+{
+ my $self = shift;
+ return $self->{sort} eq 'C';
+}
+
# handle out going messages, immediately without waiting for the select to drop
# this could, in theory, block
sub send_now
# handle out going messages, immediately without waiting for the select to drop
# this could, in theory, block
sub send_now
@@
-174,20
+183,23
@@
sub send_file
$self->send(@buf);
}
$self->send(@buf);
}
-#
just a shortcut for $dxchan->send(msg(...));
+#
this will implement language independence (in time)
sub msg
{
my $self = shift;
sub msg
{
my $self = shift;
-
$self->send(DXM::msg(@_)
);
+
return DXM::msg(@_
);
}
# change the state of the channel - lots of scope for debugging here :-)
sub state
{
my $self = shift;
}
# change the state of the channel - lots of scope for debugging here :-)
sub state
{
my $self = shift;
- $self->{oldstate} = $self->{state};
- $self->{state} = shift;
- dbg('state', "$self->{call} channel state $self->{oldstate} -> $self->{state}\n");
+ if (@_) {
+ $self->{oldstate} = $self->{state};
+ $self->{state} = shift;
+ dbg('state', "$self->{call} channel func $self->{func} state $self->{oldstate} -> $self->{state}\n");
+ }
+ return $self->{state};
}
# disconnect this channel
}
# disconnect this channel