Theodosius v3.0
Jit linker, symbol mapper, and obfuscator
pass.hpp
Go to the documentation of this file.
1// Copyright (c) 2022, _xeroxz
2// All rights reserved.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions are met:
6//
7// 1. Redistributions of source code must retain the above copyright notice,
8// this list of conditions and the following disclaimer.
9//
10// 2. Redistributions in binary form must reproduce the above copyright notice,
11// this list of conditions and the following disclaimer in the documentation
12// and/or other materials provided with the distribution.
13//
14// 3. Neither the name of the copyright holder nor the names of its
15// contributors may be used to endorse or promote products derived from
16// this software without specific prior written permission.
17//
18// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
22// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28// POSSIBILITY OF SUCH DAMAGE.
29//
30
31#pragma once
32#include <spdlog/spdlog.h>
33#include <decomp/symbol.hpp>
34#include <obf/transform/gen.hpp>
35
36#define XED_ENCODER
37extern "C" {
38#include <xed-decode.h>
39#include <xed-interface.h>
40}
41
42/// <summary>
43/// this is the main namespace for obfuscation related things.
44/// </summary>
45namespace theo::obf {
46
47/// <summary>
48/// the pass_t class is a base clase for all passes made. you must override the
49/// pass_t::run virtual function and declare the logic of your pass there.
50///
51/// in the constructor of your pass you must call the super constructor (the
52/// pass_t constructor) and pass it the type of symbol which you are interesting
53/// in receiving.
54/// </summary>
55class pass_t {
56 public:
57 /// <summary>
58 /// the explicit constructor of the pass_t base class.
59 /// </summary>
60 /// <param name="sym_type">the type of symbol in which the pass will run on.
61 /// every symbol passed to the virtual "run" instruction will be of this
62 /// type.</param>
63 explicit pass_t(decomp::sym_type_t sym_type) : m_sym_type(sym_type){};
64
65 /// <summary>
66 /// virtual method which must be implimented by the pass that inherits this
67 /// class.
68 /// </summary>
69 /// <param name="sym">a symbol of the same type of m_sym_type.</param>
70 virtual void run(decomp::symbol_t* sym) = 0;
71
72 /// <summary>
73 /// gets the passes symbol type.
74 /// </summary>
75 /// <returns>the passes symbol type.</returns>
76 decomp::sym_type_t sym_type() { return m_sym_type; }
77
78 private:
79 decomp::sym_type_t m_sym_type;
80};
81} // namespace theo::obf