HPCToolkit
PathReplacementMgr.cpp
Go to the documentation of this file.
1 // -*-Mode: C++;-*-
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL$
6 // $Id$
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 //***************************************************************************
48 //
49 // File:
50 // $HeadURL$
51 //
52 // Purpose:
53 // [The purpose of this file]
54 //
55 // Description:
56 // [The set of functions, macros, etc. defined in the file]
57 //
58 //***************************************************************************
59 
60 //************************* System Include Files ****************************
61 
62 #include <algorithm>
63 #include <string>
64 using std::string;
65 
66 #include <cstring>
67 
68 //*************************** User Include Files ****************************
69 
70 #include "PathReplacementMgr.hpp"
71 
72 //*************************** Forward Declarations **************************
73 
74 //***************************************************************************
75 
76 //***************************************************************************
77 // PathReplacementMgr
78 //***************************************************************************
79 
81 
83 {
84 }
85 
86 
88 {
89 }
90 
91 
94 {
95  return s_singleton;
96 }
97 
98 
99 string
100 PathReplacementMgr::replace(const string& path) const
101 {
102  for (size_t i = 0; i < m_pathReplacement.size(); i++) {
103  const StringPair& x = m_pathReplacement[i];
104  const string& x_old = x.first;
105  const string& x_new = x.second;
106 
107  // Alternative: match substring instead of prefix
108  // size_t pos = path.find(x_old); if (pos != string::npos) {}
109 
110  if (path.compare(0, x_old.size(), x_old) == 0) {
111  string newPath = path;
112  newPath.replace(0, x_old.size(), x_new);
113  return newPath;
114  }
115  }
116  return path;
117 }
118 
119 
120 // Comparison function we use to sort 'pathReplacment' according to the first
121 // values of the pair, which is the old partial path.
122 //
123 // @param a: The first pair object to compare.
124 // @param b: The second pair object to compare.
125 // return: A bool indicatin if a.first.size() < b.first.size().
126 static bool
129 {
130  return a.first.size() > b.first.size();
131 }
132 
133 
134 void
135 PathReplacementMgr::addPath(const string& oldPath, const string& newPath)
136 {
137  m_pathReplacement.push_back(StringPair(oldPath, newPath));
138  std::stable_sort(m_pathReplacement.begin(), m_pathReplacement.end(),
140 }
141 
std::string replace(const std::string &path) const
std::pair< std::string, std::string > StringPair
void addPath(const std::string &oldPath, const std::string &newPath)
static PathReplacementMgr & singleton()
std::vector< StringPair > m_pathReplacement
static bool compare_as_strings(const PathReplacementMgr::StringPair &a, const PathReplacementMgr::StringPair &b)
static PathReplacementMgr s_singleton