Apply vodz' last_patch44 -- cleanup several chars to be const, fix
rotten error handling, kill spare \n's, etc
This commit is contained in:
parent
3ece93ba0f
commit
b0c39a8a8d
@ -45,7 +45,7 @@ extern void displayroutes(int noresolve, int netstatfmt);
|
|||||||
#define NETSTAT_RAW 0x40
|
#define NETSTAT_RAW 0x40
|
||||||
#define NETSTAT_UNIX 0x80
|
#define NETSTAT_UNIX 0x80
|
||||||
|
|
||||||
int flags = NETSTAT_CONNECTED |
|
static int flags = NETSTAT_CONNECTED |
|
||||||
NETSTAT_TCP | NETSTAT_UDP | NETSTAT_RAW | NETSTAT_UNIX;
|
NETSTAT_TCP | NETSTAT_UDP | NETSTAT_RAW | NETSTAT_UNIX;
|
||||||
|
|
||||||
#define PROGNAME_WIDTHs PROGNAME_WIDTH1(PROGNAME_WIDTH)
|
#define PROGNAME_WIDTHs PROGNAME_WIDTH1(PROGNAME_WIDTH)
|
||||||
@ -68,7 +68,7 @@ enum {
|
|||||||
TCP_CLOSING /* now a valid state */
|
TCP_CLOSING /* now a valid state */
|
||||||
};
|
};
|
||||||
|
|
||||||
static const char *tcp_state[] =
|
static const char * const tcp_state[] =
|
||||||
{
|
{
|
||||||
"",
|
"",
|
||||||
"ESTABLISHED",
|
"ESTABLISHED",
|
||||||
@ -142,7 +142,8 @@ static void snprint_ip_port(char *ip_port, int size, struct sockaddr *addr, int
|
|||||||
static void tcp_do_one(int lnr, const char *line)
|
static void tcp_do_one(int lnr, const char *line)
|
||||||
{
|
{
|
||||||
char local_addr[64], rem_addr[64];
|
char local_addr[64], rem_addr[64];
|
||||||
char *state_str, more[512];
|
const char *state_str;
|
||||||
|
char more[512];
|
||||||
int num, local_port, rem_port, d, state, timer_run, uid, timeout;
|
int num, local_port, rem_port, d, state, timer_run, uid, timeout;
|
||||||
struct sockaddr_in localaddr, remaddr;
|
struct sockaddr_in localaddr, remaddr;
|
||||||
unsigned long rxq, txq, time_len, retr, inode;
|
unsigned long rxq, txq, time_len, retr, inode;
|
||||||
@ -168,10 +169,10 @@ static void tcp_do_one(int lnr, const char *line)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (num < 10) {
|
if (num < 10) {
|
||||||
error_msg("warning, got bogus tcp line.\n");
|
error_msg("warning, got bogus tcp line.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
state_str=(char*)tcp_state[state];
|
state_str = tcp_state[state];
|
||||||
if ((rem_port && (flags&NETSTAT_CONNECTED)) ||
|
if ((rem_port && (flags&NETSTAT_CONNECTED)) ||
|
||||||
(!rem_port && (flags&NETSTAT_LISTENING)))
|
(!rem_port && (flags&NETSTAT_LISTENING)))
|
||||||
{
|
{
|
||||||
@ -218,7 +219,7 @@ static void udp_do_one(int lnr, const char *line)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (num < 10) {
|
if (num < 10) {
|
||||||
error_msg("warning, got bogus udp line.\n");
|
error_msg("warning, got bogus udp line.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
switch (state) {
|
switch (state) {
|
||||||
@ -282,7 +283,7 @@ static void raw_do_one(int lnr, const char *line)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (num < 10) {
|
if (num < 10) {
|
||||||
error_msg("warning, got bogus raw line.\n");
|
error_msg("warning, got bogus raw line.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
state_str=itoa(state);
|
state_str=itoa(state);
|
||||||
@ -325,7 +326,7 @@ static void unix_do_one(int nr, const char *line)
|
|||||||
num = sscanf(line, "%p: %lX %lX %lX %X %X %d %s",
|
num = sscanf(line, "%p: %lX %lX %lX %X %X %d %s",
|
||||||
&d, &refcnt, &proto, &unix_flags, &type, &state, &inode, path);
|
&d, &refcnt, &proto, &unix_flags, &type, &state, &inode, path);
|
||||||
if (num < 6) {
|
if (num < 6) {
|
||||||
error_msg("warning, got bogus unix line.\n");
|
error_msg("warning, got bogus unix line.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!(has & HAS_INODE))
|
if (!(has & HAS_INODE))
|
||||||
@ -432,22 +433,19 @@ static void unix_do_one(int nr, const char *line)
|
|||||||
#define _PATH_PROCNET_RAW "/proc/net/raw"
|
#define _PATH_PROCNET_RAW "/proc/net/raw"
|
||||||
#define _PATH_PROCNET_UNIX "/proc/net/unix"
|
#define _PATH_PROCNET_UNIX "/proc/net/unix"
|
||||||
|
|
||||||
static int do_info(char *file, char *name, void (*proc)(int, const char *))
|
static void do_info(const char *file, const char *name, void (*proc)(int, const char *))
|
||||||
{
|
{
|
||||||
char buffer[8192];
|
char buffer[8192];
|
||||||
int rc = 0;
|
|
||||||
int lnr = 0;
|
int lnr = 0;
|
||||||
FILE *procinfo;
|
FILE *procinfo;
|
||||||
|
|
||||||
procinfo = fopen((file), "r");
|
procinfo = fopen(file, "r");
|
||||||
if (procinfo == NULL) {
|
if (procinfo == NULL) {
|
||||||
if (errno != ENOENT) {
|
if (errno != ENOENT) {
|
||||||
perror((file));
|
perror(file);
|
||||||
return -1;
|
} else {
|
||||||
|
error_msg("no support for `%s' on this system.", name);
|
||||||
}
|
}
|
||||||
error_msg("%s: no support for `%s' on this system.\n",
|
|
||||||
"netstat", (name));
|
|
||||||
rc = 1;
|
|
||||||
} else {
|
} else {
|
||||||
do {
|
do {
|
||||||
if (fgets(buffer, sizeof(buffer), procinfo))
|
if (fgets(buffer, sizeof(buffer), procinfo))
|
||||||
@ -455,7 +453,6 @@ static int do_info(char *file, char *name, void (*proc)(int, const char *))
|
|||||||
} while (!feof(procinfo));
|
} while (!feof(procinfo));
|
||||||
fclose(procinfo);
|
fclose(procinfo);
|
||||||
}
|
}
|
||||||
return rc;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -505,8 +502,7 @@ int netstat_main(int argc, char **argv)
|
|||||||
displayroutes ( flags & NETSTAT_NUMERIC, !extended );
|
displayroutes ( flags & NETSTAT_NUMERIC, !extended );
|
||||||
return 0;
|
return 0;
|
||||||
#else
|
#else
|
||||||
printf( "-r (display routing table) is not compiled in.\n" );
|
error_msg_and_die( "-r (display routing table) is not compiled in." );
|
||||||
return 1;
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user