path_service.h revision ac3d58cff7c80b0ef56bf55130d91da17cbaa3c4
1// Copyright 2015 PDFium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef TESTING_UTILS_PATH_SERVICE_H_
6#define TESTING_UTILS_PATH_SERVICE_H_
7
8#include <string>
9
10#ifdef _WIN32
11#define PATH_SEPARATOR '\\'
12#else
13#define PATH_SEPARATOR '/'
14#endif
15
16// Get the various file directory and path information.
17class PathService {
18 public:
19  // Return true when the path ends with a path separator.
20  static bool EndsWithSeparator(const std::string& path);
21
22  // Retrieve the directory where executables run from.
23  static bool GetExecutableDir(std::string* path);
24
25  // Retrieve the root directory of the source tree.
26  // Assume executables always run from out/<Debug|Release>/, the source
27  // directory is two levels above the executable directory.
28  static bool GetSourceDir(std::string* path);
29
30  // Retrieve the test data directory where test files are stored.
31  // Currently, the test dir is under <source_dir>/testing/resources/.
32  static bool GetTestDataDir(std::string* path);
33
34  // Get the full path for a test file under the test data directory.
35  static bool GetTestFilePath(const std::string& file_name, std::string* path);
36};
37#endif  // TESTING_UTILS_PATH_SERVICE_H_
38