Arquivos
hhvm/hphp/compiler/expression/simple_function_call.h
T
Jordan DeLong fa6f3f7e12 Implement most of class_alias
Throws the aliased class into a target cache slot for the new
name.  Handles errors when you try to re-alias a class, but doesn't
restrict a few other cases zend does:

  - If you implement an interface twice, zend complains (one of the
    alias tests checks this).  I tried turning it on, but we violate
    it in systemlib currently so I left it off.

  - class_alias_014.php does some namespace stuff I don't quite grok.
    (@ptarjan let me know what to do if it's easy).

  - inter_007.php uses class_alias, but is testing a warning that
    happens even with out it.  (We don't raise this warning.)

  - zend raises a warning if you try to class_alias a non-user-defined
    class; I left this out.
2013-06-06 12:00:05 -07:00

152 linhas
5.7 KiB
C++

/*
+----------------------------------------------------------------------+
| HipHop for PHP |
+----------------------------------------------------------------------+
| Copyright (c) 2010-2013 Facebook, Inc. (http://www.facebook.com) |
+----------------------------------------------------------------------+
| This source file is subject to version 3.01 of the PHP license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.php.net/license/3_01.txt |
| If you did not receive a copy of the PHP license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@php.net so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
*/
#ifndef incl_HPHP_SIMPLE_FUNCTION_CALL_H_
#define incl_HPHP_SIMPLE_FUNCTION_CALL_H_
#include "hphp/compiler/expression/function_call.h"
#include "hphp/compiler/analysis/variable_table.h"
namespace HPHP {
///////////////////////////////////////////////////////////////////////////////
DECLARE_BOOST_TYPES(SimpleFunctionCall);
class SimpleFunctionCall : public FunctionCall {
public:
static void InitFunctionTypeMap();
public:
SimpleFunctionCall(EXPRESSION_CONSTRUCTOR_PARAMETERS,
const std::string &name, bool hadBackslash,
ExpressionListPtr params, ExpressionPtr cls);
DECLARE_BASE_EXPRESSION_VIRTUAL_FUNCTIONS;
ExpressionPtr preOptimize(AnalysisResultConstPtr ar);
ExpressionPtr postOptimize(AnalysisResultConstPtr ar);
void deepCopy(SimpleFunctionCallPtr exp);
bool isDefineWithoutImpl(AnalysisResultConstPtr ar);
void setValid() { m_valid = true; }
void setFromCompiler() { m_fromCompiler = true; }
void setThrowFatal() { m_type = FunType::ThrowFatal; }
int isFatalFunction() const { return m_type == FunType::ThrowFatal; }
int isStaticCompact() const { return m_type == FunType::StaticCompact; }
// define(<literal-string>, <scalar>);
bool isSimpleDefine(StringData **name, TypedValue *value) const;
virtual TypePtr inferAndCheck(AnalysisResultPtr ar, TypePtr type,
bool coerce);
virtual int getLocalEffects() const;
// implementing IParseHandler
virtual void onParse(AnalysisResultConstPtr ar, FileScopePtr fs);
virtual void beforeCheck(AnalysisResultPtr ar) {}
void addDependencies(AnalysisResultPtr ar);
void addLateDependencies(AnalysisResultConstPtr ar);
void setSafeCall(int flag) { m_safe = flag; }
void setSafeDefault(ExpressionPtr def) { m_safeDef = def; }
virtual ConstructPtr getNthKid(int n) const;
virtual void setNthKid(int n, ConstructPtr cp);
static SimpleFunctionCallPtr GetFunctionCallForCallUserFunc(
AnalysisResultConstPtr ar, SimpleFunctionCallPtr call, int testOnly,
int firstParam, bool &error);
void setupScopes(AnalysisResultConstPtr ar);
bool readsLocals() const;
bool writesLocals() const;
void updateVtFlags();
void setLocalThis(const std::string &name) { m_localThis = name; }
bool isCallToFunction(const char *name) const;
bool isCompilerCallToFunction(const char *name) const;
void resolveNSFallbackFunc(AnalysisResultConstPtr ar, FileScopePtr fs);
protected:
enum class FunType {
Unknown,
Define,
Create,
VariableArgument,
Extract,
Compact,
StaticCompact, // compact() with statically known variable names
ShellExec,
Constant,
Defined,
FunctionExists,
ClassExists,
InterfaceExists,
Unserialize,
GetDefinedVars,
FBCallUserFuncSafe,
ThrowFatal,
ClassAlias,
};
static std::map<std::string,FunType> FunctionTypeMap;
FunType m_type;
unsigned m_dynamicConstant : 1;
unsigned m_builtinFunction : 1;
unsigned m_fromCompiler : 1;
unsigned m_invokeFewArgsDecision : 1;
unsigned m_dynamicInvoke : 1;
unsigned m_transformed : 1;
unsigned m_no_volatile_check : 1;
int m_safe;
ExpressionPtr m_safeDef;
std::string m_lambda;
ExpressionPtr optimize(AnalysisResultConstPtr ar);
private:
int checkObjCall(AnalysisResultPtr ar);
FunctionScopePtr
getFuncScopeFromParams(AnalysisResultPtr ar,
BlockScopeRawPtr scope,
ExpressionPtr clsName,
ExpressionPtr funcName,
ClassScopePtr &clsScope);
std::string getThisString(bool withArrow);
void mungeIfSpecialFunction(AnalysisResultConstPtr ar, FileScopePtr fs);
std::string m_localThis;
void *m_extra; // e.g., raw pointer to the symbol defined
};
SimpleFunctionCallPtr NewSimpleFunctionCall(
EXPRESSION_CONSTRUCTOR_PARAMETERS,
const std::string &name, bool hadBackslash, ExpressionListPtr params,
ExpressionPtr cls);
///////////////////////////////////////////////////////////////////////////////
// hphp_opt functions
ExpressionPtr hphp_opt_fb_call_user_func(CodeGenerator *cg,
AnalysisResultConstPtr ar,
SimpleFunctionCallPtr call, int mode);
ExpressionPtr hphp_opt_is_callable(CodeGenerator *cg,
AnalysisResultConstPtr ar,
SimpleFunctionCallPtr call, int mode);
ExpressionPtr hphp_opt_call_user_func(CodeGenerator *cg,
AnalysisResultConstPtr ar,
SimpleFunctionCallPtr call, int mode);
///////////////////////////////////////////////////////////////////////////////
} // HPHP
#endif // incl_HPHP_SIMPLE_FUNCTION_CALL_H_