瀏覽代碼

* fixed COM parameter passing

git-svn-id: trunk@3389 -
florian 19 年之前
父節點
當前提交
2bb707a4ee
共有 2 個文件被更改,包括 19 次插入6 次删除
  1. 17 6
      compiler/pdecsub.pas
  2. 2 0
      compiler/symconst.pas

+ 17 - 6
compiler/pdecsub.pas

@@ -100,11 +100,16 @@ implementation
            if pd.deftype=procdef then
             akttokenpos:=tprocdef(pd).fileinfo;
 
-           { For left to right add it at the end to be delphi compatible }
-           if pd.proccalloption in pushleftright_pocalls then
-             paranr:=paranr_result_leftright
+           if is_interfacecom(tprocdef(pd)._class) then
+             paranr:=paranr_result_com
            else
-             paranr:=paranr_result;
+             begin
+               { For left to right add it at the end to be delphi compatible }
+               if pd.proccalloption in pushleftright_pocalls then
+                 paranr:=paranr_result_leftright
+               else
+                 paranr:=paranr_result;
+             end;
            { Generate result variable accessing function result }
            vs:=tparavarsym.create('$result',paranr,vs_var,pd.rettype,[vo_is_funcret,vo_is_hidden_para]);
            pd.parast.insert(vs);
@@ -152,7 +157,10 @@ implementation
           begin
             { Generate self variable }
             tt:=voidpointertype;
-            vs:=tparavarsym.create('$self',paranr_self,vs_value,tt,[vo_is_self,vo_is_hidden_para]);
+            if is_interfacecom(tprocdef(pd)._class) then
+              vs:=tparavarsym.create('$self',paranr_self_com,vs_value,tt,[vo_is_self,vo_is_hidden_para])
+            else
+              vs:=tparavarsym.create('$self',paranr_self,vs_value,tt,[vo_is_self,vo_is_hidden_para]);
             pd.parast.insert(vs);
           end
         else
@@ -190,7 +198,10 @@ implementation
                       vsp:=vs_var;
                     tt.setdef(tprocdef(pd)._class);
                   end;
-                vs:=tparavarsym.create('$self',paranr_self,vsp,tt,[vo_is_self,vo_is_hidden_para]);
+                if is_interfacecom(tprocdef(pd)._class) then
+                  vs:=tparavarsym.create('$self',paranr_self_com,vsp,tt,[vo_is_self,vo_is_hidden_para])
+                else
+                  vs:=tparavarsym.create('$self',paranr_self,vsp,tt,[vo_is_self,vo_is_hidden_para]);
                 pd.parast.insert(vs);
 
                 akttokenpos:=storepos;

+ 2 - 0
compiler/symconst.pas

@@ -96,7 +96,9 @@ const
     will be inserted with n+1 }
   paranr_parentfp = 1;
   paranr_result = 2;
+  paranr_result_com = 3;
   paranr_self = 3;
+  paranr_self_com = 2;
   paranr_vmt = 4;
   { Required to support variations of syscalls on MorphOS }
   paranr_syscall_basesysv = 9;