ghidra/Ghidra/Features/Decompiler/src/decompile/cpp/printjava.hh
2019-03-26 13:46:51 -04:00

71 lines
3.3 KiB
C++

/* ###
* IP: GHIDRA
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/// \file printjava.hh
/// \brief Classes supporting the java-language back-end to the decompiler
#ifndef __PRINTJAVA__
#define __PRINTJAVA__
#include "printc.hh"
/// \brief Factory and static initializer for the "java-language" back-end to the decompiler
///
/// The singleton adds itself to the list of possible back-end languages for the decompiler
/// and it acts as a factory for producing the PrintJava object for emitting java-language tokens.
class PrintJavaCapability : public PrintLanguageCapability {
static PrintJavaCapability printJavaCapability; ///< The singleton instance
PrintJavaCapability(void); ///< Singleton constructor
PrintJavaCapability(const PrintJavaCapability &op2); ///< Not implemented
PrintJavaCapability &operator=(const PrintJavaCapability &op); ///< Not implemented
public:
virtual PrintLanguage *buildLanguage(Architecture *glb);
};
/// \brief The java-language token emitter
///
/// This builds heavily on the c-language PrintC emitter. Most operator tokens, the format of
/// function prototypes, and code structuring are shared. Specifics of the java constant pool are handled
/// through the overloaded opCpoolRefOp().
///
/// Java data-types are mapped into the decompiler's data-type system in a specific way. The primitives
/// \b int, \b long, \b short, \b byte, \b boolean, \b float, and \b double all map directly. The
/// \b char primitive is treated as a 2 byte unsigned integer. A TypeStruct object holds the field
/// layout for a java class, then java objects get mapped as follows:
/// - Class reference = pointer to TYPE_UINT
/// - Array of \b int, \b long, \b short, or \b byte = pointer to TYPE_INT
/// - Array of \b float or \b double = pointer to TYPE_FLOAT
/// - Array of \b boolean = pointer to TYPE_BOOL
/// - Array of class objects = pointer to TYPE_PTR
///
/// There are some adjustments to the printing of data-types and LOAD/STORE expressions
/// to account for this mapping.
class PrintJava : public PrintC {
static OpToken instanceof; ///< The \b instanceof keyword
static bool isArrayType(const Datatype *ct); ///< Does the given data-type reference a java array
static bool needZeroArray(const Varnode *vn); ///< Do we need '[0]' syntax.
virtual void printUnicode(ostream &s,int4 onechar) const;
public:
PrintJava(Architecture *g,const string &nm="java-language"); ///< Constructor
virtual void pushTypeStart(const Datatype *ct,bool noident);
virtual void pushTypeEnd(const Datatype *ct);
virtual bool doEmitWideCharPrefix(void) const { return false; }
virtual void adjustTypeOperators(void);
virtual void opLoad(const PcodeOp *op);
virtual void opStore(const PcodeOp *op);
virtual void opCallind(const PcodeOp *op);
virtual void opCpoolRefOp(const PcodeOp *op);
};
#endif