1
0
Fork 0

2000 17 Jan updates from "Oliver Delise" <delise@mail.isis.de>

This commit is contained in:
curt 2000-01-18 18:28:51 +00:00
parent e7c6f292a5
commit e61785f83b
16 changed files with 232 additions and 153 deletions

View file

@ -3,7 +3,9 @@ README - containing Network info
Makefile.am - Makefile.am -
net_hud.cxx - display found player's info in bottom/left part of HUD net_hud.cxx - display found player's info in bottom/left part of HUD
network.cxx - initialization of netcode and vars network.cxx - initialization of netcode and vars
network.h - declaration of used vars and functions for libnetwork.a fgd.h -
should be included from other files using libnetwork network.h - declaration of used vars and functions for libNetworkOLK.a
should be included from other files using libNetworkOLK
net_send.cxx - communication with deamon net_send.cxx - communication with deamon
Tools - directory containing network tools and toys Tools - directory containing the deamon, tools and toys necessairy
for testing the network with and without FGFS.

View file

@ -31,4 +31,4 @@ b) Runtime - setting the "int net_hud_display" variable to 0 disables any
network display (default) network display (default)
Have Phun Have Phun
Oliver <delise@rp-plus.de> Oliver <delise@mail.isis.de>

View file

@ -1,9 +1,11 @@
FILES - This file, describing the other files FILES - This file, describing the other files
HEADERS - Necessairy headers to compile the programs HEADERS - Necessairy headers to compile the programs
README - Infos about programs INSTALL -
README - Detailed explanation about the programs and how to use
Makefile - Makefile -
fgd.h - Headerfile included by all programs fgd.h - Headerfile included by all programs
fgd.c - Flightgear deamon fgd.c - Flightgear deamon, talkative, strongly recommended for start
fgd_silent.c - Flightgear deamon with no debug output, for advanced users
fgd_com.c - Sends commandos to fgd fgd_com.c - Sends commandos to fgd
fgd_scan.c - Scanner to detect Flightgear deamons via TCP fgd_scan.c - Scanner to detect Flightgear deamons via TCP
fgd_mcp.c - Master Control Program for fgd fgd_mcp.c - Master Control Program for fgd

View file

@ -1,4 +1,4 @@
Please check the presence of the following header files on your system These includes must be available on any Un*x, Windoze and Mac Donald's
#include <stdio.h> #include <stdio.h>
#include <sys/socket.h> #include <sys/socket.h>
@ -9,3 +9,10 @@ Please check the presence of the following header files on your system
#include <sys/time.h> #include <sys/time.h>
#include <fcntl.h> #include <fcntl.h>
#include <sys/utsname.h> #include <sys/utsname.h>
Please look also into *all* your systemwide "socket.h" and the header
files (mainly in /usr/include/sys or krnl-src) included by them for
declarations like "MSG_PEEK" etc.
In case of missing MSG_foo declarations please contact me:
Oliver Delise <delise@mail.isis.de>

View file

@ -2,7 +2,7 @@ CPPFLAGS =
CFLAGS = CFLAGS =
CC = gcc CC = gcc
RM = rm RM = rm
PROGS = fgd fgd_scan fgd_com fgd_mcp fgd_verbose PROGS = fgd fgd_scan fgd_com fgd_mcp fgd_silent
BINDIR = /usr/local/bin BINDIR = /usr/local/bin
all: $(PROGS) all: $(PROGS)
@ -10,7 +10,7 @@ all: $(PROGS)
fgd: fgd.c fgd: fgd.c
$(CC) -o $@ $^ $(CC) -o $@ $^
fgd_verbose: fgd_verbose.c fgd_silent: fgd_silent.c
$(CC) -o $@ $^ $(CC) -o $@ $^
fgd_scan: fgd_scan.c fgd_scan: fgd_scan.c

View file

@ -1,7 +1,7 @@
Welcome to FlightGear Deamon fgd Welcome to FlightGear Deamon fgd
-------------------------------- --------------------------------
Here the first Tools to play with FlightGear Deamon. Here the first Tools to play with FlightGear Deamon.
This is yet alpha and the sources remain to be tidied up, This is yet alpha moving to beta and the sources remain to be tidied up,
and to get documented. and to get documented.
@ -242,6 +242,8 @@ History:
Nov 29 1999 -> Implementing scenario functions like virtual Nov 29 1999 -> Implementing scenario functions like virtual
Pilots Pilots
Nov 30 1999 -> ??? Nov 30 1999 -> ???
v0.1-beta : Jan 16 2000 -> Several libc5, glibc-2.0 and glibc-2.1
issues cleaned up
Future Plans: Future Plans:
@ -284,4 +286,4 @@ You can do whatever you want with this software, even enhance it.
Send comments/flames/BEER/whatever to delise@mail.isis.de Send comments/flames/BEER/whatever to delise@mail.isis.de
Oliver Delise Nov/08/99 Oliver Delise Jan/16/00

View file

@ -2,10 +2,9 @@
/* FGD.C by Oliver Delise */ /* FGD.C by Oliver Delise */
/* Contact info: */ /* Contact info: */
/* e-mail: delise@mail.isis.de */ /* e-mail: delise@mail.isis.de */
/* www: http://www.isis.de/members/~odelise/progs/mmx-emu/ */ /* www: http://www.isis.de/members/odelise/progs/flightgear */
/* ftp: http://www.isis.de/members/~odelise/progs/flightgear */
/* */ /* */
/* Version 0.1-alpha */ /* Version 0.1-beta */
/* The author of this program offers no waranty at all */ /* The author of this program offers no waranty at all */
/* about the correct execution of this software material. */ /* about the correct execution of this software material. */
/* Furthermore, the author can NOT be held responsible for */ /* Furthermore, the author can NOT be held responsible for */
@ -28,6 +27,8 @@
/* */ /* */
/* History: v0.1pre-alpha: May 25 1999 -> First release */ /* History: v0.1pre-alpha: May 25 1999 -> First release */
/* v0.1-alpha : Nov 08 1999 */ /* v0.1-alpha : Nov 08 1999 */
/* v0.1-beta : Jan 16 2000 */
/* libc5, glibc-2.0, 2.1 cleanups */
/*************************************************************/ /*************************************************************/
@ -41,7 +42,7 @@
#include <fcntl.h> #include <fcntl.h>
#include <sys/utsname.h> #include <sys/utsname.h>
#define printf // //#define printf //
/* Net-stuff */ /* Net-stuff */
fd_set rset, allset; fd_set rset, allset;
@ -217,7 +218,7 @@ int fgd_ele_len;
struct sockaddr_in address; struct sockaddr_in address;
struct sockaddr_in my_address; struct sockaddr_in my_address;
int result; int result;
extern char *sys_errlist[];
extern int errno; extern int errno;
int current_port = 0; int current_port = 0;
u_short base_port = 0; u_short base_port = 0;
@ -301,6 +302,7 @@ struct { char *ip, *lon, *lat, *alt;} fg_id;
if (1 == 1) { if (1 == 1) {
if ( bind(sock, (struct sockaddr *)&address, sizeof(address)) == -1) { if ( bind(sock, (struct sockaddr *)&address, sizeof(address)) == -1) {
printf(" Aiiiieeehh...ADRESS ALSO IN USE...\7hmmm...please check another port\n"); printf(" Aiiiieeehh...ADRESS ALSO IN USE...\7hmmm...please check another port\n");
printf(" Just wait a few seconds or do a netstat to see the port status.\n");
exit(-1); exit(-1);
} }
listen(sock, 5); listen(sock, 5);
@ -449,10 +451,12 @@ for (;;){
} }
else strcpy( fgd_client.adr, "UNKNOWN"); else strcpy( fgd_client.adr, "UNKNOWN");
/* writing answer back to client */ /* writing answer back to client */
sprintf( (char*) buff, "%s %s", "FGD", fgd_client.adr); sprintf( (char*) buff, "%sLH%s ", "FGD", fgd_client.adr);
buff[3] = strlen(fgd_client.adr); buff[3] = strlen(fgd_client.adr) + 1;
buff[4] = 0;
buff[ buff[3] + 4] = 0;
printf(" IP : %s\n", fgd_client.adr); printf(" IP : %s\n", fgd_client.adr);
write( my_sock, &buff, buff[3]+4); write( my_sock, &buff, buff[3]+5);
// close(my_sock); // close(my_sock);
break; break;
case 17: printf(" fgd : Get Mat4 DATA from client\n"); case 17: printf(" fgd : Get Mat4 DATA from client\n");
@ -500,7 +504,7 @@ for (;;){
sprintf( (char*) buff, "%s %s", "FGD", fgd_client.adr); sprintf( (char*) buff, "%s %s", "FGD", fgd_client.adr);
buff[3] = 0; buff[3] = 0;
fgd_cnt = 0; fgd_cnt = 0;
fgd_curpos = 5; fgd_curpos = 6;
test = head->next; test = head->next;
while (test != tail) { while (test != tail) {
printf(" IP : %-16s Callsign : %-16s\n", test->ipadr, test->callsign); printf(" IP : %-16s Callsign : %-16s\n", test->ipadr, test->callsign);
@ -533,7 +537,8 @@ for (;;){
if (fgd_cnt == 0) fgd_curpos --; if (fgd_cnt == 0) fgd_curpos --;
printf(" ele_len %d curpos %d\n", fgd_ele_len, fgd_curpos); printf(" ele_len %d curpos %d\n", fgd_ele_len, fgd_curpos);
buff[3] = fgd_curpos; buff[3] = fgd_curpos;
buff[4] = fgd_cnt; buff[4] = fgd_curpos / 256;
buff[5] = fgd_cnt;
write( my_sock, &buff, fgd_curpos); write( my_sock, &buff, fgd_curpos);
// close(my_sock); // close(my_sock);
break; break;
@ -596,10 +601,19 @@ for (;;){
} }
else strcpy( fgd_client.adr, "UNKNOWN"); else strcpy( fgd_client.adr, "UNKNOWN");
/* writing answer back to client */ /* writing answer back to client */
sprintf( (char*) buff, "%s %s", "FGD", fgd_client.adr); sprintf( (char*) buff, "FGDLH%s", fgd_client.adr);
buff[3] = strlen(fgd_client.adr); buff[3] = strlen(fgd_client.adr) + 1;
buff[4] = buff[buff[3]+5] = 0;
printf(" IP : %s\n", fgd_client.adr); printf(" IP : %s\n", fgd_client.adr);
write( my_sock, &buff, buff[3]+4); write( my_sock, &buff, buff[3]+5);
// Just leaving the old stuff in, to correct it for FGFS later...
// I'm sick of this f$%&ing libc5/glibc2.0/2.1 quirks
// Oliver...very angry...
// /* writing answer back to client */
// sprintf( (char*) buff, "%s %s", "FGD", fgd_client.adr);
// buff[3] = strlen(fgd_client.adr);
// printf(" IP : %s\n", fgd_client.adr);
// write( my_sock, &buff, buff[3]+4);
// close(my_sock); // close(my_sock);
break; break;
case 9: printf(" fgd : Shutdown\n"); case 9: printf(" fgd : Shutdown\n");

View file

@ -6,3 +6,14 @@
#include <sys/time.h> #include <sys/time.h>
#include <fcntl.h> #include <fcntl.h>
#include <sys/utsname.h> #include <sys/utsname.h>
/* this seems to be missing for glibc-2.0.x */
/* libc5 & glibc-2.1 do have them */
#ifndef MSG_PEEK
int MSG_PEEK = 0x02; /* Peek at incoming messages. */
#define MSG_PEEK MSG_PEEK
#endif
#ifndef MSG_WAITALL
int MSG_WAITALL = 0x100; /* Wait for a full request. */
#define MSG_WAITALL MSG_WAITALL
#endif

View file

@ -1,11 +1,10 @@
/***********************************************************/ /*************************************************************/
/* FGD_COM.C by Oliver Delise */ /* FGD_COM.C by Oliver Delise */
/* Contact info: */ /* Contact info: */
/* e-mail: delise@mail-isis.de */ /* e-mail: delise@mail-isis.de */
/* www: http://www.online-club.de/~olk/progs/mmx-emu/ */ /* www: http://www.isis.de/members/odelise/progs/flightgear */
/* ftp: http://www.online-club.de/~olk/progs/flightgear */
/* */ /* */
/* Version 0.1-alpha */ /* Version 0.1-beta */
/* The author of this program offers no waranty at all */ /* The author of this program offers no waranty at all */
/* about the correct execution of this software material. */ /* about the correct execution of this software material. */
/* Furthermore, the author can NOT be held responsible for */ /* Furthermore, the author can NOT be held responsible for */
@ -28,7 +27,9 @@
/* */ /* */
/* History: v0.1pre-alpha: May 25 1999 -> First release */ /* History: v0.1pre-alpha: May 25 1999 -> First release */
/* v0.1-alpha Nov 08 1999 */ /* v0.1-alpha Nov 08 1999 */
/***********************************************************/ /* v0.1-beta Jan 16 2000 -> libc5/glibc-2.0 */
/* glibc2.1 cleanups */
/*************************************************************/
#include <stdio.h> #include <stdio.h>
#include <sys/socket.h> #include <sys/socket.h>
@ -47,7 +48,6 @@ int my_sock;
struct sockaddr_in address; struct sockaddr_in address;
struct sockaddr_in my_address; struct sockaddr_in my_address;
int result; int result;
extern char *sys_errlist[];
extern int errno; extern int errno;
int current_port = 0; int current_port = 0;
u_short base_port = 0; u_short base_port = 0;

View file

@ -2,10 +2,9 @@
/* FGD_MCP.C by Oliver Delise */ /* FGD_MCP.C by Oliver Delise */
/* Contact info: */ /* Contact info: */
/* e-mail: delise@mail.isis.de */ /* e-mail: delise@mail.isis.de */
/* www: http://www.isis.de/members/~odelise/progs/mmx-emu/ */ /* www: http://www.isis.de/members/odelise/progs/flightgear */
/* ftp: http://www.isis.de/members/~odelise/progs/flightgear */
/* */ /* */
/* Version 0.1-alpha */ /* Version 0.1-beta */
/* The author of this program offers no waranty at all */ /* The author of this program offers no waranty at all */
/* about the correct execution of this software material. */ /* about the correct execution of this software material. */
/* Furthermore, the author can NOT be held responsible for */ /* Furthermore, the author can NOT be held responsible for */
@ -28,10 +27,13 @@
/* */ /* */
/* History: v0.1pre-alpha: May 25 1999 -> First release */ /* History: v0.1pre-alpha: May 25 1999 -> First release */
/* v0.1-alpha Nov 11 1999 */ /* v0.1-alpha Nov 11 1999 */
/* v0.1-beta Jan 16 2000 libc5/glibc-2.0 */
/* glibc-2.1 cleanups */
/*************************************************************/ /*************************************************************/
#include <stdio.h> #include <stdio.h>
#include "fgd.h" #include "fgd.h"
#include <math.h>
//#define printf // //#define printf //
@ -41,7 +43,6 @@ int my_sock;
struct sockaddr_in address; struct sockaddr_in address;
struct sockaddr_in my_address; struct sockaddr_in my_address;
int result; int result;
extern char *sys_errlist[];
extern int errno; extern int errno;
int current_port = 10000; int current_port = 10000;
u_short base_port = 10000; u_short base_port = 10000;
@ -213,13 +214,15 @@ void fgd_init(void){
printf(" IP : %s\n", fgd_ip); printf(" IP : %s\n", fgd_ip);
} }
} else if ((address.sin_addr.s_addr = inet_addr( fgd_host)) == INADDR_NONE) { } else if ((address.sin_addr.s_addr = inet_addr( fgd_host)) == INADDR_NONE) {
fprintf(stderr," Could not get %s host entry !\n", fgd_host);
printf(" NOT resolved !!!\n"); printf(" NOT resolved !!!\n");
exit(1); printf("MCP: Could not get %s host entry !\n", fgd_host);
printf("MCP: Enter '10' for deamon IP or fqdn or alias. (your choice)\n");
// exit(1);
} else if (verbose == 2) printf(" address valid\n"); } else if (verbose == 2) printf(" address valid\n");
if ((base_port > end_port) || ((short)base_port < 0)) { if ((base_port > end_port) || ((short)base_port < 0)) {
fprintf(stderr,"Bad port range : start=%d end=%d !\n"); printf("MCP: Bad port range : start=%d end=%d !\n");
printf("MCP: Enter '10' for deamon IP/fqdn\n");
exit(1); exit(1);
} else if (verbose == 2) { } else if (verbose == 2) {
printf(" Port range: %d to %d\n",base_port,end_port); printf(" Port range: %d to %d\n",base_port,end_port);
@ -319,10 +322,10 @@ void fgd_send_com( char *FGD_com, char *FGFS_host) {
/* The Receiving Part, fgd returns errormessages, succes, etc... */ /* The Receiving Part, fgd returns errormessages, succes, etc... */
do { do {
fgd_status = recv( sock, (char *) buffp, 4, MSG_WAITALL); fgd_status = recv( sock, (char *) buffp, 5, MSG_WAITALL);
printf(" status %d\n", fgd_status); printf(" status %d\n", fgd_status);
} }
// while ( (fgd_status != 4) && (fgd_status != 0) ); // while ( (fgd_status != 5) && (fgd_status != 0) );
while ( (fgd_status == -1) || (fgd_status == -1) ); while ( (fgd_status == -1) || (fgd_status == -1) );
if (verbose == 2) { if (verbose == 2) {
printf(" Got reply : %x %x %x\n", buffp[0], buffp[1], buffp[2]); printf(" Got reply : %x %x %x\n", buffp[0], buffp[1], buffp[2]);
@ -337,15 +340,17 @@ void fgd_send_com( char *FGD_com, char *FGFS_host) {
case 1: printf("FGD: Registering Host %s\n", FGFS_host); case 1: printf("FGD: Registering Host %s\n", FGFS_host);
break; break;
case 2: printf("FGD: Showing registered Hosts at %s\n", fgd_host); case 2: printf("FGD: Showing registered Hosts at %s\n", fgd_host);
if (buffp[3] != 4) { printf(" %d %d\n", buffp[3], buffp[4]);
if ( (buffp[3] + 256 * buffp[4]) != 5 ) {
/* FIXME: replace with SELECT to avoid broken pipes, known bug (-; */ /* FIXME: replace with SELECT to avoid broken pipes, known bug (-; */
/* but the transfer is calculated very accurately, null problemo */
do { do {
fgd_status = recv( sock, fgd_txt, buffp[3]-4, MSG_WAITALL); fgd_status = recv( sock, fgd_txt, buffp[3]-5, MSG_WAITALL);
// printf(" status %d\n", fgd_status); // printf(" status %d\n", fgd_status);
} }
// while ( (fgd_status != 4) && (fgd_status != 0) ); // while ( (fgd_status != 4) && (fgd_status != 0) );
while ( (fgd_status == -1) || (fgd_status == -1) ); while ( (fgd_status == -1) || (fgd_status == -1) );
// read( sock, fgd_txt, buffp[3]-4); // read( sock, fgd_txt, buffp[3]-5);
fgd_curpos = 2; fgd_curpos = 2;
for (fgd_cnt = 1; fgd_cnt < (fgd_txt[0]+1); fgd_cnt++) { for (fgd_cnt = 1; fgd_cnt < (fgd_txt[0]+1); fgd_cnt++) {
fgd_ele_len = fgd_txt[fgd_curpos-1]; fgd_ele_len = fgd_txt[fgd_curpos-1];
@ -355,27 +360,26 @@ void fgd_send_com( char *FGD_com, char *FGFS_host) {
printf(" #%d %s\n", fgd_cnt, fgfs_host); printf(" #%d %s\n", fgd_cnt, fgfs_host);
} }
} }
break; break;
case 5: printf("FGD: Receiving data from Host %s\n", FGFS_host); case 5: printf("FGD: Receiving data from Host %s\n", FGFS_host);
read( sock, fgd_txt, buffp[3]); read( sock, fgd_txt, (unsigned char) buffp[3] + 256 * (unsigned char) buffp[4]);
fgd_txt[buffp[3]] = 0; fgd_txt[buffp[3]] = 0;
if (strcmp(fgd_txt, "UNKNOWN") == -1) { if (strcmp(fgd_txt, "UNKNOWN") == 0) {
printf("FGD: Data from Host %s received\n", fgd_txt); printf("FGD: Host not in list, sorry...\n");
} }
else printf("FGD: Host not in list, sorry...\n"); else printf("FGD: Data from Host %s received\n", fgd_txt);
break; break;
case 6: printf("FGD: Sending data to Host %s\n", FGFS_host); case 6: printf("FGD: Sending data to Host %s\n", FGFS_host);
if (buffp[3] != 4) { if (buffp[3] != 5) {
/* FIXME: replace with SELECT */ /* FIXME: replace with SELECT */
if (verbose == 2) printf("Noch %d bytes\n", (unsigned char) buffp[3]); if (verbose == 2) printf("Noch %d bytes\n", (unsigned char) buffp[3] + 256 * (unsigned char) buffp[4]);
do { do {
fgd_status = recv( sock, fgd_txt, (unsigned char) buffp[3]-4, MSG_PEEK); fgd_status = recv( sock, fgd_txt, (unsigned char) buffp[3]-5, MSG_PEEK);
if (verbose == 2) printf("Status %d\n", fgd_status); if (verbose == 2) printf("Status %d\n", fgd_status);
} }
while ( (fgd_status == 4) || (fgd_status == -1) ); while ( (fgd_status == 5) || (fgd_status == -1) );
// while ( (fgd_status == -1) || (fgd_status == -1) ); // while ( (fgd_status == -1) || (fgd_status == -1) );
read( sock, fgd_txt, buffp[3]-4); read( sock, fgd_txt, buffp[3]-5);
fgd_curpos = 2; fgd_curpos = 2;
fgd_ppl_old = fgd_ppl; fgd_ppl_old = fgd_ppl;
fgd_ppl = fgd_txt[0]; fgd_ppl = fgd_txt[0];
@ -432,10 +436,10 @@ void fgd_send_com( char *FGD_com, char *FGFS_host) {
case 8: printf("FGD: Unregistering Host %s\n", FGFS_host); case 8: printf("FGD: Unregistering Host %s\n", FGFS_host);
read( sock, fgd_txt, buffp[3]); read( sock, fgd_txt, buffp[3]);
fgd_txt[buffp[3]] = 0; fgd_txt[buffp[3]] = 0;
if (strcmp(fgd_txt, "UNKNOWN") == -1) { if (strcmp(fgd_txt, "UNKNOWN") == 0) {
printf("FGD: Host %s unregistered\n", fgd_txt); printf("FGD: Host not in list, sorry...\n");
} }
else printf("FGD: Host not in list, sorry...\n"); else printf("FGD: Host %s unregistered\n", fgd_txt);
break; break;
case 9: printf(" Shutdown FlightGear-Deamon %s .\n", fgd_name); case 9: printf(" Shutdown FlightGear-Deamon %s .\n", fgd_name);
break; break;
@ -457,10 +461,10 @@ int main(int argc, char **argv) {
fgd_init(); fgd_init();
for ( ; (atoi( (char*) fgd_job)) != 99;){ for ( ; (atoi( (char*) fgd_job)) != 99;){
printf("MCP: ready...enter commando (42 help) "); printf("MCP: ready...enter commando (42 help) ");
gets((char *) fgd_job); fgets((char *) fgd_job, 5, stdin);
if (verbose == 2) printf("MCP: got %s %d\n", (char *) fgd_job, strlen((char *) fgd_job)); // if (verbose == 2) printf("MCP: got %s %d\n", (char *) fgd_job, strlen((char *) fgd_job));
if ( strcmp( fgd_job, "") > 0 ) switch( atoi((char*) fgd_job)) { if ( strcmp( fgd_job, "\n") > 0 ) switch( atoi((char*) fgd_job)) {
case 0 : if ( strcmp( (char *) fgd_job, "0") == 0 ){ case 0 : if ( strncmp( (char *) fgd_job, "0", 1) == 0 ){
printf("MCP: Scan for fgd\n"); printf("MCP: Scan for fgd\n");
fgd_send_com( "0", src_host); fgd_send_com( "0", src_host);
} }
@ -491,29 +495,35 @@ int main(int argc, char **argv) {
printf(" Deamon Host IP Port\n"); printf(" Deamon Host IP Port\n");
printf(" %-16s%-16s%-16s%-16d\n", fgd_name, fgd_host, fgd_ip, base_port); printf(" %-16s%-16s%-16s%-16d\n", fgd_name, fgd_host, fgd_ip, base_port);
printf("\n Enter new Host:[%s] ", fgd_host); printf("\n Enter new Host:[%s] ", fgd_host);
gets((char *) fgd_txt); fgets((char *) fgd_txt, 32, stdin);
if ( strlen(fgd_txt) != 0 ) { if ( strlen(fgd_txt) != 1 ) {
strcpy(fgd_host, fgd_txt); strcpy(fgd_host, fgd_txt);
fgd_host[ strlen( fgd_txt) - 1] = 0;
if (host_info = gethostbyname( fgd_host)) { if (host_info = gethostbyname( fgd_host)) {
bcopy(host_info->h_addr, (char *)&address.sin_addr,host_info->h_length); bcopy(host_info->h_addr, (char *)&address.sin_addr,host_info->h_length);
strcpy((char *) fgd_ip, (char *) inet_ntoa(address.sin_addr)); strcpy((char *) fgd_ip, (char *) inet_ntoa(address.sin_addr));
if (verbose == 2) { if (verbose == 2) {
printf(" resolved\n FGD running on HOST : %s", fgd_host); printf("MCP: Resolved...FGD running on HOST : %s", fgd_host);
printf(" IP : %s\n", fgd_ip); printf(" IP : %s\n", fgd_ip);
} }
} else if ((address.sin_addr.s_addr = inet_addr( fgd_host)) == INADDR_NONE) { } else if ((address.sin_addr.s_addr = inet_addr( fgd_host)) == INADDR_NONE) {
fprintf(stderr," Could not get %s host entry !\n", fgd_host); fprintf(stderr,"MCP: Could not get %s host entry !\n", fgd_host);
printf(" NOT resolved !!!\n"); printf(" NOT resolved !!!\n");
exit(1); // exit(1);
} else if (verbose == 2) printf(" address valid\n"); } else if (verbose == 2) printf(" address valid\n");
} }
break; break;
case 11 : printf("MCP: Choose default deamon Port:\n"); case 11 : printf("MCP: Choose default deamon Port:\n");
printf(" Deamon Host IP Port\n"); printf(" Deamon Host IP Port\n");
printf(" %-16s%-16s%-16s%-16d\n", fgd_name, fgd_host, fgd_ip, base_port); printf(" %-16s%-16s%-16s%-16d\n", fgd_name, fgd_host, fgd_ip, base_port);
printf(" Enter new Port: "); printf(" Enter new Port:[%d] ", base_port);
gets((char *) buffp); fgets((char *) buffp, 16, stdin);
current_port = atoi((char*) buffp); current_port = atoi((char*) buffp);
if (current_port < 1025) {
printf("MCP: Be fair please...Ports below 1024 are not a good choice\n");
current_port = base_port;
break;
}
if (current_port != 0) { if (current_port != 0) {
base_port = atoi((char*) buffp); base_port = atoi((char*) buffp);
end_port = base_port; end_port = base_port;
@ -543,7 +553,8 @@ int main(int argc, char **argv) {
break; break;
case 21 : printf("MCP: Enter your callsign, Pilot "); case 21 : printf("MCP: Enter your callsign, Pilot ");
gets((char *) fgd_callsign); fgets((char *) fgd_callsign, 32, stdin);
fgd_callsign[ strlen(fgd_callsign) - 1 ] = 0;
break; break;
case 42 : printf("MCP: Commands available:\n 0 Scan for fgd\n 1 Register\n"); case 42 : printf("MCP: Commands available:\n 0 Scan for fgd\n 1 Register\n");
printf(" 2 Show registered\n 3 Send MSG\n 4 Send MSG to ALL\n"); printf(" 2 Show registered\n 3 Send MSG\n 4 Send MSG to ALL\n");
@ -551,7 +562,7 @@ int main(int argc, char **argv) {
printf(" 8 Unregister from fgd\n 9 Shutdown fgd\n"); printf(" 8 Unregister from fgd\n 9 Shutdown fgd\n");
printf("10 Set deamon HOST\n11 Set deamon PORT\n"); printf("10 Set deamon HOST\n11 Set deamon PORT\n");
printf("20 Show values\n21 Set own callsign\n"); printf("20 Show values\n21 Set own callsign\n");
printf("31 Set deamon PORT\n"); // printf("31 Set deamon PORT\n");
printf("98 Stress test\n"); printf("98 Stress test\n");
printf("99 Quit Master Control Program (not recommended)\n"); printf("99 Quit Master Control Program (not recommended)\n");
break; break;
@ -566,14 +577,16 @@ int main(int argc, char **argv) {
fgd_send_com( "5", src_host); fgd_send_com( "5", src_host);
fgd_send_com( "6", src_host); fgd_send_com( "6", src_host);
printf("other lat:%7.3f boss lat:%7.3f\n", other->latf, boss->latf); printf("other lat:%7.3f boss lat:%7.3f\n", other->latf, boss->latf);
if (fabs(boss->latf - other->latf) > 0.001) { if (fabs( (double) boss->latf - (double) other->latf ) > 0.001) {
printf("other lat:%7.3f boss lat:%7.3f\n", other->latf, boss->latf); printf("other lat:%7.3f boss lat:%7.3f\n", other->latf, boss->latf);
fgd_loss++; fgd_loss++;
} }
} }
printf(" Packets lost: %d\n", fgd_loss); printf(" Packets lost: %d\n", fgd_loss);
break; break;
default: break; case 99 : printf("MCP: Good bye...\n");
break;
default: printf("MCP: ???\n");
} }
} }
// fgd_send_com( argv[5], argv[6]); // fgd_send_com( argv[5], argv[6]);
@ -588,6 +601,5 @@ int main(int argc, char **argv) {
free(fgfs_pilot); free(fgfs_pilot);
free(src_host); free(src_host);
free(fgd_txt); free(fgd_txt);
printf("MCP: Exit...\n");
exit(0); exit(0);
} }

View file

@ -1,11 +1,10 @@
/***********************************************************/ /*************************************************************/
/* FGD_SCAN.C by Oliver Delise */ /* FGD_SCAN.C by Oliver Delise */
/* Contact info: */ /* Contact info: */
/* e-mail: delise@mail-isis.de */ /* e-mail: delise@mail-isis.de */
/* www: http://www.online-club.de/~olk/progs/mmx-emu/ */ /* www: http://www.isis.de/members/odelise/progs/flightgear */
/* ftp: http://www.online-club.de/~olk/progs/flightgear */
/* */ /* */
/* Version 0.1-alpha */ /* Version 0.1-beta */
/* The author of this program offers no waranty at all */ /* The author of this program offers no waranty at all */
/* about the correct execution of this software material. */ /* about the correct execution of this software material. */
/* Furthermore, the author can NOT be held responsible for */ /* Furthermore, the author can NOT be held responsible for */
@ -28,7 +27,9 @@
/* */ /* */
/* History: v0.1pre-alpha: May 25 1999 -> First release */ /* History: v0.1pre-alpha: May 25 1999 -> First release */
/* v0.1-alpha Nov 08 1999 */ /* v0.1-alpha Nov 08 1999 */
/***********************************************************/ /* v0.1-beta Jan 16 2000 libc5/glibc-2.0 */
/* glibc-2.1 cleanups */
/*************************************************************/
#include <stdio.h> #include <stdio.h>
@ -47,7 +48,6 @@ int my_sock;
struct sockaddr_in address; struct sockaddr_in address;
struct sockaddr_in my_address; struct sockaddr_in my_address;
int result; int result;
extern char *sys_errlist[];
extern int errno; extern int errno;
int current_port = 20000; int current_port = 20000;
u_short base_port = 20000; u_short base_port = 20000;

View file

@ -6,3 +6,14 @@
#include <sys/time.h> #include <sys/time.h>
#include <fcntl.h> #include <fcntl.h>
#include <sys/utsname.h> #include <sys/utsname.h>
/* this seems to be missing for glibc-2.0.x */
/* libc5 & glibc-2.1 do have them */
#ifndef MSG_PEEK
int MSG_PEEK = 0x02; /* Peek at incoming messages. */
#define MSG_PEEK MSG_PEEK
#endif
#ifndef MSG_WAITALL
int MSG_WAITALL = 0x100; /* Wait for a full request. */
#define MSG_WAITALL MSG_WAITALL
#endif

View file

@ -2,7 +2,7 @@
// //
// Written by Oliver Delise, started May 1999. // Written by Oliver Delise, started May 1999.
// //
// Copyleft (C) 1999 Oliver Delise - delise@rp-plus.de // Copyleft (C) 1999 Oliver Delise - delise@mail.isis.de
// //
// This program is free software; you can redistribute it and/or // This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as // modify it under the terms of the GNU General Public License as

View file

@ -1,11 +1,10 @@
/*************************************************************/ /*************************************************************/
/* FGD_MCP.C by Oliver Delise */ /* NET_SEND.CXX by Oliver Delise */
/* Contact info: */ /* Contact info: */
/* e-mail: delise@mail.isis.de */ /* e-mail: delise@mail.isis.de */
/* www: http://www.isis.de/members/~odelise/progs/mmx-emu/ */ /* www: http://www.isis.de/members/odelise/progs/flightgear */
/* ftp: http://www.isis.de/members/~odelise/progs/flightgear */
/* */ /* */
/* Version 0.1-alpha */ /* Version 0.1-beta */
/* The author of this program offers no waranty at all */ /* The author of this program offers no waranty at all */
/* about the correct execution of this software material. */ /* about the correct execution of this software material. */
/* Furthermore, the author can NOT be held responsible for */ /* Furthermore, the author can NOT be held responsible for */
@ -28,6 +27,8 @@
/* */ /* */
/* History: v0.1pre-alpha: May 25 1999 -> First release */ /* History: v0.1pre-alpha: May 25 1999 -> First release */
/* v0.1-alpha Nov 11 1999 */ /* v0.1-alpha Nov 11 1999 */
/* v0.1-beta Jan 16 2000 -> libc5, glibc2.0 */
/* glibc-2.1 issues fixed */
/*************************************************************/ /*************************************************************/
#include <stdio.h> #include <stdio.h>
@ -256,12 +257,12 @@ void fgd_init(void){
} else if ((address.sin_addr.s_addr = inet_addr( fgd_host)) == INADDR_NONE) { } else if ((address.sin_addr.s_addr = inet_addr( fgd_host)) == INADDR_NONE) {
fprintf(stderr," Could not get %s host entry !\n", fgd_host); fprintf(stderr," Could not get %s host entry !\n", fgd_host);
printf(" NOT resolved !!!\n"); printf(" NOT resolved !!!\n");
exit(1); // exit(1);
} else if (verbose == 2) printf(" address valid\n"); } else if (verbose == 2) printf(" address valid\n");
if ((base_port > end_port) || ((short)base_port < 0)) { if ((base_port > end_port) || ((short)base_port < 0)) {
fprintf(stderr,"Bad port range : start=%d end=%d !\n"); fprintf(stderr,"Bad port range : start=%d end=%d !\n");
exit(1); // exit(1);
} else if (verbose == 2) { } else if (verbose == 2) {
printf(" Port range: %d to %d\n",base_port,end_port); printf(" Port range: %d to %d\n",base_port,end_port);
} }
@ -314,7 +315,8 @@ void fgd_send_com( char *FGD_com, char *FGFS_host) {
if (sock == -1) if (sock == -1)
{ {
fprintf(stderr, "Error assigning master socket: %s\n",sys_errlist[errno]); fprintf(stderr, "Error assigning master socket: %s\n",sys_errlist[errno]);
exit(-1); /* must check how severe this really is */
// exit(-1);
} }
address.sin_port = htons(current_port); address.sin_port = htons(current_port);
@ -416,7 +418,8 @@ void fgd_send_com( char *FGD_com, char *FGFS_host) {
} }
} else if (errno == 113) { } else if (errno == 113) {
fprintf(stderr,"No route to host !\n"); fprintf(stderr,"No route to host !\n");
exit(1); /* must check this */
// exit(1);
} }
/* fprintf(stderr,"Error %d connecting socket %d to port %d: %s\n", /* fprintf(stderr,"Error %d connecting socket %d to port %d: %s\n",
errno,sock,current_port,sys_errlist[errno]); */ errno,sock,current_port,sys_errlist[errno]); */
@ -473,10 +476,18 @@ void fgd_send_com( char *FGD_com, char *FGFS_host) {
case 5: printf("FGD: Receiving data from Host %s\n", FGFS_host); case 5: printf("FGD: Receiving data from Host %s\n", FGFS_host);
read( sock, fgd_txt, buffp[3]); read( sock, fgd_txt, buffp[3]);
fgd_txt[buffp[3]] = 0; fgd_txt[buffp[3]] = 0;
/* This works...
if (strcmp(fgd_txt, "UNKNOWN") == 0) {
printf("FGD: Host not in list, sorry...\n");
}
else printf("FGD: Data from Host %s received\n", fgd_txt);
*/
/* This has problem with glibc-2.1
if (strcmp(fgd_txt, "UNKNOWN") == -1) { if (strcmp(fgd_txt, "UNKNOWN") == -1) {
if (verbose == 2) printf("FGD: Data from Host %s received\n", fgd_txt); if (verbose == 2) printf("FGD: Data from Host %s received\n", fgd_txt);
} }
else if (verbose == 2) printf("FGD: Host not in list, sorry...\n"); else if (verbose == 2) printf("FGD: Host not in list, sorry...\n");
*/
break; break;
case 17: if (verbose == 2) printf("FGD: Receiving Mat4 data from Host %s\n", FGFS_host); case 17: if (verbose == 2) printf("FGD: Receiving Mat4 data from Host %s\n", FGFS_host);
read( sock, fgd_txt, fgd_reply_len); read( sock, fgd_txt, fgd_reply_len);
@ -634,11 +645,18 @@ void fgd_send_com( char *FGD_com, char *FGFS_host) {
test = test->next; test = test->next;
} }
fgd_ppl = 0; fgd_ppl = 0;
/* /* This does...
if (strcmp(fgd_txt, "UNKNOWN") == 0) {
printf("FGD: Host not in list, sorry...\n");
}
else printf("FGD: Host %s unregistered\n", fgd_txt);
*/
/* This does not work on glibc-2.1
if (strcmp(fgd_txt, "UNKNOWN") == -1) { if (strcmp(fgd_txt, "UNKNOWN") == -1) {
printf("FGD: Host %s unregistered\n", fgd_txt); printf("FGD: Host %s unregistered\n", fgd_txt);
} }
else printf("FGD: Host not in list, sorry...\n"); */ else printf("FGD: Host not in list, sorry...\n");
*/
break; break;
case 9: printf(" Shutdown FlightGear-Deamon %s .\n", fgd_name); case 9: printf(" Shutdown FlightGear-Deamon %s .\n", fgd_name);
break; break;

View file

@ -2,7 +2,7 @@
// //
// Written by Oliver Delise, started May 1999. // Written by Oliver Delise, started May 1999.
// //
// Copyleft (C) 1999 Oliver Delise - delise@rp-plus.de // Copyleft (C) 1999 Oliver Delise - delise@mail.isis.de
// //
// This program is free software; you can redistribute it and/or // This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as // modify it under the terms of the GNU General Public License as

View file

@ -2,7 +2,7 @@
// //
// Written by Oliver Delise, started May 1999. // Written by Oliver Delise, started May 1999.
// //
// Copyleft (C) 1999 Oliver Delise - delise@rp-plus.de // Copyleft (C) 1999 Oliver Delise - delise@mail.isis.de
// //
// This program is free software; you can redistribute it and/or // This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as // modify it under the terms of the GNU General Public License as