Re: [fossil-users] Binary file merge

2011-09-21 Thread Jeff Slutter

On 9/21/2011 3:50 PM, Stephan Beal wrote:
i'm trying to figure out if that's doable with a minor tweak to the 
current code, but i just don't see it (but i'm not at all familiar 
with the diff/merge code). The first problem i see with this change 
now is that the is-it-binary determination is made one or two levels 
too deep for us to respond by launching gmerge. gmerge is not launched 
until after blob_diff() returns (and reports success). gmerge takes 4 
options: pivot original merge other. Fossil doesn't have all of those 
if blob_merge() fails, so it cannot call gmerge. In order to fix this 
it would have to figure out in advance if the object is binary and... 
and do what? We don't have a binary diff algo, AFAIK.





If that's the case than I too would vote for a 'gmerge' command. Soon I 
will be doing the exact same thing as Tomek, where I want to handle 
merging of my own binary data. If necessary, when that time comes, I can 
look into implementing the command if someone more knowledgeable about 
that code doesn't beat me to it first :)


Barring that, and not looking at the code right now, there could be a 
binary diff algo in Fossil that just reports a "Failed: Can not merge 
binary files" so if there is no user configured merge tool set, it still 
ends up with the same results.

___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Binary file merge

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 9:08 PM, Tomek Kott  wrote:

> As I see it, fossil doesn't need to know what the binary file is...it just
> needs to call the external program. If the program can't handle it, then
> presumably it would return an error anyway, and hence the same error message
> would come out...Am I missing something?
>

That makes sense to me.


> Maybe what I'm really asking for is for a "fossil gmerge" command that
> would work the same as the fossil "gdiff" command. CUrrently, fossil has no
> problem using gdiff on binary files.
>

i'm trying to figure out if that's doable with a minor tweak to the current
code, but i just don't see it (but i'm not at all familiar with the
diff/merge code). The first problem i see with this change now is that the
is-it-binary determination is made one or two levels too deep for us to
respond by launching gmerge. gmerge is not launched until after blob_diff()
returns (and reports success). gmerge takes 4 options: pivot original merge
other. Fossil doesn't have all of those if blob_merge() fails, so it cannot
call gmerge. In order to fix this it would have to figure out in advance if
the object is binary and... and do what? We don't have a binary diff algo,
AFAIK.

At least that's my understanding of it.

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] any interest in integrating jimtcl w/fossil?

2011-09-21 Thread Ingo Koch
On 09/21/11 20:16, Martin S. Weber wrote:
> Absolutely. Rest assured, I do:
>
> On 09/20/11 15:00, Martin S. Weber wrote:
> > Of course if you're an IDE person, you'll
> > appreciate easier integration with, say, the behemothian eclipse, the
> > leviathan netbeans, the Zizian IDEA or the all-encompassing emacs.
>
> Sorry I forgot to mention the humongous VisualXXX ;)
>
LOL, sorry that I missed the mentioned post. :-)

Regards,
Ingo

___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Binary file merge

2011-09-21 Thread Tomek Kott
To be clear, I'm not saying that fossil needs to handle the binary merge.
That's why the external program is there. The user (who would generically
know what kind of binary files are used in the repo) provides a shell script
for the gmerge command. Fossil calls gmerge (if present) when there is a
binary file (or a merge that goes haywire). The shell script goes through
and decides the merge tool to use (for my case, lvmerge for the labview
code) in the correct format (lvmerge "%baseline" "%original" "%merge"
"%output"). In my case, this repository only handles these kinds of files,
so instead of the shell script, I can call lvmerge directly.

As I see it, fossil doesn't need to know what the binary file is...it just
needs to call the external program. If the program can't handle it, then
presumably it would return an error anyway, and hence the same error message
would come out...Am I missing something?

Maybe what I'm really asking for is for a "fossil gmerge" command that would
work the same as the fossil "gdiff" command. CUrrently, fossil has no
problem using gdiff on binary files.

Tomek

On Wed, Sep 21, 2011 at 2:46 PM, Stephan Beal  wrote:

> On Wed, Sep 21, 2011 at 8:42 PM, Tomek Kott  wrote:
>
>> Then can I put in a feature request for gmerge to support binary file
>> merging? With the assumption that the user will (through a system dependent
>> method, like a shell script) call the appropriate binary file merger for the
>> binary file type passed in? That would make my (merging) life much easier. I
>> think that's the way that the diff command works currently.
>>
>
> IIRC (but i won't promise that i do!), this discussion came up a few years
> ago and the general opinion was (again, IIRC) that a binary merge is not
> generically possible. To merge contents of binary files the merging program
> has to understand their structure. e.g. i can't just (via a generic algo)
> replace 17 bytes of a ZIP file (binary file) with 21 (or 5 or N) bytes
> brought in by a merge because i'll corrupt it. The internal zip header's
> idea of that field is now wrong (or i might have overwritten part of that
> field via the merge). The same applies to any non-random binary data (but
> who's versioning random data?).
>
> --
> - stephan beal
> http://wanderinghorse.net/home/stephan/
>
> ___
> fossil-users mailing list
> fossil-users@lists.fossil-scm.org
> http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users
>
>
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Binary file merge

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 8:42 PM, Tomek Kott  wrote:

> Then can I put in a feature request for gmerge to support binary file
> merging? With the assumption that the user will (through a system dependent
> method, like a shell script) call the appropriate binary file merger for the
> binary file type passed in? That would make my (merging) life much easier. I
> think that's the way that the diff command works currently.
>

IIRC (but i won't promise that i do!), this discussion came up a few years
ago and the general opinion was (again, IIRC) that a binary merge is not
generically possible. To merge contents of binary files the merging program
has to understand their structure. e.g. i can't just (via a generic algo)
replace 17 bytes of a ZIP file (binary file) with 21 (or 5 or N) bytes
brought in by a merge because i'll corrupt it. The internal zip header's
idea of that field is now wrong (or i might have overwritten part of that
field via the merge). The same applies to any non-random binary data (but
who's versioning random data?).

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Binary file merge

2011-09-21 Thread Tomek Kott
Then can I put in a feature request for gmerge to support binary file
merging? With the assumption that the user will (through a system dependent
method, like a shell script) call the appropriate binary file merger for the
binary file type passed in? That would make my (merging) life much easier. I
think that's the way that the diff command works currently.

Thanks,

Tomek

On Wed, Sep 21, 2011 at 2:35 PM, Stephan Beal  wrote:

> On Wed, Sep 21, 2011 at 8:16 PM, Tomek Kott  wrote:
>
>> I guess the question is, does fossil even attempt to launch the gmerge
>> tool when merging binary files?
>>
>>
> The code says...
>
> The merge command ends up calling merge_3way(), which does:
>
> zGMerge = db_get("gmerge-command", 0);
> if( zGMerge && zGMerge[0] ){
> ... go run gmerge ...
> }
>
> The error string you report is not triggered until after merge_3way()
> returns, and only if merge_3way() returns <0. merge_3way() returns <0 if
> blob_merge() returns <0, so, which leads us to blob.c...
>
> blob_merge() says:
>
> ** The return is 0 upon complete success. If any input file is binary,
> ** -1 is returned and pOut is unmodified.  If there are merge
>
> So it seems that binary merges are not supported at all (at least that's
> how i interpret it).
>
> --
> - stephan beal
> http://wanderinghorse.net/home/stephan/
>
> ___
> fossil-users mailing list
> fossil-users@lists.fossil-scm.org
> http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users
>
>
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Binary file merge

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 8:16 PM, Tomek Kott  wrote:

> I guess the question is, does fossil even attempt to launch the gmerge tool
> when merging binary files?
>
>
The code says...

The merge command ends up calling merge_3way(), which does:

zGMerge = db_get("gmerge-command", 0);
if( zGMerge && zGMerge[0] ){
... go run gmerge ...
}

The error string you report is not triggered until after merge_3way()
returns, and only if merge_3way() returns <0. merge_3way() returns <0 if
blob_merge() returns <0, so, which leads us to blob.c...

blob_merge() says:

** The return is 0 upon complete success. If any input file is binary,
** -1 is returned and pOut is unmodified.  If there are merge

So it seems that binary merges are not supported at all (at least that's how
i interpret it).

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] any interest in integrating jimtcl w/fossil?

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 8:12 PM, Ingo Koch  wrote:

> Please keep in mind that such an API should not only help implementing
> language
> bindings for fossil but should also support tool makers.
>

We're all agreed on the many potential benefits, i think. The only hurdle is
the size of the task. It would be a major overhaul. That's not to discount
the idea - i'm all for it. i did in fact start to do this way back in 2008,
but quickly found that fossil's use of exit() as an error handling strategy
(which makes sense in a standalone app) was just the first of several big
worms i'd have to deal with.

An other thing:
> Seeing how much fossil developer related traffic currently is on the
> mailing
> list, maybe it is time to setup a new fossil-deve...@lists.fossil-scm.org?
>

Richard suggested that last week, but i don't think he's gotten around to it
yet. For the sake of the non-dev users, who are certainly sick of my chatter
by now, i hope he (or someone else with admin access? Bueler?) finds some
time for it.

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] any interest in integrating jimtcl w/fossil?

2011-09-21 Thread Martin S. Weber

On 09/21/11 14:12, Ingo Koch wrote:

On 09/20/11 15:53, Martin S. Weber wrote:

On 09/20/11 19:20, Steve Bennett wrote:

It is the interface to fossil which is important.


Yep. That's where step #1 comes in - librarization of fossil. Luckily I'll
have time for that (at least rounding up an API suggestion) next week.


Please keep in mind that such an API should not only help implementing language
bindings for fossil but should also support tool makers.


Absolutely. Rest assured, I do:

On 09/20/11 15:00, Martin S. Weber wrote:
> Of course if you're an IDE person, you'll
> appreciate easier integration with, say, the behemothian eclipse, the
> leviathan netbeans, the Zizian IDEA or the all-encompassing emacs.

Sorry I forgot to mention the humongous VisualXXX ;)

Regards,

-Martin
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


[fossil-users] Binary file merge

2011-09-21 Thread Tomek Kott
Hi folks,

I use fossil for some LabView development (among other dev work). For those
not familiar with it, it's a graphical programming environment, and the
files are binary. That in itself isn't a big deal. Especially because we're
provided with a merge tool. I've tested out the merge command I pass I set
up in fossil (for gmerge):

lvmerge "%baseline" "%original" "%merge" "%output"

However, when I go to merge two branches, fossil just says "* Cannot
merge binary file Measurements/Resistance/DC/Get Resistance.vi" without
launching the merge tool.

I guess the question is, does fossil even attempt to launch the gmerge tool
when merging binary files?

Thanks,

Tomek
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] any interest in integrating jimtcl w/fossil?

2011-09-21 Thread Ingo Koch
On 09/20/11 15:53, Martin S. Weber wrote:
> On 09/20/11 19:20, Steve Bennett wrote:
>> It is the interface to fossil which is important.
>
> Yep. That's where step #1 comes in - librarization of fossil. Luckily I'll
> have time for that (at least rounding up an API suggestion) next week.

Please keep in mind that such an API should not only help implementing language
bindings for fossil but should also support tool makers.
I'm working on a C# library to use fossil commands and a Windows GUI for fossil
(with the goal of Visual Studio integration) and I really miss a library like
the one that exists for SQLite.
Implementing tools around fossil would be so much easier if a library would be
available.

An other thing:
Seeing how much fossil developer related traffic currently is on the mailing
list, maybe it is time to setup a new fossil-deve...@lists.fossil-scm.org ?
I think it would make sense to split because users looking for answers regarding
their day to day usage problems and not being directly interested in development
of fossil should not be bothered with development topics. Maybe someone of the
active developers asks Richard to set up a new list?

Regards,
Ingo


___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] binary in JSON: maybe there is some hope...

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 4:05 PM, Stephan Beal  wrote:

> From what i've read, his proposal is just that - to encode (as a string)
> non-
>

It turns out i completely misunderstood what he's doing there. He's encoding
the JSON itself as binary, as opposed to encoding binary data in JSON.

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


[fossil-users] RFC: JSON error reporting conventions

2011-09-21 Thread Stephan Beal
Hi, all!

Currently the JSON API reports app-level errors by setting a resultCode
property to a string in the form FOSSIL- (==4-digit,
left-zero-padded decimal integer). i used that because i already had code
which did it and it works well in the project i stole that from. While
tinkering with adding "non-fatal warnings" support i'm trying out plain
integer values (the  part of FOSSIL-) instead.

So the different looks like:

resultCode: "FOSSIL-1234"
vs
resultCode: 1234

Has anyone got any strong arguments in favour of one or the other? i'm
tending now towards the second form, and the only reason i haven't done it
already is because the first form is used in the docs so much ;).

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Feature request: edit files via web interface

2011-09-21 Thread Bill Burdick
On Wed, Sep 21, 2011 at 11:10 AM, Stephan Beal wrote:

> On Wed, Sep 21, 2011 at 5:59 PM, Bill Burdick wrote:
>
>> back through a server to get it.  The data scheme essentially allows a
>> client to emulate a web server for itself (note the mime-type in the
>> example).
>>
>
> Thank you for the explanation. Are data URLs always (or normally)
> base64-encoded or do they allow arbitrary encodings? (i assume the latter
> since the URL contains the encoding name?) If data URLs most commonly use
> one format or another, i would strongly prefer to use that same format for
> transferring binary over JSON (simply via "portability via ubiquity"
> reasons).
>

No problem!  It looks like you can choose base-64 or ascii (with %-escaped
hex octets).  This covers all of the details:
http://en.wikipedia.org/wiki/Data_Uri


Bill
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Feature request: edit files via web interface

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 5:59 PM, Bill Burdick wrote:

> back through a server to get it.  The data scheme essentially allows a
> client to emulate a web server for itself (note the mime-type in the
> example).
>

Thank you for the explanation. Are data URLs always (or normally)
base64-encoded or do they allow arbitrary encodings? (i assume the latter
since the URL contains the encoding name?) If data URLs most commonly use
one format or another, i would strongly prefer to use that same format for
transferring binary over JSON (simply via "portability via ubiquity"
reasons).

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Feature request: edit files via web interface

2011-09-21 Thread Bill Burdick
On Wed, Sep 21, 2011 at 10:43 AM, Stephan Beal wrote:

> On Wed, Sep 21, 2011 at 5:27 PM, Bill Burdick wrote:
>
>> Maybe this is obvious, but a client-side editor could use data-scheme URIs
>> to display intermediately edited data before you commit it to Fossil.
>>
>
> It wasn't obvious to me, certainly. Naively i will ask: would that provide
> any benefit to that over e.g. base64-encoding to an arbitrary JSON field?
> The client has the binary data, so how/where he intends to encode it to
> (data URL or in the request JSON) is pretty much up to him. Or am i missing
> the point of the proper use of data urls?
>

The "data" scheme is for actually displaying the binary data, like an image,
in a client.  Displaying an image in a client is easy if the data came as a
stand-alone HTTP document (like as the source of an image element) but if
you get an image as part of a stream, like inside a JSON response, and you
want to display it in a browser using an image tag or a canvas, you need a
URL for that data and that's where the "data" scheme comes in.  It allows
you to provide that data in-line, rather than as an HTTP request, so you can
construct a data URI from the data you got from JSON.  That means you can
process the image in the client and display the result without having to go
back through a server to get it.  The data scheme essentially allows a
client to emulate a web server for itself (note the mime-type in the
example).


Bill
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Feature request: edit files via web interface

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 5:27 PM, Bill Burdick wrote:

> Maybe this is obvious, but a client-side editor could use data-scheme URIs
> to display intermediately edited data before you commit it to Fossil.
>

It wasn't obvious to me, certainly. Naively i will ask: would that provide
any benefit to that over e.g. base64-encoding to an arbitrary JSON field?
The client has the binary data, so how/where he intends to encode it to
(data URL or in the request JSON) is pretty much up to him. Or am i missing
the point of the proper use of data urls?

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Feature request: edit files via web interface

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 5:18 PM, Bill Burdick wrote:

> 
>

That's very good news because it (possibly) means that many JSON-consuming
clients will (probably) provide base64 en/decoding APIs so that clients can
construct/destruct these.

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Feature request: edit files via web interface

2011-09-21 Thread Bill Burdick
On Wed, Sep 21, 2011 at 10:18 AM, Bill Burdick wrote:

> On Tue, Sep 20, 2011 at 4:22 AM, Stephan Beal wrote:
>
>> On Tue, Sep 20, 2011 at 1:38 AM, Joshua Paine wrote:
>>
>>> On 9/19/2011 7:15 PM, Stephan Beal wrote:
>>>
 and JS cannot natively deal with binary data (that's coming in v5 or
>>>
>>>  whatever new version is coming soon).

>>>
>>> Standard javascript doesn't have this ability yet, but individual impl
>>> have relevant capabilities. E.g., privileged JS in XUL has access to files
>>> and can get base64 strings from them, and the canvas element has a toDataURL
>>> method that returns base64 encoded data plus a tiny amount of metadata.
>>
>>
>> The JS version accompanying HTMLv5 (i don't remember the version number)
>> contains some support for binary data. Some browsers have already started
>> implementing this and some apps already use it (e.g. gmail).
>>
>> So the option for binary data certainly can't be ruled out altogether.
>> OTOH, while JS is expected to (==i expect) be the primary client, there will
>> likely be other platforms out there for which base64 is more convenient.
>>
>
> The "data:" URI scheme works well for this.  There are examples on this
> page:
> http://www.websiteoptimization.com/speed/tweak/inline-images/folder-test.htmland
>  here is a data url that may work, if it comes through properly in this
> email:
>
>
> 
>

Maybe this is obvious, but a client-side editor could use data-scheme URIs
to display intermediately edited data before you commit it to Fossil.


Bill
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] Feature request: edit files via web interface

2011-09-21 Thread Bill Burdick
On Tue, Sep 20, 2011 at 4:22 AM, Stephan Beal  wrote:

> On Tue, Sep 20, 2011 at 1:38 AM, Joshua Paine wrote:
>
>> On 9/19/2011 7:15 PM, Stephan Beal wrote:
>>
>>> and JS cannot natively deal with binary data (that's coming in v5 or
>>
>> whatever new version is coming soon).
>>>
>>
>> Standard javascript doesn't have this ability yet, but individual impl
>> have relevant capabilities. E.g., privileged JS in XUL has access to files
>> and can get base64 strings from them, and the canvas element has a toDataURL
>> method that returns base64 encoded data plus a tiny amount of metadata.
>
>
> The JS version accompanying HTMLv5 (i don't remember the version number)
> contains some support for binary data. Some browsers have already started
> implementing this and some apps already use it (e.g. gmail).
>
> So the option for binary data certainly can't be ruled out altogether.
> OTOH, while JS is expected to (==i expect) be the primary client, there will
> likely be other platforms out there for which base64 is more convenient.
>

The "data:" URI scheme works well for this.  There are examples on this
page:
http://www.websiteoptimization.com/speed/tweak/inline-images/folder-test.htmland
here is a data url that may work, if it comes through properly in this
email:




Bill
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] binary in JSON: maybe there is some hope...

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 3:55 PM, Joshua Paine wrote:

> Precisely because it adds no types, it doesn't have anything to say about
> "what do I do if the data I want to send isn't one of the JSON types?"
>

>From what i've read, his proposal is just that - to encode (as a string)
non-JSON (primarily binary) types, basically as a list containing a type tag
and the byte values. After reading over more of it, i think it might be
easier/more portable (but perhaps less space-efficient) to recycle sqlite3's
blob-as-text format ("Xaabbccdd..."). That's trivial to encode/decode in all
but the most restrictive environments, though it may not be efficient to to
do. e.g. in JavaScript we could decode to an array (internally a linked list
or some such, so it'd have a HUGE overhead if we store only 1 byte per array
element) but we can't use a string because we can't change bytes of a JS
string (we can only create new strings). Some native-level JS toolkits
provide a ByteArray class for efficiently handling binary data, and the new
JS has various new array types for handling them. But JSON itself doesn't,
so i can't rely on any of those :/.

i was briefly very hopeful, but somehow i'm not anymore :/. (Nonetheless, i
find his proposal interesting for other specific use cases, and might find a
use for it elsewhere.)

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] any interest in integrating jimtcl w/fossil?

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 3:53 PM, Martin S. Weber wrote:

> Yep. That's where step #1 comes in - librarization of fossil. Luckily I'll
> have time for that (at least rounding up an API suggestion) next week.
>

i recently went through a very similar migration/refactoring (on a much
smaller scale, but the exact same problems), and have some ideas about this.
i would be VERY interested in assisting if you (or someone else) would take
the reigns.

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] binary in JSON: maybe there is some hope...

2011-09-21 Thread Joshua Paine

On 9/21/2011 9:29 AM, Stephan Beal wrote:

his proposal adds binary support to JSON without actually extending JSON
with new data types.


It won't help you any. All that proposal is about is an alternate, 
non-text serialization for JSON data to avoid the expense of converting 
to text and back again, e.g., for an object database or some wire 
transmission scenarios.


Precisely because it adds no types, it doesn't have anything to say 
about "what do I do if the data I want to send isn't one of the JSON types?"


--
Joshua Paine
LetterBlock: Web Applications Built With Joy
http://letterblock.com/
301-576-1920
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


[fossil-users] potential backwards-compatible solution to the multi-login problem

2011-09-21 Thread Stephan Beal
Hi, all,

i think i've found a backwards-compatible solution to the multi-login
problem and wanted to run it by people familiar with the problem so that
they can spot any holes in my thought process before i start hacking...

(Just a quick reminder: while the lack of multiple logins is only a minor
nuisance in the HTML interface (i've never needed multiple logins), in the
JSON interface it will quickly become a hurdle.)

Currently the login info is stored in the user table for non-anonymous
users. For anonymous users we rely 100% on the cookie/auth token, which is a
hash of various things and fossil can tell if it's been tampered with. (The
cookie handling is very impressive, if you ask me.)

My proposal would be to store the login-related info in a new table, keeping
the same fields/algorithms as we currently use in the user table. The
down-side would be that we could theoretically end up with arbitrary many
stale login entries in the db (which could theoretically be used as attack
vectors). The up-side is that we could support multiple logins per user this
way. We could periodically purge contents which are older than X
minutes/days/whatever (config option), and the number of login entries are
very, very unlikely to every reach a point which notably impacts the db file
size (we're talking probably <100 bytes per record). We could also limit the
number of concurrent logins, purging the oldest ones for a given user if we
go over the limit (config option). Logins would of course be excluded from
syncing, and would in effect become a part of the local fossil db file (a
non-critical part - the table could be dropped/emptied without affecting
fossil's behaviour except that it would effectively log everyone out). A new
command could be added which would force a cleanup of any stale (optionally
all) login tokens (e.g. fossil login purge).

:-?

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] any interest in integrating jimtcl w/fossil?

2011-09-21 Thread Martin S. Weber

On 09/20/11 19:20, Steve Bennett wrote:

The simple answer is, No, you will not be able run (any) Tcl code unaltered.


Thanks for that info.


It may not be unreasonable to allow an arbitrary language binding to fossil.


Indeed. I've been looking into jim / tcl mostly because of Th1. j/t are a 
superset of Th1 - the logical alternatives (python, ruby, lua, forth, guile, 
...) aren't.





As I've written earlier, I'd really like to see a list of all the commands and 
subcommands of tcl on one side, and all of the commands and subcommands of jim 
on the other side, and an indicator whether a) jim does not support given 
command and/or subcommand, b) jim supports it but with differences, c) jim 
supports it and it behaves idempotent to the tcl command/subcommand, d) a) or 
b) is the case but by loading package x it becomes c). Without this information 
IMO it is impossible to do an informed choice on whether to use jim or tcl.


I understand, but this is not trivial since there are some subtle differences 
which go beyond commands existing or not.


Exactly that's why I'd expect the implementors of jim to document that as they 
go along implementing it. They are the ones who know best about the compatibility.



I don't think the design proposal needs to care too much about the language 
features.


Hmm, somewhat. If there will be language bindings, there will be a first one, 
perceived as the default. Choosing that first one (and/or the one that fossil 
uses on its own fossil) is tricky. But that's step #2 ...



It is the interface to fossil which is important.


Yep. That's where step #1 comes in - librarization of fossil. Luckily I'll 
have time for that (at least rounding up an API suggestion) next week.


-Martin
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


[fossil-users] binary in JSON: maybe there is some hope...

2011-09-21 Thread Stephan Beal
Hi, all!

A guy just posted this on the json mailing list:

https://docs.google.com/document/d/12SimAfBVcl8Fd-lr_SSBkM5B_PyEhDRfhgu1Lzvfpfw/edit?hl=en_US&pli=1

his proposal adds binary support to JSON without actually extending JSON
with new data types. i haven't read all the way through it, but what i've
read so far sounds reasonable enough.

Just something to keep in mind once we get to a point where handling binary
becomes necessary (e.g. committing arbitrary files over JSON).

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users


Re: [fossil-users] First JSON timeline demo

2011-09-21 Thread Stephan Beal
On Wed, Sep 21, 2011 at 1:00 AM, Nolan Darilek wrote:

>  Is it possible to dump all structures to the same call, then require
> clients to intelligently determine which is which?
>

It is, of course, but i need to develop them independently (look at
timeline.c:page_timeline() and you'll see why). Once the independent
commands work, it's easy to merge them into a structure which contains
different chunks for the wiki/ticket/commit info. It will also be easy to
alias them to e.g. /json/timeline?t=ci (which is how the which-type
distinction is currently made).



> Seems like it should be fairly trivial on the client side. Mind you, I'm
> not opposed to separate calls either, I just wonder why the different
> structures automatically rule out someone taking up the challenge of
> differentiating them in whatever clients they've dreamed up?
>

It doesn't actually - the complication is in the server-side implementation.
page_timeline() is a beast (almost 400 lines long), and my brain needs
smaller chunks to work with.

-- 
- stephan beal
http://wanderinghorse.net/home/stephan/
___
fossil-users mailing list
fossil-users@lists.fossil-scm.org
http://lists.fossil-scm.org:8080/cgi-bin/mailman/listinfo/fossil-users