summaryrefslogtreecommitdiffstats
path: root/courgette/ensemble.h
diff options
context:
space:
mode:
authordgarrett@chromium.org <dgarrett@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-10-21 22:24:19 +0000
committerdgarrett@chromium.org <dgarrett@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-10-21 22:24:19 +0000
commit93d529cafc6423e431a88612dff69d06d4f0759f (patch)
tree46e73fe8ddd2806e23a1309b92cd9ffca33c9ccb /courgette/ensemble.h
parentad2e64c7fae41d9b8053e040fd282b1cf0f8b610 (diff)
downloadchromium_src-93d529cafc6423e431a88612dff69d06d4f0759f.zip
chromium_src-93d529cafc6423e431a88612dff69d06d4f0759f.tar.gz
chromium_src-93d529cafc6423e431a88612dff69d06d4f0759f.tar.bz2
Start refactoring to reduce executable type knowledge.
This creates executable detection functions, a globally shared enum for describing an executable type, and reduces the number of classes and locations with executable specific knowledge. These changes, along with moving architecture specific classes into their own files should make it easier to produce special purpose clients that only contain the code required to apply their own form of patch. DisassemblerWin32EXE, ImagePE, CourgetteWin32X86PatchGenerator, and CourgetteWin32X86Patcher, and ensemble handling are all heavily affected here. This should have no effect on the behavior of the system yet, and is instead all prep-work. This is the same as an earlier CL, except that ParseHeader will now return an error for 64 bit PE executables, and resource only DLLs. This is because the detection factories depend on ParseHeader to decide if a given file is supported. BUG=None TEST=Unittests Review URL: http://codereview.chromium.org/7920004 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@103879 0039d316-1c4b-4281-b951-d872f2087c98 Review URL: http://codereview.chromium.org/8344037 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@106793 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'courgette/ensemble.h')
-rw-r--r--courgette/ensemble.h24
1 files changed, 13 insertions, 11 deletions
diff --git a/courgette/ensemble.h b/courgette/ensemble.h
index f907f9d..e766782 100644
--- a/courgette/ensemble.h
+++ b/courgette/ensemble.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 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.
@@ -36,11 +36,14 @@ class PEInfo;
//
class Element {
public:
- enum Kind { WIN32_X86_WITH_CODE, WIN32_NOCODE };
+ Element(ExecutableType kind,
+ Ensemble* ensemble,
+ const Region& region,
+ PEInfo*info);
- virtual ~Element() {}
+ virtual ~Element();
- Kind kind() const { return kind_; }
+ ExecutableType kind() const { return kind_; }
const Region& region() const { return region_; }
// The name is used only for debugging and logging.
@@ -50,16 +53,14 @@ class Element {
// containing Ensemble.
size_t offset_in_ensemble() const;
- // Some subclasses of Element might have a PEInfo.
- virtual PEInfo* GetPEInfo() const { return NULL; }
-
- protected:
- Element(Kind kind, Ensemble* ensemble, const Region& region);
+ // The ImageInfo for this executable
+ virtual PEInfo* GetImageInfo() const { return info_; }
private:
- Kind kind_;
+ ExecutableType kind_;
Ensemble* ensemble_;
Region region_;
+ PEInfo *info_;
DISALLOW_COPY_AND_ASSIGN(Element);
};
@@ -139,7 +140,8 @@ struct CourgettePatchFile {
static const uint32 kVersion = 20110216;
- // Transformation method IDs.
+ // Transformation method IDs. These are embedded in generated files, so
+ // never remove or change an existing id.
enum TransformationMethodId {
T_COURGETTE_WIN32_X86 = 1, // Windows 32 bit 'Portable Executable' x86.
};