diff options
author | ddomingo <ddomingo@redhat.com> | 2008-09-15 13:53:32 +1000 |
---|---|---|
committer | ddomingo <ddomingo@redhat.com> | 2008-09-15 13:53:32 +1000 |
commit | 58b5c08a69fa298a92ead6d9384415ff750ea2ef (patch) | |
tree | e6069a6944ccf0bcb5e9884104d3819121896dfb /stap-find-servers | |
parent | 4ef55e8308f34b73d6a0a69850900ae0d06499ce (diff) | |
parent | 8b524b8e33e94007b15f33546819056b56435cf2 (diff) | |
download | systemtap-steved-58b5c08a69fa298a92ead6d9384415ff750ea2ef.tar.gz systemtap-steved-58b5c08a69fa298a92ead6d9384415ff750ea2ef.tar.xz systemtap-steved-58b5c08a69fa298a92ead6d9384415ff750ea2ef.zip |
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap
Diffstat (limited to 'stap-find-servers')
-rwxr-xr-x | stap-find-servers | 28 |
1 files changed, 19 insertions, 9 deletions
diff --git a/stap-find-servers b/stap-find-servers index fea645bd..3038c54e 100755 --- a/stap-find-servers +++ b/stap-find-servers @@ -50,19 +50,27 @@ function match_server { local rc=1 # not found yet # Loop over the avahi service descriptors. - while read + read || exit $rc + while test "X$REPLY" != "X" do + server_name= + server_ip= + server_port= + server_sysinfo= + # Examine the next service descriptor # Is it a stap server? - (echo $REPLY | grep -q "^=.*_stap") || continue + if ! echo $REPLY | grep -q "=.* .* IPv4 .*_stap"; then + read || exit $rc + continue + fi + REPLY= # Get the details of the service - local service_tag equal data + local service_tag equal service_data while read service_tag equal service_data do case $service_tag in - '=' ) - break ;; hostname ) server_name=`expr "$service_data" : '\[\([^]]*\)\]'` ;; @@ -74,12 +82,12 @@ function match_server { local attempt for ((attempt=0; $attempt < 5; ++attempt)) do - server_ip=`expr "$server_ip" : '^\([0-9]*\.[0-9]*\.[0-9]*\.[0-9]*\)$'` + server_ip=`expr "$server_ip" : '\([0-9]*\.[0-9]*\.[0-9]*\.[0-9]*\)$'` if test "X$server_ip" != "X"; then break fi # Resolve the server.domain to an ip address. - server_ip=`avahi-resolve-host-name $hostname` + server_ip=`avahi-resolve-host-name $server_name` server_ip=`expr "$server_ip" : '.* \(.*\)$'` done ;; @@ -90,7 +98,9 @@ function match_server { server_sysinfo=`expr "$service_data" : '\[.*\"\(sysinfo=[^]]*\)\"\]'` ;; * ) - break ;; + REPLY="$service_tag $equal $service_data" + break + ;; esac done @@ -100,7 +110,7 @@ function match_server { fi # It's compatible, or we're finding all servers. Print a summary line - echo $server_name $server_ip $server_port "'$server_sysinfo'" + echo "$server_name $server_ip $server_port '$server_sysinfo'" rc=0 done |