Stream: brlcad

Topic: GCV


view this post on Zulip Sumagna Das (Dec 10 2020 at 18:09):

Sean said:

yeah, sorry for the ping Sumagna Das -- that's not something you need to read through. Summary is just that gcv needs some lovin' and your work making a plugin for it make that obvious.

So i was busy with my studies and a personal project.......is there anything i can do to help fix GCV?

view this post on Zulip Sean (Dec 10 2020 at 20:19):

@Sumagna Das woo hoo! so how'd your testing go? hopefully passed all your exams :)

view this post on Zulip Sumagna Das (Dec 10 2020 at 20:20):

Yup...the exams went well..

view this post on Zulip Sean (Dec 10 2020 at 20:20):

awesome

view this post on Zulip Sean (Dec 10 2020 at 20:20):

that's always a good feeling to have that behind you.

view this post on Zulip Sean (Dec 10 2020 at 20:22):

As for GCV, I think the main stopper is how mime types are implemented by gcv and bu. If you recall, it was having trouble forwarding your PNG input file to your plugin.

view this post on Zulip Sean (Dec 10 2020 at 20:23):

couple issues there, I think

view this post on Zulip Sumagna Das (Dec 10 2020 at 20:23):

yea......it wasnt recognizing PNG files.

view this post on Zulip Sean (Dec 10 2020 at 20:24):

right, that's because PNGs are a 2D type and GCV is expecting 3D types because that's how LIBBU was implemented, separating them into groups

view this post on Zulip Sumagna Das (Dec 10 2020 at 20:25):

ohh.......thats why it was taking the PNG file as GCV_MODEL_UNKNOWN Or something like that

view this post on Zulip Sean (Dec 10 2020 at 20:25):

you can find that nutty logic in src/libbu/mime.cmake where it autogenerates source code. you can see the source code it generated by looking in the build dir at src/libbu/mime.c

view this post on Zulip Sean (Dec 10 2020 at 20:25):

bingo, correct

view this post on Zulip Sean (Dec 10 2020 at 20:25):

we had to say "handle anything" because it's a type in a completely different mime type bucket

view this post on Zulip Sean (Dec 10 2020 at 20:25):

so I think we need to change that in libbu

view this post on Zulip Sumagna Das (Dec 10 2020 at 20:26):

i will look into mime.cmake tomorrow

view this post on Zulip Sean (Dec 10 2020 at 20:26):

to either flatten the mime typing like it is in the original data file (see misc/mime.types) with the groupings being optional tagging

view this post on Zulip Sean (Dec 10 2020 at 20:28):

actually, that's the best approach I can come up with besides just recreating a mime typing API again (from scratch or otherwise)

view this post on Zulip Sean (Dec 10 2020 at 20:30):

probably easier than looking at mime.cmake is to simply look at include/bu/mime.h with a critical eye towards what needs to change

view this post on Zulip Sumagna Das (Dec 10 2020 at 20:30):

Sean said:

to either flatten the mime typing like it is in the original data file (see misc/mime.types) with the groupings being optional tagging

what do you mean by flatten?

view this post on Zulip Sean (Dec 10 2020 at 20:30):

the issue is the bu_mime_context_t parameters -- those have apps pick between 2d, 3d, video, and other mime type sets

view this post on Zulip Sean (Dec 10 2020 at 20:31):

they could all be combined into one, for example, thus grouping them into one context (for example)

view this post on Zulip Sean (Dec 10 2020 at 20:33):

that's what was meant by flattening them -- grouping into one set

view this post on Zulip Sean (Dec 10 2020 at 20:37):

or making null or a default be all sets or something

view this post on Zulip Sumagna Das (Dec 16 2020 at 19:32):

i just saw the files you told me to see....

view this post on Zulip Sumagna Das (Dec 16 2020 at 19:33):

what am i supposed to do here?

view this post on Zulip Sean (Dec 17 2020 at 19:01):

@Sumagna Das what's your perspective on the mime.h api? we either need to add/create a mime group that has all types (in addition to or instead of the domain-specific groups), or we could remove the groupings so it's just a type-based lookup like the system mime-type system.

view this post on Zulip Sean (Dec 17 2020 at 19:01):

Or something else entirely. It's a design decision that has to be made next. From there, the coding changes are pretty straightforward.

view this post on Zulip Sean (Dec 17 2020 at 19:02):

maybe think about how you would have WANTED to write the code in gcv, in an ideal world.

view this post on Zulip Sumagna Das (Dec 17 2020 at 19:33):

we can remove the groupings..

view this post on Zulip Sumagna Das (Dec 21 2020 at 18:44):

(deleted)

view this post on Zulip Sumagna Das (Dec 21 2020 at 18:45):

hey @Sean, will any of the files in the rest of the codebase be affected if we remove the groupings?

view this post on Zulip Sumagna Das (Dec 21 2020 at 20:14):

and one other thing........is there any named type called bu_mime_context?

view this post on Zulip starseeker (Dec 22 2020 at 00:15):

@Sean I offer this merely as food for thought - conceptually, could we think about "conversions" between different mime type categories (i.e. images and geometry files) not as conversions but as procedural geometry generations? That would categorize the task of generating some kind of geometry file from a PNG image as a task for a different type of program...

view this post on Zulip starseeker (Dec 22 2020 at 00:17):

That appeals to me in some ways since it would mean the conceptually ambiguity (i.e. should a PNG import become a binary object in a .g file, a shader texture, a terrain DSP object, etc...) would then be out of scope for GCV.

view this post on Zulip Sumagna Das (Dec 22 2020 at 20:15):

@Sean i dont know if i were supposed to do this before telling anything but i removed the bu_mime_image_t-kinda grouping and combined them into bu_mime_context_t group. I renamed the group containing BU_MIME_APPLICATION, BU_MIME_IMAGE, etc from bu_mime_context_t to bu_mime_context.

view this post on Zulip Sumagna Das (Dec 22 2020 at 20:16):

/me is bad at naming variables.

view this post on Zulip Sumagna Das (Dec 22 2020 at 20:23):

imma send the mime_types.h and mime.cmake so that you can see what i did (other than doing the other naming changes)

view this post on Zulip Sumagna Das (Dec 22 2020 at 20:25):

mime.cmake
mime_types.h

view this post on Zulip Sumagna Das (Dec 22 2020 at 20:26):

these are the two main files that have been changed (i know that mime.cmake changes the second file but it was one of the major changes i did)

view this post on Zulip Sumagna Das (Dec 23 2020 at 18:46):

i fixed GCV not taking any mime type other than BU_MIME_MODEL_UNKNOWN

view this post on Zulip Sumagna Das (Dec 23 2020 at 18:53):

the ((bu_mime_context_t)type_int) != BU_MIME_MODEL_UNKNOWN condition in fmt_type() function in gcv.c was causing the problem...i changed it to ((bu_mime_context_t)type_int) != BU_MIME_MODEL_UNKNOWN && type_int != -1

view this post on Zulip Sumagna Das (Dec 23 2020 at 19:00):

@Sean PS: if you didnt see the mime.cmake file, then i want to notify you that i flattened the groupings and because of that, every group like bu_mime_model_t is combined into bu_mime_context_t

view this post on Zulip Sean (Dec 26 2020 at 17:01):

starseeker said:

That appeals to me in some ways since it would mean the conceptually ambiguity (i.e. should a PNG import become a binary object in a .g file, a shader texture, a terrain DSP object, etc...) would then be out of scope for GCV.

Hm, interesting though but I think it'd be fairly arbitrary and (more importantly) not user friendly. Don't think it's a distinction that fits our modeling paradigm as implicit geometry means object data is often in some lower-dimensional form. Your gdal linkage is a good example. Perfectly normal for terrain data to live in 2D tiff/png/jpg container, and as such I'd entirely expect gcv to handle converting it. Same for vol data. The data lives in 2D containers, and I would expect gcv to handle them just the same. Pulling out terrain, vol, ebm, pnts, and even BoT creation (e.g., when container is say a txt file with xyz, for example) wouldn't be terribly obvious to me.

I think gcv's on the right track already. The mime type issue is just an issue because the current BU interface is attempting to categorize and the categories are obviously restricting visibility. They're a namespace. We just need to complete the metaphor by introducing global namespacing (i.e., uncategorized), and this should be solved.

view this post on Zulip Sean (Dec 26 2020 at 17:04):

I kind of see this getting inverted. We have a master list of types (mime.types) that are string->type mappings. We have a series of additional types that are akin to "image/* -> png, tiff, jpg, gif, ..." mappings so callers can distinguish on any type or rich subsets of types (or exclude types).

view this post on Zulip Sean (Dec 26 2020 at 17:05):

Towards that, we may want to make those explicit in our mime.types file so any grouping types are auto-generated instead of encoded.

view this post on Zulip Sean (Dec 26 2020 at 17:10):

Sumagna Das said:

imma send the mime_types.h and mime.cmake so that you can see what i did (other than doing the other naming changes)

Can you send an svn diff too? Not easy to see what all was changed in mime.cmake, how it compares.

view this post on Zulip Sean (Dec 26 2020 at 17:15):

I'm increasingly thinking we want a traditional string mapping, so apps/callers can do globbing or lookups on their own (e.g., mime.lookup("/path/to/myfile") or mime.lookup(".jpg"))

view this post on Zulip Sumagna Das (Dec 26 2020 at 17:52):

Sean said:

Sumagna Das said:

imma send the mime_types.h and mime.cmake so that you can see what i did (other than doing the other naming changes)

Can you send an svn diff too? Not easy to see what all was changed in mime.cmake, how it compares.

only for mime.cmake?

view this post on Zulip Sumagna Das (Dec 26 2020 at 17:59):

changes.diff

view this post on Zulip Sumagna Das (Dec 26 2020 at 18:03):

it might be a little dirty because i wasnt sure about the changes i was making.....if it needs cleaning up, then tell me where it needs
a little cleanup..

view this post on Zulip starseeker (Dec 26 2020 at 22:11):

I'm not entirely sure I follow - you mean we'd define image/png and terrain/png as distinct mime types, and given a png file the user would need to identify the mime type explicitly so the converter would know what to do with it?

view this post on Zulip Sean (Dec 27 2020 at 06:33):

no, not inventing types like that. I meant making the categoric groupings like image/* be an enum type in the same namespace. So like how BU_MIME_IMAGE_JPEG is supposed to match "jpg" or "jpeg" etc, there'd also be a BU_MIME_IMAGE that'd represent all the BU_MIME_IMAGE_* types instead of having a separate context data structure. There'd just be a master registry like sumagna has now with additional groupings like we had before so plugins can just ask for a type, or can narrow in on a subset, or call out a custom set.

view this post on Zulip starseeker (Dec 28 2020 at 05:41):

(Sorry - I'm sure I'm either being dense or missing the point...)

I'm still not following... when gcv gets the input:

gcv image.tiff output.g

how is the question decided as to whether that tiff image ends up as an ebm, a terrain object, a shader object, or just a straight up binary object holding the image? All of those are potentially valid interpretations of the same data...

view this post on Zulip starseeker (Dec 28 2020 at 05:42):

The only way I can see is the user must provide somehow additional context that specifies one of those outcomes, but I'm not seeing a good way yet to do it...

view this post on Zulip Sumagna Das (Jan 01 2021 at 18:42):

SO what should i do about the changes i made in the files for flattening the mime types alongside keeping the group names only?

view this post on Zulip Sumagna Das (Feb 03 2021 at 12:48):

Sumagna Das said:

SO what should i do about the changes i made in the files for flattening the mime types alongside keeping the group names only?

hey @Sean what should i do about these changes?

view this post on Zulip starseeker (Mar 25 2021 at 16:24):

Did we ever come to a conclusion on this? I'm really not happy about flattening the image vs. geometry context out of the mime types unless/until we have another way to distinguish those categories...

Looking at the icv/io.h changes in the pull request, bu_mime_context_t just feels too generic to me - personally, I want things to fail immediately and hard at build time if I accidentally try to feed a geometry file type through an image conversion...

view this post on Zulip starseeker (Mar 25 2021 at 16:26):

I still don't have any good feeling for what gcv is supposed to do when the input "gcv image.png image.g" is given to it...

view this post on Zulip Sumagna Das (Mar 25 2021 at 18:30):

starseeker said:

Did we ever come to a conclusion on this? I'm really not happy about flattening the image vs. geometry context out of the mime types unless/until we have another way to distinguish those categories...

Looking at the icv/io.h changes in the pull request, bu_mime_context_t just feels too generic to me - personally, I want things to fail immediately and hard at build time if I accidentally try to feed a geometry file type through an image conversion...

oh.......didnt knew you wouldnt agree with that.

view this post on Zulip starseeker (Mar 25 2021 at 18:32):

@Sumagna Das I'll defer to @Sean - he has a clearer vision than I do of where he wants to go with GCV. I'm just fundamentally bothered by my inability to answer the question "What is supposed to happen when the user gives us 'gcv image.png output.g' on the command line."

view this post on Zulip starseeker (Mar 25 2021 at 18:47):

The options I know of for "gcv image.png output.g" are:

  1. Just error out with some sort of inadequate specification error unless something like a specific backend is supplied - i.e., require something like "gcv image.png --plugin GDAL output.g" before proceeding. Works, but has negative usability implications.

  2. Always default to the "highest order" output - i.e. for a PNG file, we can default to a height field geometric interpretion and require specification for something else like a texture/shader object or binary object. Easiest from the user perspective IF what we default to is what they want, but potentially frustrating if it does the "wrong" thing for their particular case and they don't know what to do to change the behavior.

  3. Just define any non geometry->geometry conversions as out of scope for gcv - i.e. turning cases involving image data that can't be unambiguously identified as terrain data over to procedural geometry generators rather than the gcv converter. This has the virtue of simplicity, since anything that doesn't have an unambiguous geometric interpretation is simply an invalid input to gcv and another tool is required. However, in prior discussions Sean felt that failing to convert in such cases would be a usability hit.

view this post on Zulip Sumagna Das (Mar 25 2021 at 19:06):

starseeker said:

Did we ever come to a conclusion on this? I'm really not happy about flattening the image vs. geometry context out of the mime types unless/until we have another way to distinguish those categories...

Looking at the icv/io.h changes in the pull request, bu_mime_context_t just feels too generic to me - personally, I want things to fail immediately and hard at build time if I accidentally try to feed a geometry file type through an image conversion...

i was also checking the changes for the removing the 2nd level groupings and it does seem like that removing them could pose a problem.

view this post on Zulip Sumagna Das (Mar 25 2021 at 19:08):

if a specific category is not specified, then there is actually a program that some program using these types can be fed anything as input rather than getting files from a specific category. for example, like you said, ICV is supposed to get only images as input but removing the 2nd level grouping can mean that it can get any type of file as input

view this post on Zulip Sumagna Das (Mar 25 2021 at 19:10):

one thing i did in one of the commits is that alongside keeping the 2nd level grouping is that i added a BU_MIME_AUTO which acted like a switch saying that search from the whole of the mime types' namespace.

view this post on Zulip Sumagna Das (Mar 25 2021 at 19:11):

that enum can work pretty well for now for GCV so that it gets all the types of files

view this post on Zulip Sumagna Das (Mar 25 2021 at 19:14):

but as you said for the 2nd option, the plugin will not know what the user wants and do a default conversion

view this post on Zulip Sean (Mar 25 2021 at 21:22):

A lot of excellent insights mentioned, but we shouldn't lose sight of the implementation goal at hand -- namely, creating a vol from a stack of one or more images and how that usability and discovery plays out. The existing BU interface can't/couldn't handle it, so changes are needed. That's not to say that we can also have groupings, or that we don't still also have to sort out what a given conversion request behavior should be, too.

view this post on Zulip Sean (Mar 25 2021 at 21:25):

@starseeker I think your summary of "gcv image.png output.g" options are spot-on. I would flat-out reject #3 as unreasonable and unnecessary restriction. The problem of there being multiple conversion results possible for a given input is not unique to images by any stretch. Geometry have that problem as well.

view this post on Zulip Sean (Mar 25 2021 at 21:26):

I think the gdal integration is further supporting evidence -- it makes complete usability sense to me that the conversion tool will accept a 2d input and have the wherewithall to generate a 3d representation from it.

view this post on Zulip Sean (Mar 25 2021 at 21:28):

As for options #1 and #2, they're not mutually exclusive and I think we'll end up wanting to do a mix of both. They're certainly related to the typing system and ability to do something high-order automatically, but not strictly coupled to it (beyond our existing implementation coupling them).

view this post on Zulip starseeker (Mar 25 2021 at 21:32):

So then what's our way forward to arrive at a concrete implementation design?

view this post on Zulip starseeker (Mar 25 2021 at 21:35):

That's where I keep getting stuck... if we want to allow the complexity explosion of N conceptual interpretations of what it means to convert image data to geometry data, how do we encapsulate that in a usable way for programmer and user? Every attempt I've made has fallen short...

view this post on Zulip Sean (Mar 25 2021 at 21:38):

Actually I wouldn't have said the first attempt fell short, it just made an assumption that didn't hold up to the next plugin. So we know some adaptation is needed.

view this post on Zulip Sean (Mar 25 2021 at 21:40):

Without punting the adaptation to the user yet, there are two issues. First there is/was no way for a plugin to declare that it handles a non-geometric type. Second, there didn't appear to be a way to route to the plugin manually (had to manually disable other plugins).

view this post on Zulip Sean (Mar 25 2021 at 21:42):

I think the original plan for gcv plugins is still the way to go -- namely that plugins define the processing architecture by declaring what they can handle and reporting whether they can handle a particular input.

view this post on Zulip Sean (Mar 25 2021 at 21:44):

With #1 fixed by doing "some change" to the typing system -- there is a decision we have to immediately face, namely what to do when two plugins support the type and two plugins say yes to handling that particular input. A PNG input is nominally something we can handle today in three ways (gdal, this new vol plugin, and binary/image object).

view this post on Zulip starseeker (Mar 25 2021 at 21:45):

There's another issue as well - if we're allowing multiple interpretations (terrain, shader, extrusion, binary blob, etc.) then the mime specification isn't going to be sufficient for the plugin API identification on its own. We need some way for a plugin to say "I support image->terrain, image->blob, but not image->shader" (for example.)

view this post on Zulip Sean (Mar 25 2021 at 21:51):

That's for filter plugins. There can be many plugins, but a given plugin is going to do one of those. We can probably constrain it to only being one of those from a declaration standpoint, or let the input callback make more complex or specific determinations.

view this post on Zulip Sean (Mar 25 2021 at 21:53):

In the original architecture concept, filters did not deal with typed input at all. We could reduce them down to that and it would probably greatly simplify processing (and plugin implementation).

view this post on Zulip starseeker (Mar 25 2021 at 21:56):

Actually, I semi-lost site of the original prompting issue for the question - in the proposed github pull request, the icv API is changed so that it too takes a generic mime type, rather than just image mime types. For your design vision, is that an OK direction?

view this post on Zulip Sean (Mar 25 2021 at 22:00):

That's a good question. I'd not looked into the pull request in detail yet, but the gist I think is not unreasonable. And for similar reasons, say one wanted to implement a plugin that created an image from a .txt file that contained r g b d data, or from an .xls file where some range of cells has rgb values, etc.

view this post on Zulip Sean (Mar 25 2021 at 22:06):

I think all that's needed to let that work is for a plugin to be able to list it's types. Any nuance can be handled in the callback. To make it convenient, we can provide meta types (e.g., BU_MIME_IMAGE, BU_MIME_MODEL, etc.).

view this post on Zulip Sean (Mar 25 2021 at 22:08):

That would preserve the two-level namespace as data.

view this post on Zulip Sean (Mar 25 2021 at 22:26):

The outstanding questions for bu_mime are 1) do we need to make multiple typedefs available, i.e., what code or feature(s) will benefit from a compile-time type restriction and 2) do we want/need defines for meta groupings and 3) do we want/need string-based type associations (whether as a grouping mechanism, for interfacing with other things, or ...?)

view this post on Zulip Sumagna Das (Mar 26 2021 at 03:31):

i understood most of the part here until the last 4 or 5 messages :sweat_smile:

view this post on Zulip Sean (Mar 26 2021 at 16:52):

LOL @Sumagna Das

view this post on Zulip Sean (Mar 26 2021 at 16:55):

basically, trying to figure out what/how exactly should bu_mime change so that we can still hard-fail during compilation on a categoric type (if that is needed somewhere) but also support plugins declaring their support and being potentially more nuanced in their input validation callback.

view this post on Zulip Sean (Mar 26 2021 at 17:01):

I think @starseeker is probably not (yet)fond of the idea of some tools like icv handling non-image formats (e.g., data files), and that's a valid critique. I see it essentially required and thus will require a bit more thought on how tools like icv/gcv respond when there are 2+ plugins that say they can handle a given input.

For example, we likely will have 3 plugins that read a png file in gcv and they're all roughly equal probability: png-to-dsp-via-gdal, png-to-vol, png-to-binunif

view this post on Zulip Sumagna Das (Mar 26 2021 at 17:58):

Sean said:

I think @starseeker is probably not (yet)fond of the idea of some tools like icv handling non-image formats (e.g., data files), and that's a valid critique. I see it essentially required and thus will require a bit more thought on how tools like icv/gcv respond when there are 2+ plugins that say they can handle a given input.

For example, we likely will have 3 plugins that read a png file in gcv and they're all roughly equal probability: png-to-dsp-via-gdal, png-to-vol, png-to-binunif

thats a big problem......

view this post on Zulip Sumagna Das (Mar 29 2021 at 19:37):

did you guys come to any conclusion? i want to finish this thing before my exams from 12th april.

view this post on Zulip Sean (Mar 30 2021 at 04:56):

@Sumagna Das I'm not seeing a better way around it. Options seem to be:
A) require non-geometric plugins to resort to being an "unknown" type whereupon the same problem of routing still exists for all such plugins (which would also require something like forced user-specification which would hurt usability/discoverability). I think this is architecturally a problem because there's not a more appropriate place for such functionality, yet typing as unknown would kind of imply they're second-class plugins or otherwise unsupported.
B) let the functionality be handled elsewhere and limit gcv strictly to geometry file inputs. for example, the vol command could read in from images, the dsp command could read in via gdal. while that would be useful in workflows, it seems like it doesn't address gcv being an intuitive place to read data files that result in geoemtry. again, gdal is a great example of this.
C) make changes to the typing system and gcv so it will route files to plugins that handle that file(s) type. fairly unobtrusive change imho. it doesn't answer what happens when multiple plugins handle the same input type but then neither does the current code or options A or B.
D) eliminate the typing system. it's not strictly required. its intent was to improve usability so if there was only one plugin or set of plugins that could handle a given conversion, that it would just do it instead of a user explicitly having to say which plugin (e.g., gcv --i gdal input.png output.g

There is declarative simplicity with D and in some respects we probably should have started there, but B and C have superior usability in my view, C winning out overall as more discoverable.

Towards that end, I think what we should do is keep some means to know we have (for example) and image vs geometry vs something else. I think that can be a sub-typedef like bu_mime_image_t and bu_mime_model_t for compile time restriction or it can be a meta type like BU_MIME_IMAGE for runtime restriction (I don't feel strongly for either being better). That will be helpful for commands like overlay or screengrab that only deal with images. As for gcv, I think that'll generalize to something like bu_mime_t (which has all types) and plugins declare a set of one or more mime types. In the case where multiple plugins match, we'll make it report the conflict, list out available options, and require the user specify.

view this post on Zulip Sumagna Das (Mar 30 2021 at 05:33):

B and D sound more like it to me.

view this post on Zulip Sumagna Das (Mar 30 2021 at 05:35):

but the problem still stays that there will a uncertainty about what happens when multiple plugins handle the same file type

view this post on Zulip Sumagna Das (Mar 30 2021 at 05:40):

we can do B but alongside we can make it report if any conflict exists where multiple plugins are trying to handle the same file.

view this post on Zulip Sean (Mar 30 2021 at 15:18):

@Sumagna Das they are certainly options, but they have an undeniable impact on usability and discoverability, and which went or at least go against the original design plans for gcv (that it will figure out what's best when/where it can)

view this post on Zulip Sumagna Das (Mar 30 2021 at 19:55):

(deleted)

view this post on Zulip Sumagna Das (Mar 30 2021 at 19:58):

i was trying to find out the real definition of GCV and found out what it was initially made for (Geometry Conversion library) so i think the plugins which handle non-geometry types should be seperated from GCV and either be made into a command inside mged or be made a fully seperate executable or be added as an option to existing commands inside or outside mged.

view this post on Zulip Sean (Mar 30 2021 at 23:36):

@Sumagna Das except what constitutes "non-geometry" is very much debatable, it depends on the data format, and depends on the data domain (where it came from).

view this post on Zulip Sean (Mar 30 2021 at 23:37):

for example, is a text file full of XYZ vertices a geometry type?

view this post on Zulip Sean (Mar 30 2021 at 23:55):

because that's a common "geometry" format that could be a polygonal mesh (it's called xyz format) or it could be point cloud scan data (is that geometry??) or it could be raw terrain elevation data (certainly represents geometry) ...

view this post on Zulip Sean (Mar 30 2021 at 23:56):

and yet that same can be said of an image files too -- they're just a quantized array of data. could be terrain (PNG is a standard format for terrain data) ... or could just be an image.

view this post on Zulip Sean (Mar 30 2021 at 23:58):

in the medical industry, dicom is their geometry file format, but they are just sets of images. they can represent 3D volumes or point clouds ... or just be images with no 3D implication.

view this post on Zulip Sean (Mar 31 2021 at 00:01):

gcv's original scope was the consolidation of a bunch of geometry converters into one tool, but even from the onset that already included data files too, so I don't think it's a out of place to include them. moreover, and more problematically, it doesn't solve a problem by excluding them -- if anything it would create pointless work like extracting gdal from gcv.

view this post on Zulip Sumagna Das (Mar 31 2021 at 02:16):

didnt know geometry types were this complicated

view this post on Zulip Sean (Mar 31 2021 at 12:16):

The waters are muddy and we're learning, will make mistakes. I think it's all good. We can try a direction and if it doesn't work out, we can change it. I think the least code churn at this point is to just tweak bu_mime to provide a means to scan all types and let plugins declare whatever it is they read/write. We'll learn.

view this post on Zulip Sumagna Das (Mar 31 2021 at 15:48):

I had that part ready so that it could scan from all types

view this post on Zulip Sumagna Das (Mar 31 2021 at 15:48):

But It would need the 2nd level grouping which I removed

view this post on Zulip Sumagna Das (Mar 31 2021 at 15:49):

Also
Is it needed tobring back bu_mime_*_t enums or should they be combined like they are right now?

view this post on Zulip Sean (Mar 31 2021 at 19:18):

I think we should keep both typedefs for now. That way commands like screengrab can literally be hard-limited to image formats.

view this post on Zulip Sean (Mar 31 2021 at 19:19):

but then also have a bu_mime_t that has them all

view this post on Zulip Sean (Mar 31 2021 at 19:19):

(instead of bu_mime_context_t, not really a benefit introducing another term)

view this post on Zulip Sumagna Das (Mar 31 2021 at 19:20):

can you check the PR

view this post on Zulip Sumagna Das (Mar 31 2021 at 19:21):

i removed the commit which remove the 2nd level grouping like BU_MIME_IMAGE, etc

view this post on Zulip Sumagna Das (Mar 31 2021 at 19:21):

i also added BU_MIME_AUTO which searches from all of them

view this post on Zulip Sumagna Das (Apr 21 2021 at 18:30):

sorry for the inactivity
i had exams going on
now that I am done with the exams
what were the plans for this part @Sean ?

view this post on Zulip Sean (Apr 21 2021 at 19:00):

@Sumagna Das how'd the exams go?

view this post on Zulip Sean (Apr 21 2021 at 19:00):

no worries, good to focus on your exams.... they're kind of important ;)

view this post on Zulip Sumagna Das (Apr 21 2021 at 19:01):

Sean said:

Sumagna Das how'd the exams go?

it went pretty well

view this post on Zulip Sumagna Das (Apr 22 2021 at 20:15):

there is one thing i want to ask

view this post on Zulip Sumagna Das (Apr 22 2021 at 20:16):

should i bring back all of the bu_mime_*_t and keep one bu_mime_t namespace along with it?

view this post on Zulip Sean (Apr 23 2021 at 03:59):

@Sumagna Das that would probably be good for now, so an app / use case could choose to be type-limited or not. longer term I think we could probably find a way that does it with fewer API symbols, if needed.

view this post on Zulip Sumagna Das (Apr 23 2021 at 07:53):

[  0%] Built target timestamp
[  0%] Built target BENCHMARK_PIX_cp
Scanning dependencies of target libbu-obj
[  0%] Built target netpbm
[  0%] Built target 04238f4c3429a37ca335f9352ba2dc81_cp
[  0%] Building C object src/libbu/CMakeFiles/libbu-obj.dir/crashreport.c.o
[  0%] Built target openNURBS_headers_cp
[  0%] Built target fix_6r_cp
[  0%] Built target nonie_r_12_cp
[  0%] Built target nurb_example_c_cp
[  0%] Built target raydebug_tcl_cp
[  0%] Building C object src/libbu/CMakeFiles/libbu-obj.dir/mime.c.o
[  0%] Built target CL_FILES_cp
[  0%] Built target tpkg_c_cp
[  0%] Built target termcap_cp
[  0%] Built target brlman_tcl_cp
[  0%] Building C object src/libbu/CMakeFiles/libbu-obj.dir/vers.c.o
In file included from /home/sumagnadas/github/brlcad_git/include/bu/mime.h:27,
                 from /home/sumagnadas/github/brlcad_git/build1/src/libbu/mime.c:21:
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:887:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_AUTO’
  887 |     BU_MIME_APPLICATION_AUTO,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:44:5: note: previous definition of ‘BU_MIME_APPLICATION_AUTO’ was here
   44 |     BU_MIME_APPLICATION_AUTO,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:888:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_ANDREW_DASH_INSET’
  888 |     BU_MIME_APPLICATION_ANDREW_DASH_INSET,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:45:5: note: previous definition of ‘BU_MIME_APPLICATION_ANDREW_DASH_INSET’ was here
   45 |     BU_MIME_APPLICATION_ANDREW_DASH_INSET,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:889:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_APPLIXWARE’
  889 |     BU_MIME_APPLICATION_APPLIXWARE,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:46:5: note: previous definition of ‘BU_MIME_APPLICATION_APPLIXWARE’ was here
   46 |     BU_MIME_APPLICATION_APPLIXWARE,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:890:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_ATOMCAT_PLUS_XML’
  890 |     BU_MIME_APPLICATION_ATOMCAT_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:47:5: note: previous definition of ‘BU_MIME_APPLICATION_ATOMCAT_PLUS_XML’ was here
   47 |     BU_MIME_APPLICATION_ATOMCAT_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:891:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_ATOMSVC_PLUS_XML’
  891 |     BU_MIME_APPLICATION_ATOMSVC_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:48:5: note: previous definition of ‘BU_MIME_APPLICATION_ATOMSVC_PLUS_XML’ was here
   48 |     BU_MIME_APPLICATION_ATOMSVC_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:892:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_ATOM_PLUS_XML’
  892 |     BU_MIME_APPLICATION_ATOM_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:49:5: note: previous definition of ‘BU_MIME_APPLICATION_ATOM_PLUS_XML’ was here
   49 |     BU_MIME_APPLICATION_ATOM_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:893:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_CCXML_PLUS_XML’
  893 |     BU_MIME_APPLICATION_CCXML_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:50:5: note: previous definition of ‘BU_MIME_APPLICATION_CCXML_PLUS_XML’ was here
   50 |     BU_MIME_APPLICATION_CCXML_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:894:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_CDMI_DASH_CAPABILITY’
  894 |     BU_MIME_APPLICATION_CDMI_DASH_CAPABILITY,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:51:5: note: previous definition of ‘BU_MIME_APPLICATION_CDMI_DASH_CAPABILITY’ was here
   51 |     BU_MIME_APPLICATION_CDMI_DASH_CAPABILITY,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:895:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_CDMI_DASH_CONTAINER’
  895 |     BU_MIME_APPLICATION_CDMI_DASH_CONTAINER,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:52:5: note: previous definition of ‘BU_MIME_APPLICATION_CDMI_DASH_CONTAINER’ was here
   52 |     BU_MIME_APPLICATION_CDMI_DASH_CONTAINER,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:896:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_CDMI_DASH_DOMAIN’
  896 |     BU_MIME_APPLICATION_CDMI_DASH_DOMAIN,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:53:5: note: previous definition of ‘BU_MIME_APPLICATION_CDMI_DASH_DOMAIN’ was here
   53 |     BU_MIME_APPLICATION_CDMI_DASH_DOMAIN,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:897:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_CDMI_DASH_OBJECT’
  897 |     BU_MIME_APPLICATION_CDMI_DASH_OBJECT,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:54:5: note: previous definition of ‘BU_MIME_APPLICATION_CDMI_DASH_OBJECT’ was here
   54 |     BU_MIME_APPLICATION_CDMI_DASH_OBJECT,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:898:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_CDMI_DASH_QUEUE’
  898 |     BU_MIME_APPLICATION_CDMI_DASH_QUEUE,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:55:5: note: previous definition of ‘BU_MIME_APPLICATION_CDMI_DASH_QUEUE’ was here
   55 |     BU_MIME_APPLICATION_CDMI_DASH_QUEUE,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:899:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_CU_DASH_SEEME’
  899 |     BU_MIME_APPLICATION_CU_DASH_SEEME,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:56:5: note: previous definition of ‘BU_MIME_APPLICATION_CU_DASH_SEEME’ was here
   56 |     BU_MIME_APPLICATION_CU_DASH_SEEME,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:900:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_DAVMOUNT_PLUS_XML’
  900 |     BU_MIME_APPLICATION_DAVMOUNT_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:57:5: note: previous definition of ‘BU_MIME_APPLICATION_DAVMOUNT_PLUS_XML’ was here
   57 |     BU_MIME_APPLICATION_DAVMOUNT_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:901:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_DOCBOOK_PLUS_XML’
  901 |     BU_MIME_APPLICATION_DOCBOOK_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:58:5: note: previous definition of ‘BU_MIME_APPLICATION_DOCBOOK_PLUS_XML’ was here
   58 |     BU_MIME_APPLICATION_DOCBOOK_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:902:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_DSSC_PLUS_DER’
  902 |     BU_MIME_APPLICATION_DSSC_PLUS_DER,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:59:5: note: previous definition of ‘BU_MIME_APPLICATION_DSSC_PLUS_DER’ was here
   59 |     BU_MIME_APPLICATION_DSSC_PLUS_DER,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:903:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_DSSC_PLUS_XML’
  903 |     BU_MIME_APPLICATION_DSSC_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:60:5: note: previous definition of ‘BU_MIME_APPLICATION_DSSC_PLUS_XML’ was here
   60 |     BU_MIME_APPLICATION_DSSC_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:904:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_ECMASCRIPT’
  904 |     BU_MIME_APPLICATION_ECMASCRIPT,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:61:5: note: previous definition of ‘BU_MIME_APPLICATION_ECMASCRIPT’ was here
   61 |     BU_MIME_APPLICATION_ECMASCRIPT,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/home/sumagnadas/github/brlcad_git/build1/include/bu/mime_types.h:905:5: error: redeclaration of enumerator ‘BU_MIME_APPLICATION_EMMA_PLUS_XML’
  905 |     BU_MIME_APPLICATION_EMMA_PLUS_XML,
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.....

i knew something like this would happen

view this post on Zulip Sumagna Das (Apr 23 2021 at 07:54):

any suggestion how to overcome this?

view this post on Zulip starseeker (Apr 23 2021 at 10:08):

You've got multiple definitions in the generated output looks like... I'd pick one, check where it's getting defined, and trace that back to see where it's coming from in the generated logic.

view this post on Zulip starseeker (Apr 23 2021 at 10:30):

A thought - what if we completely eliminate any notion of mime type typedefs, and instead make it all integer defines. The categories would become:

#define BU_MIME_UNKNOWN 0
#define BU_MIME_APPLICATION 1
#define BU_MIME_AUDIO 2
...

and the mime types would be one long list of defines:

#define BU_MIME_APPLICATION_ANDREW_DASH_INSET 1
#define BU_MIME_APPLICATION_APPLIXWARE 2
....

Then we define zero terminated static integer arrays or something similar to encode the context information:

static long BU_MIME_IMAGES[] = {
BU_MIME_IMAGE_PNG,
BU_MIME_IMAGE_JPG,
...
0
};

and a function long bu_mime_context( long mime_id) to walk the arrays and find the right context.

The only other functions we would need should be translators to/from strings, which we're already generating now.

This both eliminates the separate typedefs for each context, and allows us to assert categories in user code if we so desire.

view this post on Zulip starseeker (Apr 23 2021 at 10:43):

Then, on the gcv side, we change the plugin setup slightly.

On the GCV library side, we define a series of bit flag types that correspond to various geometry object output categories:

#define BINARY_OBJ 0x01
#define IMAGE_OBJ   0x02
#define  GEOM_OBJ  0x04
...

We have each plugin provide a function which takes two integers - a mime context and a mime type and returns an integer holding bit flags set to correspond to what that plugin can either write or create given that input.

The mime context argument could be set to either BU_MIME_UNKNOWN - in which case a plugin will decide on its own if it can handle a PNG image as image data, terrain (geometry) data, or both. If it can do both, it sets both bit flags in the return. If the caller does provide it a mime context (BU_MIME_MODEL, say) then it will only return - if it can do it- the GEOM_OBJ flag set.

Then, for a given pairing of inputs and outputs, we have a way forward. By default, if the user doesn't constrain the solution set, gcv will make a stab at determining the file mime type but will pass BU_MIME_UNKNOWN to the reader/writer plugins to get the full range of options. It will then look at the mime types returned from all the plugins and identify viable pairings. If either or both of the plugin and mime context interpretations are not unique, it will report the available options back to the user and request specification of either or all of a mime context interpretation, desired output object category, and reader/writer plugin to use. If, however, only one unique interpretation is found, then it doesn't have to ask anything and will try the only thing it can.

This allows conversion problems with unique potential solutions (3dm-g, for example) to simply proceed. Ambiguous cases (multiple plugins supporting STL or interpreting PNG as either terrain or an image object) will report the available options and give the user guidance on how to refine the problem.

view this post on Zulip starseeker (Apr 23 2021 at 10:44):

Theoretically, icv and gcv might collapse completely into just gcv...

view this post on Zulip starseeker (Apr 23 2021 at 10:57):

We may also want to add a .gcv defaults file where users can set plugin or interpretation defaults so they can avoid specifying things all the time (command line options would override the defaults file, but the defaults file could make things more automatic for "normal" use.)

view this post on Zulip Sumagna Das (Apr 23 2021 at 12:16):

the define method sounds good
we can work with that

view this post on Zulip Sumagna Das (Apr 23 2021 at 12:18):

it doesnt require any redefining of symbols/enums

view this post on Zulip Sumagna Das (Apr 23 2021 at 12:19):

the one thing i am havin problems understanding is the GCV part.

view this post on Zulip Sumagna Das (Apr 23 2021 at 12:20):

Sumagna Das said:

the one thing i am havin problems understanding is the GCV part.

so in the plugin file, there is a define part?
or is it on the api part?

view this post on Zulip Sumagna Das (Apr 23 2021 at 12:22):

plus the part about how we are going to name the inputs and outputs for the plugins.

view this post on Zulip starseeker (Apr 23 2021 at 12:23):

The GCV plugins provide hooks to the main gcv library. Right now (for example) there's a "rhino_can_read" function which takes the file and tests it. What we can try instead is a function that accepts the mime arguments in addition to the file - this allows the plugin to have more context when making its decisions about what it can/can't read.

view this post on Zulip starseeker (Apr 23 2021 at 12:25):

If, for example, the 3DM mime type was passed in and the context passed in was BU_MIME_MODEL, the rhino_can_read function would know to try the file and see if it can open it. However, if the context passed in was BU_MIME_IMAGE (i.e. the specific conversion path of interest is to treat the 3DM data as an image format) then rhino_can_read would report that it can't read the file. It only supports reading the 3DM format as geometry, not as an image.

view this post on Zulip starseeker (Apr 23 2021 at 12:27):

So the function would look something like:

static long
  rhino_can_read(long mime_context, long mime_type, const char *source_path)
  {
     if (mime_type != BU_MIME_MODEL_VND_RHINO)
         return 0;

     if (mime_context != BU_MIME_MODEL)
         return 0;

      int fv;
      ON_String mSC;
      ON_3dmProperties mprop;
      if (!source_path) return 0;
      FILE *fp = ON::OpenFile(source_path,"rb");
      if (!fp) return 0;
      ON_BinaryFile file(ON::on_read3dm,fp);
      if (!file.Read3dmStartSection(&fv, mSC)) return 0;
      if (!file.Read3dmProperties(mprop)) return 0;
      return GEOM_OBJ;
  }

view this post on Zulip starseeker (Apr 23 2021 at 12:31):

This gets at addressing the issue that was causing me mental indigestion earlier - how to deal with the situation where a tiff image might need to come into a .g as a terrain import or an image. Even a generic GEOM_OBJ return type might not be enough - we may need to encode certain supported BRL-CAD entity types as flags. An image, for example, could be a source for dsp terrain primitives or also for an extruded bitmap...

view this post on Zulip starseeker (Apr 23 2021 at 12:38):

But as a next step we can probably just see if that approach will work - if it does, more specificity just means defining additional contexts beyond BU_MIME_MODEL and BU_MIME_IMAGE for plugins to check for.

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:26):

starseeker said:

A thought - what if we completely eliminate any notion of mime type typedefs, and instead make it all integer defines. The categories would become:

#define BU_MIME_UNKNOWN 0
#define BU_MIME_APPLICATION 1
#define BU_MIME_AUDIO 2
...

and the mime types would be one long list of defines:

#define BU_MIME_APPLICATION_ANDREW_DASH_INSET 1
#define BU_MIME_APPLICATION_APPLIXWARE 2
....

Then we define zero terminated static integer arrays or something similar to encode the context information:

static long BU_MIME_IMAGES[] = {
BU_MIME_IMAGE_PNG,
BU_MIME_IMAGE_JPG,
...
0
};

and a function long bu_mime_context( long mime_id) to walk the arrays and find the right context.

The only other functions we would need should be translators to/from strings, which we're already generating now.

This both eliminates the separate typedefs for each context, and allows us to assert categories in user code if we so desire.

done the first two define parts

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:27):

now the left of the tasks are

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:29):

also
should i make the arrays in the mime_types.h file?

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:29):

or somewhere other would be much better?

view this post on Zulip starseeker (Apr 23 2021 at 20:43):

whatever you think makes sense - could be inside the generated bu_mime_context funtion

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:44):

ohk
so what would the function do exactly?

view this post on Zulip starseeker (Apr 23 2021 at 20:44):

So given an input, it would check a series of arrays to see which one (if any) contain that integer

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:45):

get an mime type id/value, walk all the arrays, find the right type
if available, return a string that will say which context it belongs to else BU_mime_unknown?

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:45):

Sumagna Das said:

get an mime type id/value, walk all the arrays, find the right type
if available, return a string that will say which context it belongs to else BU_mime_unknown?

is this roughly the way it will work?

view this post on Zulip starseeker (Apr 23 2021 at 20:46):

Roughly, yes - I'd return the mime integer, rather than a string - we can define a function to translate mime contexts to strings if we want that (user messages, etc.), but the integer itself is probably enough for most uses.

view this post on Zulip starseeker (Apr 23 2021 at 20:47):

My first cut at it would be to generate the per-mime-context arrays, then generate a NULL terminated array of pointers to those arrays.

view this post on Zulip starseeker (Apr 23 2021 at 20:48):

Then you iterate over the array-of-arrays, and iterate over each array's contents.

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:48):

starseeker said:

Roughly, yes - I'd return the mime integer, rather than a string - we can define a function to translate mime contexts to strings if we want that (user messages, etc.), but the integer itself is probably enough for most uses.

a function which returns a string would be handy for the message as you said

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:48):

starseeker said:

Then you iterate over the array-of-arrays, and iterate over each array's contents.

that sounds better

view this post on Zulip starseeker (Apr 23 2021 at 20:48):

I would just make a const char *bu_mime_context_str(long ctx) function

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:49):

currently i am trying to atleast get the part for arrays working
then make the array of pointers if it helps

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:50):

starseeker said:

I would just make a const char *bu_mime_context_str(long ctx) function

that i will keep for the endgame

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:50):

the main part is the one which returns the integer

view this post on Zulip starseeker (Apr 23 2021 at 20:50):

However you want to approach it. @Sean hasn't weighed in, and he may have other thoughts

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:51):

thats the problem right now

view this post on Zulip starseeker (Apr 23 2021 at 20:51):

You mean the big one to return the integer? Yes, that's the main logic.

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:51):

starseeker said:

You mean the big one to return the integer? Yes, that's the main logic.

yea

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:53):

foreach(context ${ACTIVE_TYPES})
  string(TOUPPER "${context}" c)
  set(mcstr "${mcstr}             if (mime_${context}(ext) != -1){\n")
  set(mcstr "${mcstr}                  return mime_${context}(ext);\n")
  set(mcstr "${mcstr}             }\n")
endforeach(context ${ACTIVE_TYPES})

i had this part before to iterate between all of the mime types

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:54):

do you think i could reuse this logic for this one in "the" function?

view this post on Zulip starseeker (Apr 23 2021 at 20:54):

you'll have to experiment - it'll most likely take a few iterations to arrive at a final design.

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:55):

will try to setup atleast the array part right now

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:55):

then move on to the function

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:55):

the function is nothing without the arrays

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:56):

but right now thinking whether it is better to put it with the mime_types.h file or in the mime.c file

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:56):

which one sounds better for keeping the array for the defines?

view this post on Zulip starseeker (Apr 23 2021 at 20:57):

If it were me I'd probably define the arrays as part of the function.

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:57):

ok

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:57):

lemme try then

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:58):

vs code just crashed out of nowhere :neutral:

view this post on Zulip starseeker (Apr 23 2021 at 20:58):

in the current mime.c I generated all the string to number and back mappings as static if checks, IIRC...

view this post on Zulip starseeker (Apr 23 2021 at 20:58):

You might give Ninja on windows a try... less overhead

view this post on Zulip starseeker (Apr 23 2021 at 20:59):

It should work - that's what our CI on github is using.

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:59):

starseeker said:

in the current mime.c I generated all the string to number and back mappings as static if checks, IIRC...

yea
all the functions are present in the mime.c file

view this post on Zulip Sumagna Das (Apr 23 2021 at 20:59):

starseeker said:

You might give Ninja on windows a try... less overhead

is ninja available in linux?

view this post on Zulip starseeker (Apr 23 2021 at 21:00):

Oh, sorry - I thought you meant visual studio. yes, ninja is primarily used on Linux

view this post on Zulip starseeker (Apr 23 2021 at 21:00):

That won't help you though if you're using vs code as your source editor

view this post on Zulip Sumagna Das (Apr 23 2021 at 21:00):

let me check though

view this post on Zulip Sumagna Das (Apr 23 2021 at 21:00):

i use the terminal inside VS code for building most of the time as i use a different build folder for this change or else normal building gets messed up

view this post on Zulip starseeker (Apr 23 2021 at 21:01):

/me uses vim most of the time, and Emacs when he must (DocBook editing usually).

view this post on Zulip Sumagna Das (Apr 23 2021 at 21:02):

starseeker said:

/me uses vim most of the time, and Emacs when he must (DocBook editing usually).

i heard that vim is a good one but havent tried yet because no time for learning new things :sweat:

view this post on Zulip Sumagna Das (Apr 23 2021 at 21:03):

have my 10th grade's exam coming next year

view this post on Zulip Sumagna Das (Apr 23 2021 at 21:41):

and one last thing.....should there be an auto and an unknown special for every category like "BU_MIME_IMAGE_AUTO", "BU_MIME_IMAGE_UNKNOWN" in every array?

view this post on Zulip Sumagna Das (Apr 23 2021 at 21:45):

right now, the arrays part is ready without those special ones including the array of arrays
now the only part that is left is the real logic which returns the integer for the right context/category

view this post on Zulip starseeker (Apr 23 2021 at 22:00):

Not sure about the unknowns - my thought right now is one generic unknown mime type is probably enough, unless we think of a use case.

view this post on Zulip Sumagna Das (Apr 24 2021 at 05:00):

ohk

view this post on Zulip Sumagna Das (Apr 24 2021 at 05:02):

right now, the only thing i am having a problem is that i can iterate thru the array of arrays but when it comes to the array containing the types, i have no such variable in the cmake file which can help me get the number of elements in each array

view this post on Zulip Sumagna Das (Apr 24 2021 at 05:04):

so do you know of any condition which can help me get each of the elements in the array

view this post on Zulip Sumagna Das (Apr 24 2021 at 05:04):

like for using while?

view this post on Zulip starseeker (Apr 24 2021 at 13:14):

I'm not 100% sure I follow, but you can build a counter in CMake if you need to so you can write out that information. I think it's the math() command...

view this post on Zulip Sumagna Das (Apr 24 2021 at 13:19):

would it be worth it for each array tho?

view this post on Zulip Sumagna Das (Apr 24 2021 at 13:20):

i thought that it might make it take more memory while generating the file :shrug:

view this post on Zulip Sumagna Das (Apr 24 2021 at 13:22):

right now, i just came with an idea. as the last element of the arrays will always be 0, we can put a while loop for *elem !=0.

view this post on Zulip Sumagna Das (Apr 24 2021 at 13:22):

how does that sound?

view this post on Zulip starseeker (Apr 24 2021 at 13:32):

Sounds good.

view this post on Zulip Sumagna Das (Apr 24 2021 at 20:22):

any idea how or where we can make an use of it?

view this post on Zulip Sumagna Das (Apr 24 2021 at 20:22):

the function is implemented

view this post on Zulip Sumagna Das (Apr 24 2021 at 20:59):

And also
In how many places we have to change the logic of a function to work with this define logic?

view this post on Zulip Sumagna Das (Apr 24 2021 at 21:01):

Except for the mime.c file

view this post on Zulip starseeker (Apr 25 2021 at 01:05):

You could try reworking a gcv plugin and the library to use the new setup, maybe starting with the 3dm (rhino) convertor and disabling the others.

view this post on Zulip Sumagna Das (Apr 25 2021 at 20:04):

starseeker said:

Then, on the gcv side, we change the plugin setup slightly.

On the GCV library side, we define a series of bit flag types that correspond to various geometry object output categories:

#define BINARY_OBJ 0x01
#define IMAGE_OBJ   0x02
#define  GEOM_OBJ  0x04
...

We have each plugin provide a function which takes two integers - a mime context and a mime type and returns an integer holding bit flags set to correspond to what that plugin can either write or create given that input.

The mime context argument could be set to either BU_MIME_UNKNOWN - in which case a plugin will decide on its own if it can handle a PNG image as image data, terrain (geometry) data, or both. If it can do both, it sets both bit flags in the return. If the caller does provide it a mime context (BU_MIME_MODEL, say) then it will only return - if it can do it- the GEOM_OBJ flag set.

Then, for a given pairing of inputs and outputs, we have a way forward. By default, if the user doesn't constrain the solution set, gcv will make a stab at determining the file mime type but will pass BU_MIME_UNKNOWN to the reader/writer plugins to get the full range of options. It will then look at the mime types returned from all the plugins and identify viable pairings. If either or both of the plugin and mime context interpretations are not unique, it will report the available options back to the user and request specification of either or all of a mime context interpretation, desired output object category, and reader/writer plugin to use. If, however, only one unique interpretation is found, then it doesn't have to ask anything and will try the only thing it can.

This allows conversion problems with unique potential solutions (3dm-g, for example) to simply proceed. Ambiguous cases (multiple plugins supporting STL or interpreting PNG as either terrain or an image object) will report the available options and give the user guidance on how to refine the problem.

this was one of the things you wanted with the gcv library?

view this post on Zulip Sumagna Das (Apr 25 2021 at 20:09):

if i follow this, there are some questions in my mind

view this post on Zulip Sumagna Das (Apr 25 2021 at 21:17):

one other question, how do i return both bit flags?

view this post on Zulip starseeker (Apr 25 2021 at 21:56):

There are tutorials online about bit flags and bit masks - see, for example, https://www.learn-c.org/en/Bitmasks

view this post on Zulip starseeker (Apr 25 2021 at 21:57):

https://www.codeproject.com/Articles/2247/An-introduction-to-bitwise-operators

view this post on Zulip starseeker (Apr 25 2021 at 21:58):

Basically the idea is you return a single number, and the on/off status of the individual bits is used to contain information.

view this post on Zulip starseeker (Apr 25 2021 at 21:59):

I tend to go with an unsigned long long to maximize the potential number of flags that can be set in a single number.

view this post on Zulip starseeker (Apr 25 2021 at 21:59):

As to how many flags we will need to define, that's one of the things that isn't fully clear yet.

view this post on Zulip starseeker (Apr 25 2021 at 22:00):

They'll be handled (set and checked) as bit masks (there are other examples in our code where we use such flags)

view this post on Zulip starseeker (Apr 25 2021 at 22:01):

So we return a single number, but the bit flags are used to encode multiple pieces of information within the single number.

view this post on Zulip starseeker (Apr 25 2021 at 22:03):

An unsigned long long will be (at least) 64 bits, so that gives us up to 64 flags within that single number.

view this post on Zulip starseeker (Apr 25 2021 at 22:04):

I would suggest making a small C or C++ program and exploring how those flags work, if you're unfamiliar with them.

view this post on Zulip Sumagna Das (Apr 26 2021 at 07:55):

starseeker said:

I would suggest making a small C or C++ program and exploring how those flags work, if you're unfamiliar with them.

it looks like i will have to do this to understand it

view this post on Zulip Sumagna Das (Apr 26 2021 at 07:56):

its a bit mind boggling

view this post on Zulip Sean (Apr 27 2021 at 04:21):

I'm late to the party, but I'd question the value of bitsets for typedefs, and they're fundamentally limited to the number of available bits. It'd have to go over 64 bits if we're talking the types themselves (or is this only for categories?), and solutions for that are typically obnoxious...

view this post on Zulip Sean (Apr 27 2021 at 04:25):

The usual reason for doing bit flags is for performance, which really isn't needed here. This whole system is primarily dealing with file identification, in I/O land (i.e., as slow as it gets). If the direction is to get a handle to an identifier, then we might as well directly adopt the mime-type classifier string-as-data and ditch all the API complexity.

view this post on Zulip Sean (Apr 27 2021 at 04:25):

That would greatly simplify things.

view this post on Zulip Sean (Apr 27 2021 at 04:27):

Apps/Libs could set "*" (i.e., mime unknown) or "model\*" (i.e., mime category 'model') etc.
Plugins could declare categories or specific types or sets of types (e.g., "model/*" and/or "text/plain").

view this post on Zulip Sean (Apr 27 2021 at 04:30):

Sumagna Das said:

right now, the only thing i am having a problem is that i can iterate thru the array of arrays but when it comes to the array containing the types, i have no such variable in the cmake file which can help me get the number of elements in each array

If you've created a fixed array at compile time, then you can determine the size with:
size_t length = sizeof(array) / sizeof(array[0]);

view this post on Zulip Sumagna Das (Apr 27 2021 at 07:02):

If I got that correctly, The bit flags are only for the categories and not for all the types.

view this post on Zulip Sumagna Das (Apr 27 2021 at 19:01):

Sean said:

Sumagna Das said:

right now, the only thing i am having a problem is that i can iterate thru the array of arrays but when it comes to the array containing the types, i have no such variable in the cmake file which can help me get the number of elements in each array

If you've created a fixed array at compile time, then you can determine the size with:
size_t length = sizeof(array) / sizeof(array[0]);

yea got this part working......

view this post on Zulip Sumagna Das (Apr 27 2021 at 20:06):

one thing i have to ask, should i work using the bit flags?

view this post on Zulip Sumagna Das (Apr 27 2021 at 20:06):

Sumagna Das said:

one thing i have to ask, should i work using the bit flags?

@Sean

view this post on Zulip Sumagna Das (Apr 28 2021 at 20:27):

@starseeker got the functions working with the extra arguments but how to use the returned bit flag tho?

view this post on Zulip Sumagna Das (Apr 28 2021 at 20:29):

right now, testing the syntax atleast thru the 3DM plugin. the other plugins are disabled for now.

view this post on Zulip Sumagna Das (Apr 28 2021 at 20:31):

Sumagna Das said:

starseeker got the functions working with the extra arguments but how to use the returned bit flag tho?

like what should i do with bit flags?
should i check for the output types?
should i send them to the user through a selection menu?

view this post on Zulip starseeker (Apr 28 2021 at 21:21):

So my thinking, for what it's worth, was to do the following:

Have the gcv executable support an option to specify the processing mode: --image for example to treat a .tiff file as an image, and --geom to force processing as geometry.

What should happen if you feed gcv the .3dm file and tell it to process it as an image, would be for it to query the plugin with the mime context set to BU_MIME_IMAGE. The plugin, in turn, should recognize that it can't process a 3dm file as an image, and return nothing.

With the --geom option set, the context would be set to BU_MIME_MODEL, and without it the context would be BU_MIME_UNKNOWN. In either of those cases the plugin would then report it could handle the 3dm input successfully, and return a value with the GEOM bit flag set. The gcv executable would then know it had at least one conversion path.

This gets more interesting with an image format like .png. Since it could be interpreted as either an image or terrain data, if we don't supply either --image or --geom to introduce a context both a plugin to read pngs and generate .g files containing those images and the gdal plugin producing geometry files will report they can handle the PNG file. If --image or --geom are supplied, and the prospective plugins return values with their respective bit flags set, gcv can select the plugin that not only handles PNG but handles it as the desired type of information. If neither --image or --geom are supplied and the PNG file is fed to gcv, we don't know what to do with it - there are multiple valid options. In that case gcv can use the return codes from the plugin tests to report the available options. Something like:

gcv terrain.png outfile.g

Error - multiple conversion alternatives found:

Image conversions (--image):
     png2gtexture  - Import PNG image as BRL-CAD texture file

Geometry conversions (--geom):
    gdal            - Import PNG image as DSP terrain data

To actually get the gdal conversion path in this scenario, the command would be either:

gdal --geom terrain.png outfile.g

or

gda --plugin=gdal terrain.png outfile.pn

view this post on Zulip starseeker (Apr 28 2021 at 21:26):

If a plugin could be capable of producing either image or geometry outputs from the same input (let's say hypothetically the gdal plugin was also able to produce a texture as well as a terrain file) it would return with both the image and geom bit flags set. In that case, even if it was the only plugin that could handle the format, gcv would know it needs additional context before the plugin can proceed to do a conversion:

gcv --plugin gdal terrain.png output.png

Error:  plugin supports both image and geometry conversion paths:

   image:   produces a .g texture object
    geom:   produces a dsp terrain file

The terrain path would then become:

gcv --plugin gdal --geom terrain.png output.png

view this post on Zulip Sumagna Das (Apr 29 2021 at 21:05):

got the options --geom and --image working somewhat. currently it just passes the BU_MIME_MODEL and BU_MIME_IMAGE defs respectively.

view this post on Zulip Sumagna Das (May 01 2021 at 19:46):

i just want to ask.....is the returned bit flag mainly going to be used to check if there are options for plugins for a certain file?

view this post on Zulip Sumagna Das (May 01 2021 at 21:14):

and i am a little bit confused right now........i tried to go for it and couldnt find out where it is checking for the types and using the function *_can_read

view this post on Zulip Sumagna Das (May 01 2021 at 21:15):

so it might help if someone can get me thru this confusion

view this post on Zulip starseeker (May 01 2021 at 22:19):

My idea (which @Sean may shoot down - it's just a notion) was to use the return bit flag to determine what sorts of input/output a given importer/exporter can handle.

If I'm following this correctly (it's been a while) struct gcv_filter in include/gcv/api.h has a callback function data_supported - I think that's where the can_read functions get hooked in. To make sure, try stepping through a gcv conversion in gdb and breaking on the can_read function in question - the backtrace should tell you how it's being called.

view this post on Zulip starseeker (May 01 2021 at 22:44):

Here's another stab at how I envisioned this working. Given the conversion input:

gcv file.png file.g

The initial filename based characterizations would be:

mime-characterize png -> BU_MIME_IMAGE, BU_MIME_IMAGE_PNG
mime-characterize g -> BU_MIME_MODEL, BU_MIME_MODEL_VND_BRLCAD_G

Step 1a: ask all reader plugins if they can handle BU_MIME_UNKNOWN, BU_MIME_IMAGE_PNG and collect responses
Step 1b: ask all writer plugins if they can handle BU_MIME_UNKNOWN, BU_MIME_MODEL_VND_BRLCAD_G and collect responses

Step 2: for any plugins that answer non-zero, characterize their responses as being BU_MIME_IMAGE, BU_MIME_MODEL, or both. The possibilities for both readers and writers are:

  1. 1 plugin, with BU_MIME_MODEL as its response.
  2. 1 plugin, with BU_MIME_IMAGE as its response.
  3. 2+ plugins, with BU_MIME_MODEL as their response.
  4. 2+ plugins, non-BU_MIME_MODEL types.
  5. Multiple types from same plugin
  6. Multiple types, multiple plugins

Step 3: Find matching reader and writer context pairings that offer conversion paths. For our hypothetical example where gdal can read a PNG both as image and terrain data, we would get the following valid conversion path pairings:

(BU_MIME_IMAGE,gdal)->(BU_MIME_IMAGE,g)
(BU_MIME_MODEL,gdal)->(BU_MIME_MODEL,g)

This situation is thus ambiguous - both the reader and writer have multiple valid interpretations of the data. The user will have to provide more context (for example --geom to specify our desired conversion context is BU_MIME_MODEL) to resolve the ambiguity.

view this post on Zulip Sumagna Das (May 02 2021 at 05:44):

starseeker said:

My idea (which Sean may shoot down - it's just a notion) was to use the return bit flag to determine what sorts of input/output a given importer/exporter can handle.

If I'm following this correctly (it's been a while) struct gcv_filter in include/gcv/api.h has a callback function data_supported - I think that's where the can_read functions get hooked in. To make sure, try stepping through a gcv conversion in gdb and breaking on the can_read function in question - the backtrace should tell you how it's being called.

for some reason, the can_read function wasnt being called when i tried putting it thru gdb. thats why i asked for where it is being called. IIRC in the code the only place where the function was called was in a condition and one of other conditions in that if statement was if (emt == BU_MIME_MODEL_AUTO && ......) and because of that the function is not being called for some reason.

view this post on Zulip starseeker (May 02 2021 at 19:05):

@Sumagna Das you may have to alter the gcv logic flows somewhat - they've always been a bit haphazard, so if something else makes sense to you feel free to give it a go.

view this post on Zulip Sean (May 05 2021 at 05:15):

@Sumagna Das how's it going? any luck deciphering the logic flow?

view this post on Zulip Sean (May 05 2021 at 05:23):

While I'm not convinced there's usability value in having categoric flags, I'm not terribly opposed. More concerned where this is heading. I think the user isn't necessarily going to know what a particular input plugin was coded to receive or what a particular filter plugin is expecting. So they're probably going to have to hunt or try them all to see what they do and that won't be a good user experience.

view this post on Zulip Sean (May 05 2021 at 05:31):

There's also an issue with many formats that have even more interpretations beyond image or geometry ... could also be data, could be a container format, could be a single format that holds multiple interpretations or multiple representations simultaneously. It's messy and categorization works against us.

view this post on Zulip Sean (May 05 2021 at 05:40):

As mentioned earlier, I'd think it'd be beneficial to focus on specific issues, such as getting vol plugin to simply work, and address the problems that specific case provokes. That's not to suggest undoing or changing anything that's been done on the pull request, but to wrap it up and get back to considering how that vol plugin works now and talking about that usability.

i.e., how it is discovered and how is it invoked unambiguously with a starting premise that a user begins with a naive invocation such as "gcv input.png output.g"

view this post on Zulip Sumagna Das (May 08 2021 at 19:58):

Sean said:

Sumagna Das how's it going? any luck deciphering the logic flow?

somewhat
havent been able to play with it in the last few days because of studies and dont think i will be able to do that in the next few days
so not much luck you can say

view this post on Zulip Sumagna Das (May 08 2021 at 20:01):

Sean said:

As mentioned earlier, I'd think it'd be beneficial to focus on specific issues, such as getting vol plugin to simply work, and address the problems that specific case provokes. That's not to suggest undoing or changing anything that's been done on the pull request, but to wrap it up and get back to considering how that vol plugin works now and talking about that usability.

i.e., how it is discovered and how is it invoked unambiguously with a starting premise that a user begins with a naive invocation such as "gcv input.png output.g"

thats actually done
i had that on sideby in a git stash so i can put all of the work right now into another stash, pop the stash which contains the vol plugin work and with some minor changes, voila! the plugin and the initial work for the GCV rework is done in the pull request.

view this post on Zulip starseeker (May 08 2021 at 20:12):

Sean said:

While I'm not convinced there's usability value in having categoric flags, I'm not terribly opposed. More concerned where this is heading. I think the user isn't necessarily going to know what a particular input plugin was coded to receive or what a particular filter plugin is expecting. So they're probably going to have to hunt or try them all to see what they do and that won't be a good user experience.

The user won't know what the plugins can do or expect - that's the idea of the proposed scheme, to have the plugins themselves tell gcv what they can and can't do, and have gcv solve the problem of what combinations constitute potentially viable conversion paths. If the path solution is not unique, gcv then presents the viable paths and how to invoke them to the user.

view this post on Zulip starseeker (May 08 2021 at 20:18):

Sean said:

There's also an issue with many formats that have even more interpretations beyond image or geometry ... could also be data, could be a container format, could be a single format that holds multiple interpretations or multiple representations simultaneously. It's messy and categorization works against us.

If we've got inputs that are fundamentally that messy (not all of them are, but I'm sure some are) then I see no alternative other than analyzing them to find the viable interpretations and reporting them back to the user with instructions for how to select the interpretation they want. That means we need some universal language in which to communicate those capabilities and options (data, image, geometry, video, etc.) The set of categoric data possibilities must ultimately be finite in order to be implementable, and for our problems there are usually just a few big ones (image, geometry, etc.) - hence my thinking that we could use the bit flag to communicate the viable options back from a plugin.

view this post on Zulip Sumagna Das (May 09 2021 at 18:42):

Sumagna Das said:

Sean said:

As mentioned earlier, I'd think it'd be beneficial to focus on specific issues, such as getting vol plugin to simply work, and address the problems that specific case provokes. That's not to suggest undoing or changing anything that's been done on the pull request, but to wrap it up and get back to considering how that vol plugin works now and talking about that usability.

i.e., how it is discovered and how is it invoked unambiguously with a starting premise that a user begins with a naive invocation such as "gcv input.png output.g"

thats actually done
i had that on sideby in a git stash so i can put all of the work right now into another stash, pop the stash which contains the vol plugin work and with some minor changes, voila! the plugin and the initial work for the GCV rework is done in the pull request.

i had pushed the vol plugin changes alongside the changes for flattening the mime namespace. review it when you can

view this post on Zulip Sean (May 12 2021 at 05:38):

starseeker said:

The user won't know what the plugins can do or expect - that's the idea of the proposed scheme, to have the plugins themselves tell gcv what they can and can't do, and have gcv solve the problem of what combinations constitute potentially viable conversion paths. If the path solution is not unique, gcv then presents the viable paths and how to invoke them to the user.

I agree the user won't know, but for that same reason they won't necessarily know whether -image or -data or -model or whatever taxonomy we come up with is appropriate. It's still not unambiguous what that means if the user specifies a png file with a category flag. It turns into "try them all and see what they do". It's compounded by the fact that category flags attempt to characterize an input or/and output homogeneously which isn't necessarily true or even a common case.

The resulting workflow sounds like a problematic UX to me.. So much so that I think we're better off focusing on declarative and getting that UX right first.. It's needed no matter what. Let's keep it simple. We really need to resist overarchitecting as simplicity will be central to any external adoption.

view this post on Zulip Sean (May 12 2021 at 05:57):

starseeker said:

If we've got inputs that are fundamentally that messy (not all of them are, but I'm sure some are) then I see no alternative other than analyzing them to find the viable interpretations and reporting them back to the user with instructions for how to select the interpretation they want.

Agreed!

That means we need some universal language in which to communicate those capabilities and options (data, image, geometry, video, etc.)

Sort of! :)

I think that's the leap to a particular solution implementat that I don't think is demonstrated. The universal language couple be plain english. If there are three plugins that can handle an input, we could simply itemize them with a description and let the user pick based on that info. In this particular instance, the user would see something like:

$ gcv image.png file.g
 Multiple plugins read PNG input.  Please select the one most appropriate with the --input=[label] option:
    gdal: Reads image and data files typically representing terrain creating height field (DSP) geometry.
    png-to-vol: Reads PNG format image files creating volumetric (VOL) geometry.
    magick: Reads multiple image file formats.

So then the user can decide which seems most appropriate and issue:

$ gcv --input=png-to-vol image.png file.g

It's simple, discoverable, and doesn't require taxonomy awareness other than what the plugins declare. The user may still try all of them, but it'll be in the context of a plugin's immediate description and other available plugins. We can later look into user preferences for default handlers or auto-pathing.

view this post on Zulip Sean (Mar 06 2024 at 16:59):

@Christopher So the next logical question I guess is what is needed to make assetimport prioritized over the other tinygltf method. Could just remove the other method since it's crashing if the other works, or does it handle text gltf better in some regard? Otherwise that's a design issue that needs to be sorted out - how to have smart defaulting.

view this post on Zulip Christopher (Mar 06 2024 at 17:03):

well, if it's just a matter of wanting it to prioritize assetimport over tinygltf, we just need to recognize it as the default 'mime type'. As of yet, gcv isn't advanced enough have smart defaulting or really any notion fallbacks; Only the hard-set default, anything else is up to the user to manually specify

view this post on Zulip Christopher (Mar 06 2024 at 17:03):

as for why it's crashing or if one is preferable over the other.. I'm not sure

view this post on Zulip starseeker (Mar 06 2024 at 17:54):

I'd vote for removing tinygltf in favor of assetimport, unless there's something the former can handle that the latter can't.

view this post on Zulip Sean (Mar 06 2024 at 18:25):

I think one of us will have to spend a few minutes looking at the implementations to figure that out. I don't recall the one in gcv being different than the gltf-g but there's clearly some difference or change. Looking at the commits, maybe a casualty of refactoring errors.

I naively assumed gcv was only using assetimport as I'd just ran "gcv file.glb file.g". Either way, I do think the default should be made to work, so if assetimport's working I think that's strong enough motivation to default to it over the gltf plugin. Can schedule them and gltf-g for review in the next minor. Maybe do a quick walkthrough.


Last updated: Jan 09 2025 at 00:46 UTC