/* Chrysalide - Outil d'analyse de fichiers binaires
* ##FILE## - traduction d'instructions Dalvik
*
* Copyright (C) 2018 Cyrille Bagard
*
* This file is part of Chrysalide.
*
* Chrysalide is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* Chrysalide is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Chrysalide. If not, see .
*/
@title invoke-direct
@id 112
@desc {
Call the indicated method. The result (if any) may be stored with an appropriate move-result* variant as the immediately subsequent instruction.
invoke-virtual is used to invoke a normal virtual method (a method that is not private, static, or final, and is also not a constructor).
When the method_id references a method of a non-interface class, invoke-super is used to invoke the closest superclass's virtual method (as opposed to the one with the same method_id in the calling class). The same method restrictions hold as for invoke-virtual.
In Dex files version 037 or later, if the method_id refers to an interface method, invoke-super is used to invoke the most specific, non-overridden version of that method defined on that interface. The same method restrictions hold as for invoke-virtual. In Dex files prior to version 037, having an interface method_id is illegal and undefined.
invoke-direct is used to invoke a non-static direct method (that is, an instance method that is by its nature non-overridable, namely either a private instance method or a constructor).
invoke-static is used to invoke a static method (which is always considered a direct method).
invoke-interface is used to invoke an interface method, that is, on an object whose concrete class isn't known, using a method_id that refers to an interface.
Note: These opbs are reasonable candidates for static linking, altering the method argument to be a more direct offset (or pair thereof).
}
@encoding() {
@format 35c | pool_meth
@syntax {
@rules {
call g_arch_instruction_set_flag(AIF_CALL)
}
}
@hooks {
link = handle_links_between_caller_and_callee
}
}