summaryrefslogtreecommitdiff
path: root/examples/Web_Crawler/URL.h
blob: 68c41f018ad9b348bd22f1bc843a3b255e4c4b17 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/* -*- C++ -*- */
// $Id$

// ============================================================================
//
// = LIBRARY
//    examples/Web_Crawler
//
// = FILENAME
//    URL.h
//
// = AUTHOR
//    Douglas C. Schmidt <schmidt@cs.wustl.edu>
//
// ============================================================================

#ifndef _URL_H
#define _URL_H

#include "Mem_Map_Stream.h"

#if !defined (ACE_LACKS_PRAGMA_ONCE)
#pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */

#include "URL_Addr.h"
#include "URL_Status.h"

#include "ace/SString.h"


// Forward declaration.
class URL_Visitor;

class URL
{
  // = TITLE
  //    Base class for a URL.
  //
  // = DESCRIPTION
  //    This class plays a role in the Visitor pattern.
public:
  virtual ~URL (void);
  // Destructor.

  virtual int accept (URL_Visitor *visitor) = 0;
  // Accept the visitor, which will then perform a particular
  // visitation strategy on the URL.  This method is part of the
  // Visitor pattern.

  virtual ssize_t send_request (void) = 0;
  // Send a <GET> command to fetch the contents in the URI from the
  // server.

  virtual const ACE_URL_Addr &url_addr (void) const = 0;
  // Returns the URL that we represent.

  virtual Mem_Map_Stream &stream (void);
  // Returns the <Mem_Map_Stream>.

  // = Get/set the reply status.
  virtual const URL_Status &reply_status (void);
  virtual void reply_status (const URL_Status &);

  // = Get/set the reply status.
  virtual const ACE_CString &content_type (void);
  virtual void content_type (const ACE_CString &);



private:
  URL_Status reply_status_;
  // Reply status of the URL.

  ACE_CString content_type_;
  // Content-type of the URL.

  Mem_Map_Stream stream_;
  // Contents of the stream.
};

#endif /* _URL_H */