LIEF: Library to Instrument Executable Formats Version 0.17.0
Loading...
Searching...
No Matches
x86/Instruction.hpp
Go to the documentation of this file.
1/* Copyright 2022 - 2025 R. Thomas
2 *
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15#ifndef LIEF_ASM_X86_INST_H
16#define LIEF_ASM_X86_INST_H
17#include "LIEF/visibility.h"
18
22
23namespace LIEF {
24namespace assembly {
25namespace x86 {
28class LIEF_API Instruction : public assembly::Instruction {
31 public:
32 using assembly::Instruction::Instruction;
33
34 using operands_it = iterator_range<Operand::Iterator>;
35 OPCODE opcode() const;
38 operands_it operands() const;
41 static bool classof(const assembly::Instruction* inst);
44
45 ~Instruction() override = default;
46};
47}
48}
49}
50#endif
This class represents a x86/x86-64 instruction.
Definition x86/Instruction.hpp:30
static bool classof(const assembly::Instruction *inst)
True if inst is an effective instance of x86::Instruction.
operands_it operands() const
Iterator over the operands of the current instruction.
~Instruction() override=default
OPCODE opcode() const
The instruction opcode as defined in LLVM.
x86/x86-64 architecture-related namespace
Definition x86/Instruction.hpp:27
Namespace related to assembly/disassembly support.
Definition Abstract/Binary.hpp:43
LIEF namespace.
Definition Abstract/Binary.hpp:36
#define LIEF_API
Definition visibility.h:41