int ACE_TMAIN (int argc, ACE_TCHAR *argv[]) { parse_args (argc, argv); ACE_LSOCK_Stream sc; ACE_LSOCK_Connector con; if (con.connect (sc, ACE_UNIX_Addr (rendezvous)) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("connect")), -1); if (do_client_processing (sc) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("do_client_processing")), -1); if (sc.close () == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("close")), -1); return 0; }
int ACE_TMAIN (int argc, ACE_TCHAR *argv[]) { parse_args (argc, argv); int fd; char buf[BUFSIZ]; int n; ACE_LSOCK_Stream sc; ACE_LSOCK_Connector con; if (con.connect (sc, ACE_UNIX_Addr (rendezvous)) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("connect")), -1); if ((fd = ACE_OS::open (file_name, O_RDONLY)) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("open")), -1); // Send the open file descriptor to the server! if (sc.send_handle (fd) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("send_handle")), -1); if ((n = sc.recv_n (buf, sizeof buf)) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("recv")), -1); else ACE_OS::write (ACE_STDOUT, buf, n); if (ACE_OS::close (fd) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("close")), -1); return 0; }
int ACE_TMAIN (int argc, ACE_TCHAR *argv[]) { const ACE_TCHAR *rendezvous = argc > 1 ? argv[1] : ACE_DEFAULT_RENDEZVOUS; char buf[BUFSIZ]; ACE_LSOCK_Stream cli_stream; ACE_LSOCK_Connector con; ACE_UNIX_Addr remote_addr (rendezvous); // Establish the connection with server. if (con.connect (cli_stream, remote_addr) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("connect")), 1); // Send data to server (correctly handles "incomplete writes"). for (int r_bytes; (r_bytes = ACE_OS::read (ACE_STDIN, buf, sizeof buf)) > 0; ) if (cli_stream.send_n (buf, r_bytes) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("send_n")), 1); // Explicitly close the writer-side of the connection. if (cli_stream.close_writer () == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("close_writer")), 1); // Wait for handshake with server. if (cli_stream.recv_n (buf, 1) != 1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("recv_n")), 1); // Close the connection completely. if (cli_stream.close () == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p\n"), ACE_TEXT ("close")), 1); return 0; }
int ACE_TMAIN (int argc, ACE_TCHAR *argv[]) { const ACE_TCHAR *file_name = argc > 1 ? argv[1] : ACE_TEXT ("./local_data"); const ACE_TCHAR *rendezvous = argc > 2 ? argv[2] : ACE_DEFAULT_RENDEZVOUS; ACE_LSOCK_Stream cli_stream; ACE_UNIX_Addr addr (rendezvous); // Establish the connection with server. ACE_LSOCK_Connector connector; if (connector.connect (cli_stream, addr) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p"), ACE_TEXT ("connect")), -1); ACE_HANDLE handle = ACE_OS::open (file_name, O_RDONLY); if (handle == ACE_INVALID_HANDLE) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p"), ACE_TEXT ("open")), -1); // Send handle to server (correctly handles incomplete writes). if (cli_stream.send_handle (handle) == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p"), ACE_TEXT ("send")), -1); char buf[BUFSIZ]; ssize_t n = cli_stream.recv (buf, sizeof buf); if (n == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p"), ACE_TEXT ("recv")), -1); else if (n == 0) //FUZZ: disable check_for_lack_ACE_OS ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("server shutdown (bug in kernel?)\n"))); //FUZZ: enable check_for_lack_ACE_OS else ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("server %*C shutdown\n"), n, buf)); // Explicitly close the connection. if (cli_stream.close () == -1) ACE_ERROR_RETURN ((LM_ERROR, ACE_TEXT ("%p"), ACE_TEXT ("close")), -1); return 0; }