You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@apr.apache.org by gr...@apache.org on 2001/06/07 23:31:31 UTC

cvs commit: apr-site/apr2_0intro/Client Client.cpp Client.dsp Client.plg ReadMe.txt StdAfx.cpp StdAfx.h

gregames    01/06/07 14:31:31

  Added:       apr2_0intro/Client Client.cpp Client.dsp Client.plg
                        ReadMe.txt StdAfx.cpp StdAfx.h
  Log:
  add files for sample APR client
  
  Submitted by:	Christian Gross
  Reviewed by:	Greg Ames
  
  Revision  Changes    Path
  1.1                  apr-site/apr2_0intro/Client/Client.cpp
  
  Index: Client.cpp
  ===================================================================
  /* ====================================================================
   * The Apache Software License, Version 1.1
   *
   * Copyright (c) 2000-2001 The Apache Software Foundation.  All rights
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   *
   * 2. Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in
   *    the documentation and/or other materials provided with the
   *    distribution.
   *
   * 3. The end-user documentation included with the redistribution,
   *    if any, must include the following acknowledgment:
   *       "This product includes software developed by the
   *        Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowledgment may appear in the software itself,
   *    if and wherever such third-party acknowledgments normally appear.
   *
   * 4. The names "Apache" and "Apache Software Foundation" must
   *    not be used to endorse or promote products derived from this
   *    software without prior written permission. For written
   *    permission, please contact apache@apache.org.
   *
   * 5. Products derived from this software may not be called "Apache",
   *    nor may "Apache" appear in their name, without prior written
   *    permission of the Apache Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
   * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
   * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
   * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
   * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
   * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
   * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
   * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
   * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
   * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   * SUCH DAMAGE.
   * ====================================================================
   *
   * This software consists of voluntary contributions made by many
   * individuals on behalf of the Apache Software Foundation.  For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  
  #include <stdlib.h>
  #include "apr_network_io.h"
  #include "apr_errno.h"
  #include "apr_general.h"
  #include <errno.h>
  
  #define STRLEN 15
  
  static void closeapr(void)
  {
      apr_terminate();
  }
  
  int main(int argc, char *argv[])
  {
      apr_pool_t *context;
      apr_socket_t *sock;
      apr_size_t length;
      apr_status_t stat;
      char datasend[STRLEN] = "Send data test";
      char datarecv[STRLEN];
      char msgbuf[80];
      char *local_ipaddr, *remote_ipaddr;
      char *dest = "127.0.0.1";
      apr_port_t local_port, remote_port;
      apr_interval_time_t read_timeout = 2 * APR_USEC_PER_SEC;
      apr_sockaddr_t *local_sa, *remote_sa;
  
      setbuf(stdout, NULL);
      if (argc > 1) {
          dest = argv[1];
      }
  
      if (argc > 2) {
          read_timeout = APR_USEC_PER_SEC * atoi(argv[2]);
      }
  
      fprintf(stdout, "Initializing.........");
      if (apr_initialize() != APR_SUCCESS) {
          fprintf(stderr, "Something went wrong\n");
          exit(-1);
      }
      fprintf(stdout, "OK\n");
      atexit(closeapr);
  
      fprintf(stdout, "Creating context.......");
      if (apr_pool_create(&context, NULL) != APR_SUCCESS) {
          fprintf(stderr, "Something went wrong\n");
          exit(-1);
      }
      fprintf(stdout, "OK\n");
  
      fprintf(stdout,"\tClient:  Making socket address...............");
      if ((stat = apr_sockaddr_info_get(&remote_sa, dest, APR_UNSPEC, 8021, 0, context)) 
          != APR_SUCCESS) {
          fprintf(stdout, "Failed!\n");
          fprintf(stdout, "Address resolution failed for %s: %s\n", 
                  dest, apr_strerror(stat, msgbuf, sizeof(msgbuf)));
          exit(-1);
      }
      fprintf(stdout,"OK\n");
  
      fprintf(stdout, "\tClient:  Creating new socket.......");
      if (apr_socket_create(&sock, remote_sa->sa.sin.sin_family, SOCK_STREAM,
                            context) != APR_SUCCESS) {
          fprintf(stderr, "Couldn't create socket\n");
          exit(-1);
      }
      fprintf(stdout, "OK\n");
  
      fprintf(stdout, "\tClient:  Connecting to socket.......");
  
      stat = apr_connect(sock, remote_sa);
  
      if (stat != APR_SUCCESS) {
          apr_socket_close(sock);
          fprintf(stderr, "Could not connect: %s (%d)\n", 
  		apr_strerror(stat, msgbuf, sizeof(msgbuf)), stat);
          fflush(stderr);
          exit(-1);
      }
      fprintf(stdout, "OK\n");
  
      apr_socket_addr_get(&remote_sa, APR_REMOTE, sock);
      apr_sockaddr_ip_get(&remote_ipaddr, remote_sa);
      apr_sockaddr_port_get(&remote_port, remote_sa);
      apr_socket_addr_get(&local_sa, APR_LOCAL, sock);
      apr_sockaddr_ip_get(&local_ipaddr, local_sa);
      apr_sockaddr_port_get(&local_port, local_sa);
      fprintf(stdout, "\tClient socket: %s:%u -> %s:%u\n", local_ipaddr, local_port, remote_ipaddr, remote_port);
  
      fprintf(stdout, "\tClient:  Trying to send data over socket.......");
      length = STRLEN;
      if (apr_send(sock, datasend, &length) != APR_SUCCESS) {
          apr_socket_close(sock);
          fprintf(stderr, "Problem sending data\n");
          exit(-1);
      }
      fprintf(stdout, "OK\n");
     
      fprintf(stdout, "\tClient:  Setting read timeout.......");
      stat = apr_setsocketopt(sock, APR_SO_TIMEOUT, read_timeout);
      if (stat) {
          fprintf(stderr, "Problem setting timeout: %d\n", stat);
          exit(-1);
      }
      fprintf(stdout, "OK\n");
  
      length = STRLEN; 
      fprintf(stdout, "\tClient:  Trying to receive data over socket.......");
  
      if ((stat = apr_recv(sock, datarecv, &length)) != APR_SUCCESS) {
          apr_socket_close(sock);
          fprintf(stderr, "Problem receiving data: %s (%d)\n", 
  		apr_strerror(stat, msgbuf, sizeof(msgbuf)), stat);
          exit(-1);
      }
      if (strcmp(datarecv, "Recv data test")) {
          apr_socket_close(sock);
          fprintf(stderr, "I did not receive the correct data %s\n", datarecv);
          exit(-1);
      }
      fprintf(stdout, "OK\n");
  
      fprintf(stdout, "\tClient:  Shutting down socket.......");
      if (apr_shutdown(sock, APR_SHUTDOWN_WRITE) != APR_SUCCESS) {
          apr_socket_close(sock);
          fprintf(stderr, "Could not shutdown socket\n");
          exit(-1);
      }
      fprintf(stdout, "OK\n");
  
      fprintf(stdout, "\tClient:  Closing down socket.......");
      if (apr_socket_close(sock) != APR_SUCCESS) {
          fprintf(stderr, "Could not shutdown socket\n");
          exit(-1);
      }
      fprintf(stdout, "OK\n");
  
      return 1;
  }
  
  
  
  1.1                  apr-site/apr2_0intro/Client/Client.dsp
  
  Index: Client.dsp
  ===================================================================
  # Microsoft Developer Studio Project File - Name="Client" - Package Owner=<4>
  # Microsoft Developer Studio Generated Build File, Format Version 6.00
  # ** DO NOT EDIT **
  
  # TARGTYPE "Win32 (x86) Console Application" 0x0103
  
  CFG=Client - Win32 Debug
  !MESSAGE This is not a valid makefile. To build this project using NMAKE,
  !MESSAGE use the Export Makefile command and run
  !MESSAGE 
  !MESSAGE NMAKE /f "Client.mak".
  !MESSAGE 
  !MESSAGE You can specify a configuration when running NMAKE
  !MESSAGE by defining the macro CFG on the command line. For example:
  !MESSAGE 
  !MESSAGE NMAKE /f "Client.mak" CFG="Client - Win32 Debug"
  !MESSAGE 
  !MESSAGE Possible choices for configuration are:
  !MESSAGE 
  !MESSAGE "Client - Win32 Release" (based on "Win32 (x86) Console Application")
  !MESSAGE "Client - Win32 Debug" (based on "Win32 (x86) Console Application")
  !MESSAGE 
  
  # Begin Project
  # PROP AllowPerConfigDependencies 0
  # PROP Scc_ProjName ""
  # PROP Scc_LocalPath ""
  CPP=cl.exe
  RSC=rc.exe
  
  !IF  "$(CFG)" == "Client - Win32 Release"
  
  # PROP BASE Use_MFC 0
  # PROP BASE Use_Debug_Libraries 0
  # PROP BASE Output_Dir "Release"
  # PROP BASE Intermediate_Dir "Release"
  # PROP BASE Target_Dir ""
  # PROP Use_MFC 0
  # PROP Use_Debug_Libraries 0
  # PROP Output_Dir "Release"
  # PROP Intermediate_Dir "Release"
  # PROP Target_Dir ""
  # ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /Yu"stdafx.h" /FD /c
  # ADD CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /Yu"stdafx.h" /FD /c
  # ADD BASE RSC /l 0x1009 /d "NDEBUG"
  # ADD RSC /l 0x1009 /d "NDEBUG"
  BSC32=bscmake.exe
  # ADD BASE BSC32 /nologo
  # ADD BSC32 /nologo
  LINK32=link.exe
  # ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib  kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /machine:I386
  # ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib  kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /machine:I386
  
  !ELSEIF  "$(CFG)" == "Client - Win32 Debug"
  
  # PROP BASE Use_MFC 0
  # PROP BASE Use_Debug_Libraries 1
  # PROP BASE Output_Dir "Debug"
  # PROP BASE Intermediate_Dir "Debug"
  # PROP BASE Target_Dir ""
  # PROP Use_MFC 0
  # PROP Use_Debug_Libraries 1
  # PROP Output_Dir "Debug"
  # PROP Intermediate_Dir "Debug"
  # PROP Target_Dir ""
  # ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /Yu"stdafx.h" /FD /GZ  /c
  # ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /YX /FD /GZ  /c
  # ADD BASE RSC /l 0x1009 /d "_DEBUG"
  # ADD RSC /l 0x1009 /d "_DEBUG"
  BSC32=bscmake.exe
  # ADD BASE BSC32 /nologo
  # ADD BSC32 /nologo
  LINK32=link.exe
  # ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib  kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /debug /machine:I386 /pdbtype:sept
  # ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib  kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /debug /machine:I386 /pdbtype:sept
  
  !ENDIF 
  
  # Begin Target
  
  # Name "Client - Win32 Release"
  # Name "Client - Win32 Debug"
  # Begin Group "Source Files"
  
  # PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
  # Begin Source File
  
  SOURCE=.\Client.cpp
  # End Source File
  # Begin Source File
  
  SOURCE=.\StdAfx.cpp
  # ADD CPP /Yc"stdafx.h"
  # End Source File
  # End Group
  # Begin Group "Header Files"
  
  # PROP Default_Filter "h;hpp;hxx;hm;inl"
  # Begin Source File
  
  SOURCE=.\StdAfx.h
  # End Source File
  # End Group
  # Begin Group "Resource Files"
  
  # PROP Default_Filter "ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe"
  # End Group
  # Begin Group "Library Files"
  
  # PROP Default_Filter ""
  # Begin Source File
  
  SOURCE=..\..\..\bin\libapr.lib
  # End Source File
  # End Group
  # End Target
  # End Project
  
  
  
  1.1                  apr-site/apr2_0intro/Client/Client.plg
  
  Index: Client.plg
  ===================================================================
  <html>
  <body>
  <pre>
  <h1>Build Log</h1>
  <h3>
  --------------------Configuration: Client - Win32 Debug--------------------
  </h3>
  <h3>Command Lines</h3>
  
  
  
  <h3>Results</h3>
  Client.exe - 0 error(s), 0 warning(s)
  </pre>
  </body>
  </html>
  
  
  
  1.1                  apr-site/apr2_0intro/Client/ReadMe.txt
  
  Index: ReadMe.txt
  ===================================================================
  ========================================================================
         CONSOLE APPLICATION : Client
  ========================================================================
  
  
  AppWizard has created this Client application for you.  
  
  This file contains a summary of what you will find in each of the files that
  make up your Client application.
  
  Client.dsp
      This file (the project file) contains information at the project level and
      is used to build a single project or subproject. Other users can share the
      project (.dsp) file, but they should export the makefiles locally.
  
  Client.cpp
      This is the main application source file.
  
  
  /////////////////////////////////////////////////////////////////////////////
  Other standard files:
  
  StdAfx.h, StdAfx.cpp
      These files are used to build a precompiled header (PCH) file
      named Client.pch and a precompiled types file named StdAfx.obj.
  
  
  /////////////////////////////////////////////////////////////////////////////
  Other notes:
  
  AppWizard uses "TODO:" to indicate parts of the source code you
  should add to or customize.
  
  /////////////////////////////////////////////////////////////////////////////
  
  
  
  1.1                  apr-site/apr2_0intro/Client/StdAfx.cpp
  
  Index: StdAfx.cpp
  ===================================================================
  // stdafx.cpp : source file that includes just the standard includes
  //	Client.pch will be the pre-compiled header
  //	stdafx.obj will contain the pre-compiled type information
  
  #include "stdafx.h"
  
  // TODO: reference any additional headers you need in STDAFX.H
  // and not in this file
  
  
  
  1.1                  apr-site/apr2_0intro/Client/StdAfx.h
  
  Index: StdAfx.h
  ===================================================================
  // stdafx.h : include file for standard system include files,
  //  or project specific include files that are used frequently, but
  //      are changed infrequently
  //
  
  #if !defined(AFX_STDAFX_H__867F0EC7_A764_4EC5_8106_1B81EDB75D20__INCLUDED_)
  #define AFX_STDAFX_H__867F0EC7_A764_4EC5_8106_1B81EDB75D20__INCLUDED_
  
  #if _MSC_VER > 1000
  #pragma once
  #endif // _MSC_VER > 1000
  
  #define WIN32_LEAN_AND_MEAN		// Exclude rarely-used stuff from Windows headers
  
  #include <stdio.h>
  
  // TODO: reference additional headers your program requires here
  
  //{{AFX_INSERT_LOCATION}}
  // Microsoft Visual C++ will insert additional declarations immediately before the previous line.
  
  #endif // !defined(AFX_STDAFX_H__867F0EC7_A764_4EC5_8106_1B81EDB75D20__INCLUDED_)