IRC logs of Freenode #BZFlag for Thursday, 2019-08-29

*** infobot <infobot!ibot@c-174-52-60-165.hsd1.ut.comcast.net> has quit IRC (Remote host closed the connection)00:16
*** infobot <infobot!ibot@c-174-52-60-165.hsd1.ut.comcast.net> has joined #bzflag00:16
*** ChanServ sets mode: +v infobot00:16
*** Sgeo <Sgeo!~Sgeo@ool-18b98995.dyn.optonline.net> has joined #bzflag01:52
*** Sgeo_ <Sgeo_!~Sgeo@ool-18b98995.dyn.optonline.net> has quit IRC (Ping timeout: 245 seconds)01:53
macsformein master (where I bumped our macOS deployment target to 10.9), we're getting warnings for two deprecated functions in DirectoryNames.cxx in the game module, FSFindFolder and FSRefMakePath... there doesn't appear to be any updated method that's accessible from C++ code02:51
macsformewe could 1) ignore or silence the warning, 2) have an Objective-C++ file wraps it, or 3) move that out of the game module and into platform, where we can use SDL_GetPrefPath(), which will also incidentally work with sandboxing if we want to do that later, and/or on iOS02:54
macsformesince I think we took pains to make all of our files C++ only a while back, I thought there might be some hesitation to adding an Objective-C++ file, even if it would only be compiled on macOS02:56
allejoi'd be hesitant to introduce another language into the codebase03:52
allejoeven if it's just for macos. still one more thing to maintain. option 3 sounds the most cross-platform friendly approach (with my limited knowledge of any of that works)03:53
allejois option 3 more cross-platform friendly (for devs that is)?03:53
Flashmacsforme: that's a bit of ugly platform-specific code04:22
Flashhttps://stackoverflow.com/questions/19404239/locating-mac-os-x-folders-using-urlfordirectory-instead-of-fsfindfolder04:22
Flashseems relevant04:22
FlashI'd think separating the platform-specific stuff into a "platform abstraction layer" is preferable to embedding it in various places04:25
FlashI had thought (with little digging) that's what SDL was for04:25
macsformeFlash: the proposed solutions in that link are for Objective-C code08:59
*** Dracos85 <Dracos85!~dracos85@24-119-188-49.cpe.cableone.net> has joined #bzflag09:26
*** Delusional_ <Delusional_!~Delusiona@unaffiliated/delusional> has joined #bzflag12:11
*** Sgeo_ <Sgeo_!~Sgeo@ool-18b98995.dyn.optonline.net> has joined #bzflag12:11
*** Delusional <Delusional!~Delusiona@unaffiliated/delusional> has quit IRC (Ping timeout: 245 seconds)12:13
*** Delusional_ is now known as Delusional12:13
*** Sgeo <Sgeo!~Sgeo@ool-18b98995.dyn.optonline.net> has quit IRC (Ping timeout: 245 seconds)12:14
*** I_Died_Once <I_Died_Once!~I_Died_On@unaffiliated/idiedonce/x-1828535> has joined #bzflag14:48
*** _I_Died_Once <_I_Died_Once!~I_Died_On@unaffiliated/idiedonce/x-1828535> has quit IRC (Ping timeout: 245 seconds)14:51
*** Sgeo_ <Sgeo_!~Sgeo@ool-18b98995.dyn.optonline.net> has quit IRC (Read error: Connection reset by peer)17:40
*** Sgeo_ <Sgeo_!~Sgeo@ool-18b98995.dyn.optonline.net> has joined #bzflag17:41
blast007macsforme: the overall directory handling stuff could be revamped.  For instance, on Windows, I'd like to store screenshots in the My Pictures folder, not a subfolder buried in a hidden configuration directory21:49
blast007so, going in that direction, I wouldn't be against having objective-c added to the src/platform/ if it gets us a feature that we can't get through SDL2's abstraction layer.21:53
blast007but if SDL2 can do what we need, we should use that21:53
macsformeis that what other games do? I only really play Overwatch on Windows, and it just puts a directory in the user's documents folder, and has the config, screenshots, and video highlights in there21:54
macsformemakes sense though, if our data is just config and screenshots, to have the config in appdata and the screenshots in the pictures folder21:58
blast007config, cache, screenshots, world downloads22:03
blast007on Windows, cache normally goes into c:\Users\Username\AppData\Local\AppName22:03
blast007configuration would go into c:\Users\Username\AppData\Roaming\AppName22:03
blast007for a game though, having configuration in Local is likely fine as well22:05
blast007most people playing games aren't going to be using roaming profiles, and even if they were you'd have variations between computers such as screen resolution22:06
macsformeI know on macOS, Apple really wants you to only write to the sandbox container area... in fact, some developers skip the app store (which requires sandboxing) due to the overall restrictiveness22:08
blast007nice.. needs a developer account to read the App Sandboxing FAQ..22:10
macsformelol22:12
blast007I imagine we can store persistent configuration and cache within the sandbox, and if we want to write screenshots and world downloads to the user's Pictures or Downloads folder, we would enable the entitlement for those22:14
blast007I've also briefly pondered a central hub for content (worlds, textures, sounds, scripts) that would be used instead of locally hosted map files.  In such a situation, a "world download" could simply be launching a URL.22:17
blast007there's plenty of things we could change about our map format22:18
blast007we could adopt some standard such as GLTF for defining our 3D scene, which would open up support for more standard editors.22:20
blast007though I guess I'm going off on a tangent now.. sorry  :)22:21
macsformewell it's at least good to consider the directories issue from a cross-platform standpoint22:27
The_NoahA hub for worlds would be awesome, especially of BZFS could run worlds directly from it.22:35
blast007The_Noah: one potential path I can see the game going is where game servers aren't set up for hosting specific maps, but instead are picked based on the location of players in a lobby and then the game server (and possibly the clients) load the desired world from the central hub23:03
blast007allows the content creators to focus on making content instead of being a sysadmin as well23:04
The_NoahOne problem I see is if a map needs a plugin that the server doesn't have. Although the server owner could just compile the plugins but that adds an extra step for some maps. (not a big issue though)23:25
blast007that's why I'd like to see plugins move from compiled code to interpreted scripts23:34

Generated by irclog2html.py 2.17.3.dev0 by Marius Gedminas - find it at https://mg.pov.lt/irclog2html/!