X-Git-Url: http://nitlanguage.org diff --git a/src/nitni/nitni_utilities.nit b/src/nitni/nitni_utilities.nit index 631421a..b1b5917 100644 --- a/src/nitni/nitni_utilities.nit +++ b/src/nitni/nitni_utilities.nit @@ -19,7 +19,7 @@ import nitni_base redef class MMethod # Build a C function name for the FFI implementation (uses friendly naming). - # * On a specific static receiver mype `recv_mtype` + # * On a specific static receiver type `recv_mtype` # * In referene to the module `from_module` (used for type resolving and as a possible prefix) # * Has a possible `suffix` to the method name (may be "__super", "__impl", null, etc.) # * With a specified length indicating whether it uses the sort name or the long name with @@ -28,7 +28,7 @@ redef class MMethod do var cname if self.is_init then - if self.name == "init" or self.name == "new" then + if self.name == "init" or self.name == "new" or self.name == "defaultinit" then cname = "new_{recv_mtype.mangled_cname}" else cname = "new_{recv_mtype.mangled_cname}_{self.short_cname}" @@ -39,13 +39,13 @@ redef class MMethod if suffix != null then cname = "{cname}{suffix}" - if length.long then cname = "{from_mmodule.name}___{cname}" + if length.long then cname = "{from_mmodule.c_name}___{cname}" return cname end # Build a C function signature for the FFI implementation (uses friendly naming). - # * On a specific static receiver mype `recv_mtype` + # * On a specific static receiver type `recv_mtype` # * In referene to the module `from_module` (used for type resolving and as a possible prefix) # * Has a possible `suffix` to the method name (may be "__super", "__impl", null, etc.) # * With a specified length indicating whether it uses the sort name or the long name with @@ -72,7 +72,7 @@ redef class MMethod var cparams = new List[String] if not self.is_init then - cparams.add( "{call_context.name_mtype(recv_mtype)} recv" ) + cparams.add( "{call_context.name_mtype(recv_mtype)} self" ) end for p in signature.mparameters do var param_mtype = p.mtype.resolve_for(recv_mtype, recv_mtype, from_mmodule, true) @@ -83,7 +83,7 @@ redef class MMethod end # Build a C function call for the FFI implementation (uses friendly naming). - # * On a specific static receiver mype `recv_mtype` + # * On a specific static receiver type `recv_mtype` # * In referene to the module `from_module` (used for type resolving and as a possible prefix) # * Has a possible `suffix` to the method name (may be "__super", "__impl", null, etc.) # * With a specified length indicating whether it uses the sort name or the long name with @@ -110,7 +110,7 @@ redef class MMethod var cparams = new List[String] if not self.is_init then - cparams.add(call_context.cast_to(recv_mtype, "recv{param_suffix}")) + cparams.add(call_context.cast_to(recv_mtype, "self{param_suffix}")) end for p in signature.mparameters do @@ -140,12 +140,10 @@ class CallContext fun cast_to(mtype: MType, name: String): String do return name end -redef class Object - # Call context to use - protected fun internal_call_context: CallContext do return new CallContext - protected fun long_signature: SignatureLength do return once new SignatureLength(true) - protected fun short_signature: SignatureLength do return once new SignatureLength(false) -end +# Call context to use +fun internal_call_context: CallContext do return new CallContext +fun long_signature: SignatureLength do return once new SignatureLength(true) +fun short_signature: SignatureLength do return once new SignatureLength(false) # Length of the signature of a C function (long version hase the module name as prefix) class SignatureLength