mirror of
https://github.com/JakeHillion/drgn.git
synced 2024-12-25 10:23:05 +00:00
type: add Type.is_pointer() and call isinstance() less
This commit is contained in:
parent
15849f5795
commit
2fa4150581
@ -7,7 +7,7 @@ import functools
|
||||
import itertools
|
||||
import math
|
||||
import operator
|
||||
from typing import Any, Callable, Iterable, Optional, Tuple, Union
|
||||
from typing import cast, Any, Callable, Iterable, Optional, Tuple, Union
|
||||
|
||||
from drgn.type import (
|
||||
ArithmeticType,
|
||||
@ -312,10 +312,11 @@ class ProgramObject:
|
||||
return ProgramObject(self.program_, type_, None, op(self.value_()))
|
||||
|
||||
def _binary_operands(self, lhs: Any, rhs: Any) -> Tuple[Any, Type, Any, Type]:
|
||||
if (isinstance(lhs, ProgramObject) and isinstance(rhs, ProgramObject) and
|
||||
lhs.program_ is not rhs.program_):
|
||||
lhs_obj = isinstance(lhs, ProgramObject)
|
||||
rhs_obj = isinstance(rhs, ProgramObject)
|
||||
if lhs_obj and rhs_obj and lhs.program_ is not rhs.program_:
|
||||
raise ValueError('operands are from different programs')
|
||||
if isinstance(lhs, ProgramObject):
|
||||
if lhs_obj:
|
||||
lhs_type = lhs.type_
|
||||
if isinstance(lhs._real_type, ArrayType):
|
||||
lhs = lhs.address_
|
||||
@ -323,7 +324,7 @@ class ProgramObject:
|
||||
lhs = lhs.value_()
|
||||
else:
|
||||
lhs_type = self.program_._type_index.literal_type(lhs)
|
||||
if isinstance(rhs, ProgramObject):
|
||||
if rhs_obj:
|
||||
rhs_type = rhs.type_
|
||||
if isinstance(rhs._real_type, ArrayType):
|
||||
rhs = rhs.address_
|
||||
@ -373,10 +374,9 @@ class ProgramObject:
|
||||
|
||||
def _relational_operator(self, op: Callable, op_name: str,
|
||||
other: Any) -> bool:
|
||||
lhs_pointer = isinstance(self._real_type, (ArrayType, PointerType))
|
||||
rhs_pointer = (isinstance(other, ProgramObject) and
|
||||
isinstance(other._real_type, (ArrayType, PointerType)))
|
||||
lhs, lhs_type, rhs, rhs_type = self._binary_operands(self, other)
|
||||
lhs_pointer = lhs_type.is_pointer()
|
||||
rhs_pointer = rhs_type.is_pointer()
|
||||
if ((lhs_pointer != rhs_pointer) or
|
||||
(not lhs_pointer and
|
||||
(not lhs_type.is_arithmetic() or not rhs_type.is_arithmetic()))):
|
||||
@ -389,11 +389,9 @@ class ProgramObject:
|
||||
return op(lhs, rhs)
|
||||
|
||||
def _add(self, lhs: Any, rhs: Any) -> 'ProgramObject':
|
||||
lhs_pointer = (isinstance(lhs, ProgramObject) and
|
||||
isinstance(lhs._real_type, (ArrayType, PointerType)))
|
||||
rhs_pointer = (isinstance(rhs, ProgramObject) and
|
||||
isinstance(rhs._real_type, (ArrayType, PointerType)))
|
||||
lhs, lhs_type, rhs, rhs_type = self._binary_operands(lhs, rhs)
|
||||
lhs_pointer = lhs_type.is_pointer()
|
||||
rhs_pointer = rhs_type.is_pointer()
|
||||
if ((lhs_pointer and rhs_pointer) or
|
||||
(lhs_pointer and not rhs_type.is_integer()) or
|
||||
(rhs_pointer and not lhs_type.is_integer()) or
|
||||
@ -416,15 +414,13 @@ class ProgramObject:
|
||||
return ProgramObject(self.program_, type_, None, lhs + rhs)
|
||||
|
||||
def _sub(self, lhs: Any, rhs: Any) -> 'ProgramObject':
|
||||
lhs_pointer = (isinstance(lhs, ProgramObject) and
|
||||
isinstance(lhs._real_type, (ArrayType, PointerType)))
|
||||
if lhs_pointer:
|
||||
lhs_sizeof = lhs._real_type.type.sizeof()
|
||||
rhs_pointer = (isinstance(rhs, ProgramObject) and
|
||||
isinstance(rhs._real_type, (ArrayType, PointerType)))
|
||||
if rhs_pointer:
|
||||
rhs_sizeof = rhs._real_type.type.sizeof()
|
||||
lhs, lhs_type, rhs, rhs_type = self._binary_operands(lhs, rhs)
|
||||
lhs_pointer = lhs_type.is_pointer()
|
||||
if lhs_pointer:
|
||||
lhs_sizeof = cast(PointerType, lhs_type).type.sizeof()
|
||||
rhs_pointer = rhs_type.is_pointer()
|
||||
if rhs_pointer:
|
||||
rhs_sizeof = cast(PointerType, rhs_type).type.sizeof()
|
||||
if ((lhs_pointer and rhs_pointer and lhs_sizeof != rhs_sizeof) or
|
||||
(lhs_pointer and not rhs_pointer and not rhs_type.is_integer()) or
|
||||
(rhs_pointer and not lhs_pointer) or
|
||||
|
20
drgn/type.py
20
drgn/type.py
@ -161,6 +161,14 @@ class Type:
|
||||
"""
|
||||
return False
|
||||
|
||||
def is_pointer(self) -> bool:
|
||||
"""
|
||||
Return whether this type is a pointer type or implicitly converts to
|
||||
one (array types, function types, and typedefs with an underlying type
|
||||
of one of these).
|
||||
"""
|
||||
return False
|
||||
|
||||
|
||||
class VoidType(Type):
|
||||
"""
|
||||
@ -876,6 +884,9 @@ class TypedefType(Type):
|
||||
def is_integer(self) -> bool:
|
||||
return self.type.is_integer()
|
||||
|
||||
def is_pointer(self) -> bool:
|
||||
return self.type.is_pointer()
|
||||
|
||||
|
||||
class PointerType(Type):
|
||||
"""
|
||||
@ -938,6 +949,9 @@ class PointerType(Type):
|
||||
return PointerType(self.size, self.type)
|
||||
return self
|
||||
|
||||
def is_pointer(self) -> bool:
|
||||
return True
|
||||
|
||||
|
||||
class ArrayType(Type):
|
||||
"""
|
||||
@ -1020,6 +1034,9 @@ class ArrayType(Type):
|
||||
def operand_type(self) -> 'PointerType':
|
||||
return PointerType(self.pointer_size, self.type)
|
||||
|
||||
def is_pointer(self) -> bool:
|
||||
return True
|
||||
|
||||
|
||||
class FunctionType(Type):
|
||||
"""
|
||||
@ -1078,3 +1095,6 @@ class FunctionType(Type):
|
||||
|
||||
def operand_type(self) -> 'PointerType':
|
||||
return PointerType(self.pointer_size, self)
|
||||
|
||||
def is_pointer(self) -> bool:
|
||||
return True
|
||||
|
Loading…
Reference in New Issue
Block a user