summaryrefslogtreecommitdiff
path: root/ACE/apps/JAWS/clients/Caching/http_client.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/apps/JAWS/clients/Caching/http_client.cpp')
-rw-r--r--ACE/apps/JAWS/clients/Caching/http_client.cpp79
1 files changed, 79 insertions, 0 deletions
diff --git a/ACE/apps/JAWS/clients/Caching/http_client.cpp b/ACE/apps/JAWS/clients/Caching/http_client.cpp
new file mode 100644
index 00000000000..f0bb20b6d56
--- /dev/null
+++ b/ACE/apps/JAWS/clients/Caching/http_client.cpp
@@ -0,0 +1,79 @@
+// $Id$
+
+// ============================================================================
+//
+// = LIBRARY
+// apps/JAWS/clients/Caching
+//
+// = FILENAME
+// http_client.cpp
+//
+// = DESCRIPTION
+// This is a very simple client. It accepts URLs from a prompt, and
+// will try to fetch them. Also accepts shell escapes.
+//
+// = AUTHOR
+// James Hu
+//
+// ============================================================================
+
+#include "ace/OS_NS_stdio.h"
+#include "ace/OS_NS_string.h"
+#include "ace/os_include/os_ctype.h"
+#include "http_handler.h"
+
+ACE_RCSID(Caching, http_client, "$Id$")
+
+int
+ACE_TMAIN (int, ACE_TCHAR *[])
+{
+ // Present a command line.
+ // * Accept a URL.
+ // Pass it to the HTTP_Connector.
+ // Connect.
+ // Report status.
+ // * Accept shell escape character.
+
+ char buf[BUFSIZ];
+
+ ACE_DEBUG ((LM_DEBUG, "* "));
+
+ while (ACE_OS::fgets (buf, sizeof (buf), stdin) != NULL)
+ {
+ char *s = buf;
+
+ // get rid of trailing '\n'
+ int len = ACE_OS::strlen (s);
+
+ if (len > 0 && s[len - 1] == '\n')
+ s[len - 1] = 0;
+
+ while (isspace (*s))
+ s++;
+
+ if (*s == '!')
+ {
+ do
+ s++;
+ while (isspace (*s));
+
+ // Shell command.
+ if (ACE_OS::system (ACE_TEXT_CHAR_TO_TCHAR (s)) == -1)
+ ACE_ERROR ((LM_ERROR, ACE_TEXT (" ! Error executing: %C\n"), s));
+ }
+ else if (ACE_OS::strncmp (s, "http://", 7) == 0)
+ {
+ // URL
+ HTTP_Connector connector;
+ connector.connect (s);
+ }
+ else
+ ACE_ERROR ((LM_ERROR, ACE_TEXT (" ? I don't understand: %C\n"), s));
+
+ ACE_ERROR ((LM_ERROR, ACE_TEXT ("* ")));
+ }
+
+ ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\nBye!\n")));
+
+ return 0;
+}