|
@@ -1680,8 +1680,8 @@ and cpp_class_path_of klass =
|
|
|
|
|
|
|
|
|
let cpp_const_type cval = match cval with
|
|
|
- | TInt i -> CppInt(i) , TCppScalar("Int")
|
|
|
- | TBool b -> CppBool(b) , TCppScalar("Bool")
|
|
|
+ | TInt i -> CppInt(i) , TCppScalar("int")
|
|
|
+ | TBool b -> CppBool(b) , TCppScalar("bool")
|
|
|
| TFloat f -> CppFloat(f) , TCppScalar("Float")
|
|
|
| TString s -> CppString(s) , TCppString
|
|
|
| _ -> (* TNull, TThis & TSuper should already be handled *)
|
|
@@ -1788,9 +1788,9 @@ let rec cpp_type_of ctx haxe_type =
|
|
|
match path,params with
|
|
|
| ([],"Void"),_ -> TCppVoid
|
|
|
| ([],"void"),_ -> TCppVoid (* for old code with @:void *)
|
|
|
- | ([],"Bool"),_ -> TCppScalar("Bool")
|
|
|
+ | ([],"Bool"),_ -> TCppScalar("bool")
|
|
|
| ([],"Float"),_ -> TCppScalar("Float")
|
|
|
- | ([],"Int"),_ -> TCppScalar("Int")
|
|
|
+ | ([],"Int"),_ -> TCppScalar("int")
|
|
|
| ([], "EnumValue"),_ -> TCppObject
|
|
|
| ([], "Class"),_ -> TCppClass
|
|
|
| ([], "Enum"),_ -> TCppClass
|
|
@@ -2035,11 +2035,11 @@ let cpp_variant_type_of t = match t with
|
|
|
| TCppVarArg
|
|
|
| TCppVoidStar -> TCppVoidStar
|
|
|
| TCppScalar "Int"
|
|
|
- | TCppScalar "Bool"
|
|
|
+ | TCppScalar "bool"
|
|
|
| TCppScalar "Float" -> t
|
|
|
| TCppScalar "double"
|
|
|
| TCppScalar "float" -> TCppScalar("Float")
|
|
|
- | TCppScalar _ -> TCppScalar("Int")
|
|
|
+ | TCppScalar _ -> TCppScalar("int")
|
|
|
| TCppVariant -> TCppVariant
|
|
|
;;
|
|
|
|
|
@@ -2058,6 +2058,8 @@ let cpp_base_type_of t =
|
|
|
| TCppDynamic -> "Object"
|
|
|
| TCppString -> "String"
|
|
|
| TCppVoidStar -> "Pointer"
|
|
|
+ | TCppScalar "int" -> "Int"
|
|
|
+ | TCppScalar "bool" -> "Bool"
|
|
|
| TCppScalar x -> x
|
|
|
| _ -> "Object"
|
|
|
;;
|
|
@@ -2513,11 +2515,11 @@ let retype_expression ctx request_type function_args expression_tree forInjectio
|
|
|
if obj.cpptype=TCppNull then
|
|
|
CppNullAccess, TCppDynamic
|
|
|
else if fieldName="cca" && obj.cpptype=TCppString then
|
|
|
- CppFunction( FuncInternal(obj,"cca","."), TCppScalar("Int")), TCppDynamic
|
|
|
+ CppFunction( FuncInternal(obj,"cca","."), TCppScalar("int")), TCppDynamic
|
|
|
else if fieldName="__s" && obj.cpptype=TCppString then
|
|
|
CppVar( VarInternal(obj,".","__s")), TCppPointer("ConstPointer", TCppScalar("char"))
|
|
|
else if fieldName="__Index" then
|
|
|
- CppEnumIndex(obj), TCppScalar("Int")
|
|
|
+ CppEnumIndex(obj), TCppScalar("int")
|
|
|
else if is_internal_member fieldName || cpp_is_real_array obj then begin
|
|
|
let cppType = cpp_return_type ctx expr.etype in
|
|
|
if obj.cpptype=TCppString then
|
|
@@ -2687,7 +2689,7 @@ let retype_expression ctx request_type function_args expression_tree forInjectio
|
|
|
|
|
|
| TArray (e1,e2) ->
|
|
|
let retypedObj = retype TCppDynamic e1 in
|
|
|
- let retypedIdx = retype (TCppScalar("Int")) e2 in
|
|
|
+ let retypedIdx = retype (TCppScalar("int")) e2 in
|
|
|
let arrayExpr, elemType = (match retypedObj.cpptype with
|
|
|
| TCppScalarArray scalar ->
|
|
|
CppArray( ArrayTyped(retypedObj,retypedIdx) ), scalar
|
|
@@ -2760,8 +2762,8 @@ let retype_expression ctx request_type function_args expression_tree forInjectio
|
|
|
|
|
|
| TUnop (op,pre,e1) ->
|
|
|
let targetType = match op with
|
|
|
- | Not -> TCppScalar("Bool")
|
|
|
- | NegBits -> TCppScalar("Int")
|
|
|
+ | Not -> TCppScalar("bool")
|
|
|
+ | NegBits -> TCppScalar("int")
|
|
|
| _ -> cpp_type_of e1.etype
|
|
|
in
|
|
|
|
|
@@ -2783,7 +2785,7 @@ let retype_expression ctx request_type function_args expression_tree forInjectio
|
|
|
CppFor(v,init,block), TCppVoid
|
|
|
|
|
|
| TWhile (e1,e2,flag) ->
|
|
|
- let condition = retype (TCppScalar("Bool")) e1 in
|
|
|
+ let condition = retype (TCppScalar("bool")) e1 in
|
|
|
let close = begin_loop() in
|
|
|
let block = retype TCppVoid (mk_block e2) in
|
|
|
CppWhile(condition, block, flag, close()), TCppVoid
|
|
@@ -2838,7 +2840,7 @@ let retype_expression ctx request_type function_args expression_tree forInjectio
|
|
|
CppVarDecl(v, init), varType
|
|
|
|
|
|
| TIf (ec,e1,e2) ->
|
|
|
- let ec = retype (TCppScalar("Bool")) ec in
|
|
|
+ let ec = retype (TCppScalar("bool")) ec in
|
|
|
let blockify = if return_type!=TCppVoid then fun e -> e else mk_block in
|
|
|
let e1 = retype return_type (blockify e1) in
|
|
|
let e2 = match e2 with None->None | Some e -> Some (retype return_type (blockify e))
|
|
@@ -2854,7 +2856,7 @@ let retype_expression ctx request_type function_args expression_tree forInjectio
|
|
|
let condition = retype conditionType condition in
|
|
|
let cppDef = match def with None -> None | Some e -> Some (retype TCppVoid (mk_block e)) in
|
|
|
(try
|
|
|
- (match conditionType with TCppScalar("Int") | TCppScalar("Bool") -> () | _ -> raise Not_found );
|
|
|
+ (match conditionType with TCppScalar("int") | TCppScalar("bool") -> () | _ -> raise Not_found );
|
|
|
let cases = List.map (fun (el,e2) ->
|
|
|
(List.map const_int_of el), (retype TCppVoid (mk_block e2)) ) cases in
|
|
|
CppIntSwitch(condition, cases, cppDef), TCppVoid
|
|
@@ -3399,6 +3401,10 @@ let gen_cpp_ast_expression_tree ctx class_name func_name function_args injection
|
|
|
|
|
|
| CppClassOf (path,native) ->
|
|
|
let path = "::" ^ (join_class_path_remap (path) "::" ) in
|
|
|
+ let path = match path with
|
|
|
+ | "::Int" -> "int"
|
|
|
+ | "::Bool" -> "bool"
|
|
|
+ | x -> x in
|
|
|
if (native) then
|
|
|
out "null()"
|
|
|
else if (path="::Array") then
|
|
@@ -5002,6 +5008,8 @@ let script_signature t optional = match script_type t optional with
|
|
|
|
|
|
let script_size_type t optional = match script_type t optional with
|
|
|
| "Object" -> "void *"
|
|
|
+ | "Int" -> "int"
|
|
|
+ | "Bool" -> "bool"
|
|
|
| x -> x
|
|
|
;;
|
|
|
|