<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
{font-family:Consolas;
panose-1:2 11 6 9 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:blue;
text-decoration:underline;}
pre
{mso-style-priority:99;
mso-style-link:"HTML Preformatted Char";
margin:0in;
font-size:10.0pt;
font-family:"Courier New";}
span.HTMLPreformattedChar
{mso-style-name:"HTML Preformatted Char";
mso-style-priority:99;
mso-style-link:"HTML Preformatted";
font-family:"Consolas",serif;}
span.EmailStyle21
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-size:10.0pt;
mso-ligatures:none;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
/* List Definitions */
@list l0
{mso-list-id:927301284;
mso-list-template-ids:1058981704;}
ol
{margin-bottom:0in;}
ul
{margin-bottom:0in;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="blue" vlink="purple" style="word-wrap:break-word">
<div class="WordSection1">
<p class="MsoNormal">Thanks for the detailed response as always. From your comments it sounds like just having access to std::string would be worth it. So convert things .cpp and do targeted, high-value refactoring mostly around string manipulation to start.
At the same time we could visit the public C API – I honestly don’t know how much that is used by folks but I definitely agree that’s much more expansive than it needs to be.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b>From:</b> MapServer-dev <mapserver-dev-bounces@lists.osgeo.org>
<b>On Behalf Of </b>Even Rouault<br>
<b>Sent:</b> Wednesday, August 9, 2023 4:50 PM<br>
<b>To:</b> Steve Lime <sdlime@gmail.com>; MapServer Dev Mailing List <mapserver-dev@lists.osgeo.org><br>
<b>Subject:</b> Re: [MapServer-dev] MapServer C++ ification<o:p></o:p></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div>
<p class="MsoNormal">Le 09/08/2023 à 22:29, Steve Lime a écrit :<o:p></o:p></p>
</div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<div>
<p class="MsoNormal">Hi all: I've been wondering what it would take to start moving MapServer towards C++. Currently we have a bit of a mixed bag, mostly C with C++ used:
<o:p></o:p></p>
<div>
<ol start="1" type="1">
<li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
When required with C++ libs like Agg.<o:p></o:p></li><li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
For any new development, for example, OGC API and config file stuff is C++.<o:p></o:p></li><li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
Conversion work Even has spearheaded (e.g. mappostgis.cpp).<o:p></o:p></li></ol>
<p class="MsoNormal">A full-on rewrite is probably not in the cards anytime but are there steps that could/should be taken to move in that direction? For example, is there any value in converting .c to .cpp and using the C++ compiler and fixing errors? When
doing a conversion are there particular C patterns that would be ripe for reworking in C++? Are there any tools that might help with something like this?<o:p></o:p></p>
</div>
</div>
</blockquote>
<p>C++ has a somewhat stricter type checking, particularly it doesn't like mixing char* and const char* to avoid altering strings that the user meant to be immutable.<o:p></o:p></p>
<p>Being able to use conveniences like std::string is a big win compared to the risky C string manipulations, and having to care about explicit allocation/deallocation. Using containers like std::vector, set or map is also convenient.<o:p></o:p></p>
<p>That said, it is a quite significant work to change the interfaces of functions to use those C++ types, especially as we don't have a very tight public C API (to my taste, we export too many things that should be kept as implementation details. I assume
a number of them are just the accidental result of pasting existing definitions).<o:p></o:p></p>
<p>I'm not even speaking about making MapServer main structures C++ classes, which would make a number of things prettier (cf *), but would be an even harder challenge, as it would be very difficult to do in an incremental way, and that would be tricky to have
it still fully backward compatible with the current use of the C API. For examples, users of the C API couldn't just msMalloc() / msFree() on the C++'ifed structures. They would have to use dedicated C allocators & deallocators that would do the appropriate
new and delete calls, and the C++ classes definition should be fully opaque to the C API, which they aren't.<o:p></o:p></p>
<p>So our freedom of changing is also restricted by all that. The retrofits I did were mostly on changing implementation details within functions, or changes in the interface of static methods<o:p></o:p></p>
<p>Even<o:p></o:p></p>
<p>(*) Which would make it possible to rewrite this extract of FLTGetTimeExpression():<o:p></o:p></p>
<p> expressionObj old_filter;<br>
msInitExpression(&old_filter);<br>
msCopyExpression(&old_filter, &lp->filter); /* save existing filter */<br>
msFreeExpression(&lp->filter);<br>
... do something ...<br>
msCopyExpression(&lp->filter, &old_filter); /* restore old filter */<br>
msFreeExpression(&old_filter);<o:p></o:p></p>
<p> as just:<o:p></o:p></p>
<p> expressionObj old_filter(std::move(lp->filter)); /* save existing filter */<br>
lp->filter.clear();<br>
... do something ...<br>
lp->filter = std::move(old_filter);<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p>Even<o:p></o:p></p>
<p class="MsoNormal">-- <o:p></o:p></p>
<pre><a href="http://www.spatialys.com/">http://www.spatialys.com</a><o:p></o:p></pre>
<pre>My software is free, but my time generally not.<o:p></o:p></pre>
</div>
</div>
</body>
</html>