blob: 57db93abc25a165b3f65be8d1abf1d3222fe55cb (
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
|
// file : mod/mod-repository-root -*- C++ -*-
// copyright : Copyright (c) 2014-2017 Code Synthesis Ltd
// license : MIT; see accompanying LICENSE file
#ifndef MOD_MOD_REPOSITORY_ROOT
#define MOD_MOD_REPOSITORY_ROOT
#include <brep/types>
#include <brep/utility>
#include <mod/module>
#include <mod/options>
namespace brep
{
class package_search;
class package_details;
class package_version_details;
class repository_details;
class repository_root: public module
{
public:
repository_root ();
// Copy constructible-only type.
//
// Create a shallow copy (handling instance) if initialized and a deep
// copy (context exemplar) otherwise.
//
explicit
repository_root (const repository_root&);
private:
virtual bool
handle (request&, response&);
virtual const cli::options&
cli_options () const {return options::repository_root::description ();}
virtual option_descriptions
options ();
virtual void
init (const name_values&);
virtual void
init (cli::scanner&);
virtual void
version ();
private:
shared_ptr<package_search> package_search_;
shared_ptr<package_details> package_details_;
shared_ptr<package_version_details> package_version_details_;
shared_ptr<repository_details> repository_details_;
shared_ptr<options::repository_root> options_;
// Sub-module the request is dispatched to. Initially is NULL. It is set
// by the first call to handle() to a deep copy of the selected exemplar.
// The subsequent calls of handle() (that may take place after the retry
// exception is thrown) will use the existing handler instance.
//
unique_ptr<module> handler_;
};
}
#endif // MOD_MOD_REPOSITORY_ROOT
|