projects
/
spider.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
improve debugging on findroutes
[spider.git]
/
perl
/
Route.pm
diff --git
a/perl/Route.pm
b/perl/Route.pm
index 3301099890e23214948639c8aa28c667bc52dbfd..f637539c0c41c11f5ffa531b485789430a2fc4da 100644
(file)
--- a/
perl/Route.pm
+++ b/
perl/Route.pm
@@
-291,10
+291,12
@@
sub findroutes
my $call = shift;
my @out;
my $call = shift;
my @out;
- dbg("ROUTE: findroutes
:
$call") if isdbg('findroutes');
+ dbg("ROUTE: findroutes $call") if isdbg('findroutes');
# return immediately if we are directly connected
# return immediately if we are directly connected
- if (my $dxchan = DXChannel::get($call)) {
+ my $dxchan = DXChannel::get($call);
+ if ($dxchan) {
+ dbg("ROUTE: findroutes $call -> directly connected") if isdbg('findroutes');
return $dxchan;
}
return $dxchan;
}
@@
-305,6
+307,13
@@
sub findroutes
my @parent = $nref->isa('Route::User') ? @{$nref->{parent}} : $call;
my %cand;
foreach my $p (@parent) {
my @parent = $nref->isa('Route::User') ? @{$nref->{parent}} : $call;
my %cand;
foreach my $p (@parent) {
+ # return immediately if we are directly connected or a user's parent node is
+ $dxchan = DXChannel::get($p);
+ if ($dxchan) {
+ dbg("ROUTE: findroutes $call -> connected direct via parent $p") if isdbg('findroutes');
+ return $dxchan;
+ }
+
my $r = Route::Node::get($p);
if ($r) {
my %r = $r->PC92C_dxchan;
my $r = Route::Node::get($p);
if ($r) {
my %r = $r->PC92C_dxchan;
@@
-326,7
+335,7
@@
sub findroutes
if (isdbg('findroutes')) {
if (@out) {
foreach (sort {$b->[0] <=> $a->[0]} @out) {
if (isdbg('findroutes')) {
if (@out) {
foreach (sort {$b->[0] <=> $a->[0]} @out) {
- dbg("ROUTE: findroute $call -> $_->[0] " . $_->[1]->call);
+ dbg("ROUTE: findroute
s
$call -> $_->[0] " . $_->[1]->call);
}
}
}
}
}
}