00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00019 
00020 
00021 
00022 
00023 
00024 
00025 
00026 #include "Aria.h"
00027 
00028 
00060 int main()
00061 {
00062   
00063   char *strToSend="Hello Client";
00064   
00065   char buff[100];
00066   
00067   size_t strSize;
00068 
00069   
00070   
00071   ArSocket serverSock, clientSock;
00072 
00073   
00074   
00075   Aria::init();
00076 
00077   
00078   if (serverSock.open(7777, ArSocket::TCP))
00079     ArLog::log(ArLog::Normal, "socketServerExample: Opened the server port.");
00080   else
00081   {
00082     ArLog::log(ArLog::Normal, "socketServerExample: Failed to open the server port: %s.",
00083        serverSock.getErrorStr().c_str());
00084     return(-1);
00085   }
00086 
00087   
00088   if (serverSock.accept(&clientSock))
00089     ArLog::log(ArLog::Normal, "socketServerExample: Client has connected.");
00090   else
00091     ArLog::log(ArLog::Terse, "socketServerExample: Error in accepting a connection from the client: %s.",
00092        serverSock.getErrorStr().c_str());
00093 
00094   
00095   
00096   
00097   if (clientSock.write(strToSend, strlen(strToSend)) == strlen(strToSend))
00098     ArLog::log(ArLog::Normal, "socketServerExample: Said hello to the client.");
00099   else
00100   {
00101     ArLog::log(ArLog::Normal, "socketServerExample: Error in sending hello string to the client.");
00102     return(-1);
00103   }
00104 
00105   
00106   
00107   strSize=clientSock.read(buff, sizeof(buff));
00108 
00109   
00110   if (strSize > 0)
00111   {
00112     
00113     buff[strSize]='\0';
00114     ArLog::log(ArLog::Normal, "socketServerExample: Client said: %s.", buff);
00115   }
00116   else
00117   {
00118     ArLog::log(ArLog::Normal, "socketServerExample: Error in waiting/reading the hello from the client.");
00119     return(-1);
00120   }
00121 
00122   
00123   clientSock.close();
00124   ArLog::log(ArLog::Normal, "socketServerExample: Socket to client closed.");
00125   
00126 
00127   
00128   serverSock.close();
00129     ArLog::log(ArLog::Normal, "socketServerExample: Server socket closed.");
00130 
00131 
00132   
00133   Aria::uninit();
00134 
00135   
00136   return(0);
00137 }