<html>
<head>
<style><!--
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
font-size: 12pt;
font-family:Calibri
}
--></style></head>
<body class='hmmessage'><div dir='ltr'>> From: hinstance@yandex.ru<br><div>> To: fpc-pascal@lists.freepascal.org<br>> Date: Sun, 2 Feb 2014 15:31:00 +0400<br>> Subject: Re: [fpc-pascal] fp universal library ?<br>> <br>> <br>> <br>> 02.02.2014, 02:45, "Fred van Stappen" <fiens@hotmail.com>:<br>> >> > Yep, thanks Michael.<br>> >> ><br>> >> > Hum, may i export dynamic array ?<br>> >><br>> >> No, you'll need to export these as (typed) pointers and a count.<br>> >><br>> >> Regards,<br>> >> Sven<br>> ><br>> > Re-Aaaaargh, ok, (and i understand now why the library-examples are so simple :-) ).<br>> ><br>> > Many thanks for that brilliant explanations.<br>> ><br>> > Ok, so i have to re-consider all the unit and forget the oop way and re-write more procedural (Yes/No ?).<br>> <br>> I think it should be layered. I tried to visualize the idea; take a look plz<br>> http://s17.postimg.org/oc24gbc27/Untitled_Diagram.png<br>> One should not write all units in procedural style to make library accessible from other languages. A better approach is to create API layers. For example to make FPC library accessible from Java and C# consider creating the following layers:<br>> FPC Library core <-> FPC Library procedural layer<br>> Procedural layer to Java OO<br>> Procedural layer to C#<br>> it should be like first API descends from OO level with FPC objects to procedural layer to make it accessible from java, then there should be java layer which "converts" it back from procedural flattened level to OO level with Java objects.<br>> <br>> AFAIK some libraries are designed like this. <br>> To further generalize the idea, consider this scheme:<br>> Language A OO <-> Language A proc. <-> dynamic lib <-> Language B proc. <-> Language B OO<br>> <br>> So the point is: of course you should NOT rewrite ALL units. Create a procedural bridge instead and then bridges for other languages like I tried to explain<br>> Of course choosing the right approach for this task it is up to you because no one knows your library better than you<br><br>Hello Hinstance and many thanks for advices.<br><br>What i will do is, like you said, not try to transform the actual working unit into a library but create a new file ( like the header file in c ) and in uses add the working unit. And that header file will be the "library" file with link to the working unit, with simple function-procedure...<br><br>I will give you news later.<br><br>Thanks<br><br></div> </div></body>
</html>