<div dir="ltr">Seth: Do you think this could be workable?<div><br></div><div><div> $config = new mapscript::configObj('path to config file');</div><div> $map = new mapscript::mapObj('my.map', $config);</div></div><div><br></div><div>Seems like we could update the MapScript mapObj constructors to take an optional configObj parameter with default of NULL. Destroying a mapObj doesn't destroy the config (it has a longer scope).</div><div><br></div><div>--Steve </div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Jun 21, 2021 at 10:09 PM Steve Lime <<a href="mailto:sdlime@gmail.com">sdlime@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="auto">Whoops, yes, i had intended to to reply all. Looping -dev back in.</div><div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sun, Jun 20, 2021 at 2:08 PM Seth G <<a href="mailto:sethg@geographika.co.uk" target="_blank">sethg@geographika.co.uk</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><u></u><div><div>Hi Steve,<br></div><div><br></div><div>I'm not sure if your last reply was also meant to be CCed to the mailing list?<br></div><div>Feel free to add this back to the chain. <br></div><div><br></div><div>Re the defaults maybe the following approach would be the most flexible:<br></div><div><br></div><div>- add a function that takes Mapfile1 and Mapfile2 and combines them so any Mapfile2 keywords take precedence, and Mapfile1 is used for any sections not specified. In JS this would be a single applyIf function but I'd imagine it is much harder in C..! The function could be made available via MapScript. <br></div><div>- allow a default Mapfile to be specified in the new config file. The function above would be used to apply settings to any Mapfile loaded via CGI. <br></div><div><br></div><div>This would get rid of the need for a new DEFAULTS section in the config file requiring object parsing etc. as it would simply be another mapObj. MapScript could then also apply a default Mapfile if required. <br></div><div></div></div></blockquote><div dir="auto"><br></div><div dir="auto">Neat idea. Seems like you’d want to load the default first to essentially initialize the mapObj and then the main one over the top of that.</div><div dir="auto"><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div><br></div><div>Re PLUGINS - is the idea the config file would simply replace:<br></div><div><br></div><div><span>PLUGIN</span> <span>"mssql"</span><br></div><div><br></div><div>With the path to the DLL when loading? E.g. <br></div><div><br></div><div><span>PLUGIN</span> <span>"C:/ms4w/Apache/specialplugins/mssql2008.dll"</span></div><div><br></div><div dir="auto">It would be good if the same Mapfile would work for both CGI and MapScript, but that would seeminly require a FONTSET-style approach. </div></div></blockquote><div dir="auto"><br></div><div dir="auto">I agree it would be best. Not sure how to make that happen without requiring changes to scripts with plugins. </div><div dir="auto"><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div dir="auto"></div></div><div><div>Seth<br></div><div><br></div><div id="gmail-m_1056926603969698388m_7778929483616667605sig62266145"><div>--<br></div><div>web:<a href="http://geographika.co.uk" target="_blank">http://geographika.co.uk</a><br></div><div>twitter: @geographika<br></div></div><div><br></div><div><br></div><div>On Sun, Jun 20, 2021, at 3:12 PM, Steve Lime wrote:<br></div><blockquote type="cite" id="gmail-m_1056926603969698388m_7778929483616667605qt"><div><br></div><div><div><br></div><div><div dir="ltr">On Sat, Jun 19, 2021 at 10:41 AM Seth G <<a href="mailto:sethg@geographika.co.uk" target="_blank">sethg@geographika.co.uk</a>> wrote:<br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><u></u><br></div><div><div>Hi Steve,<br></div><div><br></div><div>A few further thoughts.<br></div></div></blockquote><div dir="auto"><br></div><div dir="auto">Thanks!<br></div><div dir="auto"><br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div dir="auto"><br></div><div><br></div><div>Maybe DEFAULTS rather than GLOBALS would be a better term for Mapfile site-wide default settings. I think this would be part of a later addition to the config anyway?<br></div></div></blockquote><div dir="auto"><br></div><div dir="auto">Defaults is better, I agree. By later, do you mean not for 8.0?<br></div><div dir="auto"><br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div dir="auto"><br></div><div>When cloning a map or dumping it back out to a Mapfile, I presume any defaults would have to become part of the mapObj/Mapfile itself? Default values for keywords not in a Mapfile are currently copied/output with <span>msCopyMap</span>. <br></div><div><br></div></div></blockquote><div dir="auto"><br></div><div dir="auto">I was thinking we’d check the defaults and not write a value if it matched. A copy would retain those values though.<br></div><div dir="auto"><br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div><br></div><div>I think MapScript would need to be able to accept at least a filename to a config file. This could be added to the mapObj constructor e.g. <span>mapObj</span>(<span>char</span> *filename=<span><span>"", </span></span><span>char</span> *configfilename=<span><span>""</span></span>). <br></div><div>The main need would be to resolve PLUGIN paths. If these can only be referenced by keys in the config file then it would no longer be possible to work with LAYERs using a PLUGIN in MapScript. <br></div><div>Alternatively could it be an option to put plugins in their own key/value file and allow this to be referenced in a Mapfile, similar to FONTSET, and maybe allow restricting which paths can be used in the config file?<br></div><div><br></div></div></blockquote><div dir="auto"><br></div><div dir="auto">My initial thought was if the configObj was present in the mapObj then we’d lookup the value, so it would be required via cgi. If not then it would be taken.”as is”, so no change for mapscript. That check could be done in the END block of the load layer function. The gotcha there is if there was a mapfile that used a plugin and was also used by both mapscript and cgi.<br></div><div dir="auto"><br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div><br></div><div dir="auto">Finally if the new config file contains sections which can all be accessed via a hashTableObj then it should be fine to provide a SWIG/MapScript interface. However I'm not sure how we'd allow another contructor option cleanly - allowing mapfile, configfile, or configObj to be passed in. <br></div></div></blockquote><div dir="auto"><br></div><div dir="auto">Defaults would be an exception to just hashes - although I suppose it would possible to just use a hash there. Maybe there is no constructor. We just provide an method to load the config file into an object but it’s not used for anything but as a convenience reference. That is, a user could look stuff up but it wouldn’t be used for anything else and it wouldn’t provided to the mapObj constructor.<br></div><div dir="auto"><br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div dir="auto"><br></div></div><div><div>Seth<br></div><div><br></div><div id="gmail-m_1056926603969698388m_7778929483616667605qt-m_-82580840453596312sig62266145"><div>--<br></div><div>web:<a href="http://geographika.co.uk" target="_blank">http://geographika.co.uk</a><br></div><div>twitter: @geographika<br></div></div><div><br></div><div><br></div><div>On Sat, Jun 19, 2021, at 2:37 PM, Steve Lime wrote:<br></div><blockquote type="cite" id="gmail-m_1056926603969698388m_7778929483616667605qt-m_-82580840453596312qt"><div dir="auto">More I think about this, I think there shouldn’t be any MapScript impacts. Call it a CGI config file. That doesn’t preclude something in the future but it seems sensible to me to leave that out of scope for now.<br></div><div><div><br></div><div><div dir="ltr">On Wed, Jun 16, 2021 at 5:21 PM Steve Lime <<a href="mailto:sdlime@gmail.com" target="_blank">sdlime@gmail.com</a>> wrote:<br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div>You could certainly store that in one of the hashes "as is" although that's potentially a lot of overhead for storing that limited bit of information, especially since you have to know the path to the configuration file in the first place.<br></div><div><br></div><div>It seems to me that the most compelling reason for MapScript to leverage the config file would be for the global section that Seth mentioned. To deal with the globals we need to use the config data as part of the initialization process - so it needs to be part of loading or creating a map object. That way when you initialize the map you would, for example, set the fontset and symbolset attributes based on the global values (if present). Then those could be overridden as necessary. Some of the environment settings around things like a global debug file and level could also be useful in MapScript context.<br></div><div><br></div><div>So, we'd need to change the msLoadMap() function to take a config parameter. This would be mandatory via the CGI and optional for MapScript. I could see something like this (Perl):<br></div><div><br></div><div> $config = new mapscript::configObj('path to config file');<br></div><div> $map = new mapscript::mapObj('my.map', $config);<br></div><div><br></div><div>We could create a few helper methods associated with the config to get at things but the use of the configuration should be pretty much automatic.<br></div></div><div dir="ltr"><div> <br></div><div>--Steve<br></div></div><div><br></div><div><div dir="ltr">On Wed, Jun 16, 2021 at 9:34 AM Jeff McKenna <<a href="mailto:jmckenna@gatewaygeomatics.com" target="_blank">jmckenna@gatewaygeomatics.com</a>> wrote:<br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div>On 2021-06-16 11:06 a.m., Steve Lime wrote:<br></div><div><br></div><div>> At the moment this has no impact on MapScript. I was thinking perhaps we <br></div><div>> could add a method to optionally load a config file independently of a <br></div><div>> mapfile. Thoughts?<br></div><div>> <br></div><div><br></div><div>I believe MapScript impacts was the first comment I had made on this <br></div><div>months ago (and it is mentioned in the RFC draft also).<br></div><div><br></div><div>For example: PHP SWIG MapScript requires a path to a .php file that <br></div><div>contains all MapServer constants & functions (that is installed as part <br></div><div>of the cmake steps). For wishlist I'd like to see this new config file <br></div><div>allow to set the path to MapScript's required .php file.<br></div><div><br></div><div>-jeff<br></div><div><br></div><div><br></div><div><br></div><div>_______________________________________________<br></div><div>mapserver-dev mailing list<br></div><div><a href="mailto:mapserver-dev@lists.osgeo.org" target="_blank">mapserver-dev@lists.osgeo.org</a><br></div><div><a href="https://lists.osgeo.org/mailman/listinfo/mapserver-dev" rel="noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/mapserver-dev</a><br></div></blockquote></div></blockquote></div></div><div>_______________________________________________<br></div><div>mapserver-dev mailing list<br></div><div><a href="mailto:mapserver-dev%40lists.osgeo.org" target="_blank">mapserver-dev@lists.osgeo.org</a><br></div><div><a href="https://lists.osgeo.org/mailman/listinfo/mapserver-dev" target="_blank">https://lists.osgeo.org/mailman/listinfo/mapserver-dev</a><br></div><div><br></div></blockquote><div><br></div></div></blockquote></div></div></blockquote><div><br></div></div></blockquote></div></div>
</blockquote></div>