• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /**
2  * @file locate_images.h
3  * Location of binary images
4  *
5  * @remark Copyright 2002 OProfile authors
6  * @remark Read the file COPYING
7  *
8  * @author Philippe Elie
9  * @author John Levon
10  */
11 
12 #ifndef LOCATE_IMAGES_H
13 #define LOCATE_IMAGES_H
14 
15 #include <string>
16 #include <map>
17 #include <vector>
18 
19 #include "image_errors.h"
20 
21 /**
22  * A class containing mappings from an image basename,
23  * such as 'floppy.ko', to locations in the paths passed
24  * in to populate().
25  *
26  * The name may exist multiple times; all locations are recorded
27  * in this container.
28  */
29 class extra_images {
30 public:
31 	extra_images();
32 
33 	/// add all filenames found in the given paths prefixed by the
34 	/// archive path or the root path, recursively
35 	void populate(std::vector<std::string> const & paths,
36 		      std::string const & archive_path,
37 		      std::string const & root_path);
38 
39 	/// base class for matcher functors object
40 	struct matcher {
41 		std::string const & value;
42 	public:
matchermatcher43 		explicit matcher(std::string const & v) : value(v) {}
~matchermatcher44 		virtual ~matcher() {}
45 		/// default functor allowing trivial match
operatormatcher46 		virtual bool operator()(std::string const & str) const {
47 			return str == value;
48 		}
49 	};
50 
51 	/**
52 	 * return a vector of all directories that match the functor
53 	 */
54 	std::vector<std::string> const find(matcher const & match) const;
55 
56 	/// return a vector of all directories that match the given name
57 	std::vector<std::string> const find(std::string const & name) const;
58 
59 	/**
60 	 * @param image_name binary image name
61 	 * @param error errors are flagged in this passed enum ref
62 	 * @param fixup if true return the fixed image name else always return
63 	 *  image_name and update error
64 	 *
65 	 * Locate a (number of) matching absolute paths to the given image
66 	 * name. If we fail to find the file we fill in error and return the
67 	 * original string.
68 	 */
69 	std::string const find_image_path(std::string const & image_name,
70 				image_error & error, bool fixup) const;
71 
72 	/// return the archive path used to populate the images name map
get_archive_path()73 	std::string get_archive_path() const { return archive_path; }
74 
75 	/// Given an image name returned by find_image_path() return
76 	/// a filename with the archive_path or root_path stripped.
77 	std::string strip_path_prefix(std::string const & image) const;
78 
79 	/// return the uid for this extra_images, first valid uid is 1
get_uid()80 	int get_uid() const { return uid; }
81 
82 private:
83 	void populate(std::vector<std::string> const & paths,
84 		      std::string const & prefix_path);
85 
86 	std::string const locate_image(std::string const & image_name,
87 				image_error & error, bool fixup) const;
88 
89 	typedef std::multimap<std::string, std::string> images_t;
90 	typedef images_t::value_type value_type;
91 	typedef images_t::const_iterator const_iterator;
92 
93 	/// map from image basename to owning directory
94 	images_t images;
95 	/// the archive path passed to populate the images name map.
96 	std::string archive_path;
97 	/// A prefix added to locate binaries if they can't be found
98 	/// through the archive path
99 	std::string root_path;
100 
101 	/// unique identifier, first valid uid is 1
102 	int uid;
103 	/// unique uid generator
104 	static int suid;
105 };
106 
107 #endif /* LOCATE_IMAGES_H */
108