forked from RobotLocomotion/drake
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfind_resource.h
127 lines (106 loc) · 5.51 KB
/
find_resource.h
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
#pragma once
#include <string>
#include <vector>
#include "drake/common/drake_assert.h"
#include "drake/common/drake_copyable.h"
#include "drake/common/drake_optional.h"
namespace drake {
/// Models the outcome of drake::FindResource. After a call to FindResource,
/// typical calling code would use get_absolute_path_or_throw().
/// Alternatively, get_absolute_path() will return an `optional<string>`, which
/// can be manually checked to contain a value before using the path. If the
/// resource was not found, get_error_message() will contain an error message.
///
/// For a given FindResourceResult instance, exactly one of get_absolute_path()
/// or get_error_message() will contain a value. (Similarly, exactly one of
/// them will not contain a value.)
class FindResourceResult {
public:
DRAKE_DEFAULT_COPY_AND_MOVE_AND_ASSIGN(FindResourceResult);
/// Returns the absolute path to the resource, iff the resource was found.
optional<std::string> get_absolute_path() const;
/// Either returns the get_absolute_path() iff the resource was found,
/// or else throws std::runtime_error.
std::string get_absolute_path_or_throw() const;
/// Returns the error message, iff the resource was not found.
/// The string will never be empty; only the optional can be empty.
optional<std::string> get_error_message() const;
/// Returns the resource_path asked of FindResource.
/// (This may be empty only in the make_empty() case.)
std::string get_resource_path() const;
/// Returns a success result (the requested resource was found).
/// @pre neither string parameter is empty
/// @param resource_path the value passed to FindResource
/// @param base_path an absolute base path that precedes resource_path
static FindResourceResult make_success(
std::string resource_path, std::string absolute_path);
/// Returns an error result (the requested resource was NOT found).
/// @pre neither string parameter is empty
/// @param resource_path the value passed to FindResource
static FindResourceResult make_error(
std::string resource_path, std::string error_message);
/// Returns an empty error result (no requested resource).
static FindResourceResult make_empty();
private:
FindResourceResult() = default;
void CheckInvariants();
// The path as requested by the user.
std::string resource_path_;
// The absolute path where resource_path was found, if success.
optional<std::string> absolute_path_;
// An error message, permitted to be present only when base_path is empty.
//
// All three of resource_path, base_path, and error_message can be empty
// (e.g., a default-constructed and/or moved-from object), which represents
// resource-not-found along with an unspecified non-empty default error
// message from get_error_message().
optional<std::string> error_message_;
};
/// Adds a path in which resources are searched in a persistent variable. Paths
/// are accumulated each time this function is called. It is searched after the
/// path given by the environment variable but before the path that can be
/// found with the sentinel `.drake-resource-sentinel`. This can be used to
/// find data in installed distributions of drake (or in `pydrake`).
/// @throws std::runtime_error if the given path is not absolute.
void AddResourceSearchPath(std::string root_directory);
/// Gets current root directory value from a persistent variable.
std::vector<std::string> GetResourceSearchPaths();
/// Attempts to locate a Drake resource named by the given @p resource_path.
/// The @p resource_path refers to the relative path within the Drake source
/// repository, prepended with `drake/`. For example, to find the source
/// file `examples/pendulum/Pendulum.urdf`, the @p resource_path would be
/// `drake/examples/pendulum/Pendulum.urdf`. Paths that do not start with
/// `drake/` will return a failed result.
///
/// The search scans for the resource in the following places and in
/// the following order:
///
/// 1. In the DRAKE_RESOURCE_ROOT environment variable
/// 2. In the directories specified by `AddResourceSearchPath()` and
/// 3. In the drake source workspace.
///
/// If all of these are unavailable, or do not have the resource, then it will
/// return a failed result.
FindResourceResult FindResource(std::string resource_path);
/// Convenient wrapper for querying FindResource(resource_path) followed by
/// FindResourceResult::get_absolute_path_or_throw().
std::string FindResourceOrThrow(std::string resource_path);
/// The name of the environment variable that provides the first place where
/// FindResource attempts to look. The environment variable is allowed to be
/// unset or empty; in that case, FindResource will attempt to use other
/// locations without complaint.
///
/// The value is guaranteed to be "DRAKE_RESOURCE_ROOT". (For some users, it
/// may be easier to hard-code a value than refer to this constant.)
///
/// When the environment variable is set, resources are sought in relation to
/// it by appending the FindResource() `resource_path` to the environment
/// variable (with an intermediate `/` as appropriate). For example, if the
/// `resource_path` is `drake/examples/pendulum/Pendulum.urdf` and the
/// `DRAKE_RESOURCE_ROOT` is set to `/home/someuser/foo` then the resource will
/// be sought at `/home/someuser/foo/drake/examples/pendulum/Pendulum.urdf`.
///
/// The intended use of this variable is to seek resources from an installed
/// copy of Drake, in case other methods have failed.
extern const char* const kDrakeResourceRootEnvironmentVariableName;
} // namespace drake