Re: [Gimp-developer] Re: new-xcf

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

Christopher Curtis <ccurtis@xxxxxxxxxxx> writes:

> I would reiterate what I said, but you quoted it.  "fully parseable by
> XML parsers up until the first NULL".  I'm not trying to jam image
> data into an XML format - simply prepending an XML header and using
> NULL as a separator.  This means you can cat the file and know exactly
> what's there.  Or you can open it in notepad (maybe make it NULL, ^Z
> for Windows people...)  "file" will be able to readily identify the
> individual formats, and people could even use dd to extract the layers.

But you couldn't use any generic XML tools like validators or XSL
transformations. If we go for XML we should really make sure that we
make it proper XML, otherwise XML doesn't make sense at all. We could
then as well go for a sexp syntax. Actually the latter would be a lot
easier to implement since we could build on the established GimpConfig
framework.

>> Is there a special reason you dislike the idea of using an archive
>> instead of a single XML file? I thought we would have been past this
>> point already...
>
> I just don't see using another archive format as giving you
> anything. So say you use ZIP or JAR or TAR or AR: you still have to
> unpack (and possibly decompress) the thing just to find out what's
> in it.

You don't have to unpack the whole archive and you can use existing
widely-available tools to extract the parts you need.

> OTOH, any program that can open a file can read the XML header
> here, even if they don't parse it, it's still human readable.  And
> this lets you do your fancy compression-based-on-data-type instead of
> generic-text-compression over each layer or the whole archive.  If you
> want something fast, you can leave compression off and modify the data
> directly on disk without having to unpack/pack, as long as you stay
> within limits (ie: you can paint on a layer or move the layer around,
> but not add a new layer or change the bit-depth, and you just have to
> munmap() that section).  This makes it easy to have specialized
> external tools that manipulate layer data without all the GIMP
> overhead, easily scriptable, etc...

You can do all this with an uncompressed archive as I suggested.


Sven

[Index of Archives]     [Video For Linux]     [Photo]     [Yosemite News]     [gtk]     [GIMP for Windows]     [KDE]     [GEGL]     [Gimp's Home]     [Gimp on GUI]     [Gimp on Windows]     [Steve's Art]

  Powered by Linux