// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // This file/namespace contains utility functions for gathering // information about PE (Portable Executable) headers within // images (dll's / exe's ) #ifndef BASE_IMAGE_UTIL_H__ #define BASE_IMAGE_UTIL_H__ #include <vector> #include "base/basictypes.h" #include <windows.h> namespace image_util { // Contains both the PE section name (.text, .reloc etc) and its size. struct ImageSectionData { std::string name; size_t size_in_bytes; ImageSectionData (const std::string& section_name, size_t section_size) : name (section_name), size_in_bytes(section_size) { } }; typedef std::vector<ImageSectionData> ImageSectionsData; // Provides image statistics for modules of a specified process, or for the // specified process' own executable file. To use, invoke CreateImageMetrics() // to get an instance for a specified process, then access the information via // methods. class ImageMetrics { public: // Creates an ImageMetrics instance for given process owned by // the caller. explicit ImageMetrics(HANDLE process); ~ImageMetrics(); // Fills a vector of ImageSectionsData containing name/size info // for every section found in the specified dll's PE section table. // The DLL must be loaded by the process associated with this ImageMetrics // instance. bool GetDllImageSectionData(const std::string& loaded_dll_name, ImageSectionsData* section_sizes); // Fills a vector if ImageSectionsData containing name/size info // for every section found in the executable file of the process // associated with this ImageMetrics instance. bool GetProcessImageSectionData(ImageSectionsData* section_sizes); private: // Helper for GetDllImageSectionData and GetProcessImageSectionData bool GetImageSectionSizes(char* qualified_path, ImageSectionsData* result); HANDLE process_; DISALLOW_EVIL_CONSTRUCTORS(ImageMetrics); }; } // namespace image_util #endif