// 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 <windows.h>
#include <vector>

#include "base/basictypes.h"

namespace image_util {

// Contains both the PE section name (.text, .reloc etc) and its size.
struct ImageSectionData {
  ImageSectionData(const std::string& section_name, size_t section_size)
      : name(section_name),
        size_in_bytes(section_size) {
  }

  std::string name;
  size_t size_in_bytes;
};

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_COPY_AND_ASSIGN(ImageMetrics);
};

}  // namespace image_util

#endif  // BASE_IMAGE_UTIL_H_