Upx_Doxygen
https://github.com/upx/upx
p_w32pe.h
1 /* p_w32pe.h --
2 
3  This file is part of the UPX executable compressor.
4 
5  Copyright (C) 1996-2016 Markus Franz Xaver Johannes Oberhumer
6  Copyright (C) 1996-2016 Laszlo Molnar
7  All Rights Reserved.
8 
9  UPX and the UCL library are free software; you can redistribute them
10  and/or modify them under the terms of the GNU General Public License as
11  published by the Free Software Foundation; either version 2 of
12  the License, or (at your option) any later version.
13 
14  This program is distributed in the hope that it will be useful,
15  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  GNU General Public License for more details.
18 
19  You should have received a copy of the GNU General Public License
20  along with this program; see the file COPYING.
21  If not, write to the Free Software Foundation, Inc.,
22  59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
23 
24  Markus F.X.J. Oberhumer Laszlo Molnar
25  <markus@oberhumer.com> <ezerotven+github@gmail.com>
26  */
27 
28 
29 #ifndef __UPX_P_W32PE_H
30 #define __UPX_P_W32PE_H 1
31 
32 
33 /*************************************************************************
34 // w32/pe
35 **************************************************************************/
36 
37 class PackW32Pe : public PeFile32
38 {
39  typedef PeFile32 super;
40 
41 public:
42  PackW32Pe(InputFile *f);
43  virtual ~PackW32Pe();
44  virtual int getFormat() const { return UPX_F_WIN32_PE; }
45  virtual const char *getName() const { return isrtm ? "rtm32/pe" : "win32/pe"; }
46  virtual const char *getFullName(const options_t *) const { return "i386-win32.pe"; }
47  virtual const int *getCompressionMethods(int method, int level) const;
48  virtual const int *getFilters() const;
49 
50  virtual bool handleForceOption();
51  virtual void defineSymbols(unsigned ncsection, unsigned upxsection,
52  unsigned sizeof_oh, unsigned isize_isplit,
53  Reloc &rel, unsigned s1addr);
54  virtual void addNewRelocations(Reloc &, unsigned upxsection);
55  virtual void setOhDataBase(const pe_section_t *osection);
56  virtual void setOhHeaderSize(const pe_section_t *osection);
57  virtual void pack(OutputFile *fo);
58 
59  virtual bool canPack();
60 
61 protected:
62  virtual int readFileHeader();
63 
64  virtual void buildLoader(const Filter *ft);
65  virtual Linker* newLinker() const;
66 };
67 
68 
69 #endif /* already included */
70 
71 /* vim:set ts=4 sw=4 et: */
Definition: pefile.h:417
Definition: pefile.h:303
Definition: linker.h:35
Definition: options.h:45
Definition: file.h:89
Definition: p_w32pe.h:37
Definition: file.h:121
Definition: filter.h:53