Title of Invention

A METHOD AND A SYSTEM FOR GENERATING A COMPACT DIFFERENCE RESULT BETWEEN AN OLD DATA TABLE AND A NEW DATA TABLE

Abstract A method for generating a compact difference result between an old program and a new program. Each program including reference entries that contain reference that refer to other entries in the program. The method includes the steps of scanning the old program and for each reference entry perform steps that include replacing the reference of the entry by a distinct label mark, whereby a modified old program is generated. There is further provided the step of scanning the new program and for each reference entry perform steps that include replacing the reference of the entry by a distinct label mark, whereby a modified new program is generated. There is still further provided the step of generating the specified different result utilizing dir...
Full Text DIFFERENCE EXTRACTION BETWEEN TWO VERSIONS OF DATA-TABLES CONTAINING INTRA-REFERENCES
FIELD OF THE INVENTION
This invention relates generally to updating computer programs.
BACKGROUND OF THE INVENTION
With the ever increasing use of remote communication and in particular the Internet, new applications have been introduced such as commercial trade over the Internet, electronic supermarkets, distribution of computer products over the Internet, and others.
Both the popularity and availability of access to the Internet for common users have encouraged not only the distribution of products, but also the upgrade and update of the product under question from a remote site, using, to this end, the Internet infra-structure.
Turning to a specific example of computer programs, an old program is installed at a remote client site and is subject to be upgraded to a new program, where the latter includes some modifications as compared to the old program.
In order to cany out the update at the remote client site (through the network), the provider should, preferably, generate a difference result representative of the difference between the old program and the new program, and send the resulting file through the Internet to the remote client site. The client, in turn, invokes appropriate utility, which incorporates the differences in the old program, thereby generating the desired new program at the client site. The specified procedure carries the obvious advantages in that on the one hand, the provider does not need to be present at the client site and, on the other hand, only the difference result and not the entire new program is sent to the client. Assuming,

for example, that a modified Office '97 package (commercially available from Microsoft Inc. USA) should be sent to clients, since the compressed size of programs of the package occupies tens of Mega-bytes, and, further considering the relatively low throughput of the Internet and the bottleneck of the modem throughput at the client end (say an average of 33,600 bps), it is easy to understand that transmitting the entire new package through the network is practically infeasible.
Normally, the volume of the difference result is significantly smaller than that of the raw new program and, accordingly, sending only the difference result data rather than the entire new program, is more efficient. This notwithstanding, and as will be explained in greater detail below, applying known per se file difference applications (such as techniques utilized by diff utilities of the UNIX operating systems or a similar (diffutility of the GNU project from FSF) in order to generate a difference result between the old program and the new program, normally results in a relatively large amount of data, even if the modifications that were introduced to the old program (in order to generate the new program) are very few. Thus, consider, for example, an old program where few new instructions are inserted and few others are deleted in order to bring about the new program. The difference result between the old program and the new program will not only reveal the inserted and deleted instructions, but also all those entries that jump, jump on condition, call functions, reference to data and possibly others (referred to, collectively, as reference entries - see glossary below) which, by nature, specify a target address (reference) as an integral part of the command. The latter addresses may have been changed due to the fact that some instructions were added and others deleted. It is important to note that the reference entries that are modified are not those that were inserted, and obviously not those that were deleted. In fact, insertion of only one new entry may result in the plurality of altered reference entries which will naturally be reflected in the difference result and obviously will inflate its volume.
It is accordingly appreciated that despite the fact that the actual change between the old and new program is veiy limited, the resulting file difference is relatively large. The same problem is encountered in other applications, which employ data tables (see Glossary below), that are structured like a program and are subject to updates in the manner specified.
There is accordingly a need in the art to provide for an efficient tool which will result in significantly smaller volumes of difference results between old programs and new programs, as compared to hitherto known techniques for accomplishing difference result. The proposed tool is useful for various applications including, but not limited to, incremental software updates and version control.
There is yet another need in the art to provide for an efficient tool which will result in significantly smaller volumes of difference results between old data tables and new data tables.
GLOSSARY:
There follows a glossary of terms, some of which are conventional and others have been coined:
Dam Table - a table of entries, each may have a different size;
Entiy - a data table includes entries, each of which is an addressable unit that contains data;
Address - a number which is uniquely assigned to a single entry by which that entry is accessed; In the following description, the terms entry and address are occasionally used interchangeably.
Reference- a part of the data appearing in an entry in the data table which is used to refer to some other entry from the same data table. A reference can be
either an address or a number used to compute an address. Entries that include references are designated also as reference entries,
Label - an abstract notation of an entry which is referred by another entry of the same data table through a reference.
Old Data Table - a data table (or portion of a data table) that is to be updated (possibly from remote site) so as to generate a new data table (or portion of a new data table). Insofar as remote update is concerned, it is normally, although not necessarily, transmitted through a communication network such as the Internet. It should be noted that whilst for convenience of explanation only, the description focuses predominately on the Internet, the invention is by no means bound by this specific example.
As an example, a data table can be an executable program either as a loaded program in machine-memory or as an executable-file. In this example, entries are individual machine instructions of the program or the individual data elements used by the program.
Instructions and data elements of a program may contain addresses to other instructions or data elements and are regarded as references. Such references can be detected by a process of disassembly applied on the program or, if given, by analyzing a relocation table attached to executable programs by link-editors that create them.
Another example of a data table is a group of inter-linked data records stored in an array of bytes where records contain addresses of other data records. The format of the records and the way they are laid out in the array are known, and the analysis and decomposition of such array is possible.
Old program - an example of old data table: a program (or portion of a program) that is to be updated so as to generate a new program (or portion of a program).
It should be further noted that reference to the old program, and the new program is made for convenience of explanation only, and encompasses inter alia the upgrade of the old program to the new program (e.g. due to an upgrade in versions), modifications of the old program to the new program, (e.g. due to corrections of bugs in the old program), and changing from a first old program to a second (and possibly different) new program;
SUMMARY OF THE INVENTION
For convenience of explanation, the invention is described with reference to a specific example of computer programs. The invention is by no means bound by this particular example.
As explained above, applying a known per se file difference utility to an old program and a new program normally results in a relatively large amount of data, even if the modifications that were introduced to the old program (in order to generate the new program) are very few. The present invention is based on the observation that the relatively large size of the difference result stems from the alterations of reference in reference entries as a result of other newly inserted entries (and/or entries that were deleted).
On the basis of this observation, the invention aims at generating a modified old program and a modified new program, wherein the difference in references in corresponding entries in said new and old programs as explained above, will be reflected as invariant entries in the modified old and new programs. The net effect is that the invariant reference entries (between the modified old program and the modified new program), will not appear in the difference result, thereby reducing its size as compared to a conventional difference result obtained by using hitherto known techniques.
Accordingly, the invention provides for a method for generating a compact difference result between an old program and a new program; each program including reference entries that contain reference that refer to other entries in the program; the method comprising the steps of:(a) scanning the old program and for substantially each reference
entry perform steps that include:
(i) replacing the reference of said entry by a distinct label mark, whereby a modified old program is generated;
(b) scanning the new program and for substantially each reference
entry perform steps that include:
(i) replacing the reference of said entry by a distinct label mark, whereby a modified new program is generated;
(c) generating said difference result utilizing directly or indirectly
at least said modified old program and modified new program.
The invention further provides for a method for performing an update in an old program so as to generate a new program; each program including reference entries that contain reference that refer to other entries in the program; the method comprising the steps of:
(a) receiving data that includes a compact difference result; said
compact difference result was generated utilizing a modified old
program and a modified new program;
(b) scanning the old program and for substantially each reference
entry perform steps that include:
(i) replacing the reference of said entry by a distinct label mark, whereby the modified old program is generated;
(c) reconstituting the modified new program utilizing at least said
compact difference result and said modified old program; said
modified new program is differed from said new program at least in
that substantially each reference entry in said new program is replaced
in said modified new program by a distinct label mark;
(d) reconstituting said new program utilizing directly or indirectly
at least said compact difference result and said modified new program.
Still further, the invention provides for a method for generating a compact difference result between an old program and a new program; each program
including reference entries that contain reference that refer to other entries in the program; the method comprising the steps of:
(a) generating a modified old program utilizing at least said old
program;
(b) generating a modified new program utilizing at least said new
program, said modified old program and modified new program have
at least the following characteristics:
(i) substantially each reference in an entry in said old program that is different than corresponding entry in said new program due to delete/insert modifications that form part of the transition between said old program and new program are reflected as invariant references in the corresponding entries in said modified old and modified new programs;
(c) generating said compact difference result utilizing at least said
modified new program and modified old program.
Yet further, the invention provides for a method for performing an update in an old program so as to generate a new program; each program including reference entries that contain reference that refer to other entries in the program; the method comprising the steps of:
(a) receiving data that includes a compact difference result; said
compact difference result was generated utilizing a modified old
program and a modified new program;
(b) generating a modified old program utilizing at least said old
program;
(c) reconstituting a modified new program utilizing directly or
indirectly at least said modified old program and said compact
difference result; said modified old program and modified new
program have at least the following characteristics:
(i) substantially each reference in an entry in said old program that is different than corresponding entry in said new program

due to delete/inset modifications that form part of the transition between said old program and new program are reflected as invariant references in the corresponding entries in said modified old and modified new programs;
(d) reconstituting said new program utilizing directly or indirectly at least said compact difference result and said modified new program.
According to another aspect, the invention provides for a system for generating a compact difference result between an old program and a new program; each program including reference entries that contain reference that refer to other entries in the program; the system comprising a processing device capable of:
(a) scanning the old program and for substantially each
reference entry perform steps that include:
(i) replacing the reference of said entry by a distinct label mark, whereby a modified old program is generated;
(b) scanning the new program and for substantially each reference
entiy perform steps that include:
(i) replacing the reference of said entry by a distinct label mark, whereby a modified new program is generated;
(c) generating said difference result utilizing directly or indirectly
at least said modified old program and modified new program.
Still further, the invention provides for a system for performing an update in an old program so as to generate a new program; each program including reference entries that contain reference that refer to other entries in the program; the system comprising a processing device capable of:
(a) receiving data that includes a compact difference result; said
compact difference result was generated utilizing a modified old
program and a modified new program;
(b) scanning the old program and for substantially each reference
entry perform steps that include:

(i) replacing the reference of said entry by a distinct label mark, whereby the modified old program is generated;
(c) reconstituting the modified new program utilizing at least
said compact difference result and said modified old program; said
modified new program is differed from said new program at least in
that substantially each reference entry in said new program is replaced
in said modified new program by a distinct label mark;
(d) reconstituting said new program utilizing directly or
indirectly at least said compact difference result and said modified
new program.
The invention further provides for a system for generating a compact difference result between an old program and a new program; each program including reference entries that contain reference that refer to other entries in the program; the system comprising a processing device capable of:
(a) generating a modified old program utilizing at least said old
program;
(b) generating a modified new program utilizing at least said new
program, said modified old program and modified new program have
at least the following characteristics:
(i) substantially each reference in an entry in said old program that is different than corresponding entry in said new program due to delete/insert modifications that form part of the transition between said old program and new program are reflected as invariant references in the corresponding entries in said modified old and modified new programs;
(c) generating said compact difference result utilizing at least said
modified new program and modified old program.
Still further, the invention provides for a system for performing an update in an old program so as to generate a new program; each program including reference entries that contain reference that refer to other entries in the program;
the system comprising a processing device capable of:
(a) receiving data that includes a compact difference result; said
compact difference result was generated utilizing a modified old
program and a modified new program;
(b) generating a modified old program utilizing at least said old
program;
(c) reconstituting a modified new program utilizing directly or
indirectly at least said modified old program and said compact
difference result; said modified old program and modified new
program have at least the following characteristics:
(i) substantially each reference in an entry in said old program that is different than corresponding entry in said new program due to delete/inset modifications that form part of the transition between said old program and new program are reflected as invariant references in the corresponding entries in said modified old and modified new programs;
(d) reconstituting said new program utilizing directly or indirectly
at least said compact difference result and said modified new program.
Yet further, the invention provides for a method for generating a compact difference result between an old data table and a new data table; each data table including reference entries that contain reference that refer to other entries in the data table; the method comprising the steps of:
(a) scanning the old data table and for substantially each reference
entry perform steps that include:
(i) replacing the reference of said entry by a distinct label mark, whereby a modified old data table is generated;
(b) scanning the new data table and for substantially each reference
entry perform steps that include:
(i) replacing the reference of said entry by a distinct label mark, whereby a modified new data table is generated;
c) generating said difference result utilizing directly or indirectly at least said modified old data table and modified new data table.
Moreover, the invention provides for a method for performing an update in an old data table so as to generate a new data table; each data table including reference entries that contain reference that refer to other entries in the data table; the method comprising the steps of:
(a) receiving data that includes a compact difference result; said
compact difference result was generated utilizing a modified old data
table and a modified new data table;
(b) scanning the old data table and for substantially each reference
entry perform steps that include:
(i) replacing the reference of said entry by a distinct label mark, whereby the modified old data table is generated;
(c) reconstituting the modified new data table utilizing at least said
compact difference result and said modified old data table; said
modified new data table is differed from said new data table at least in
that substantially each reference entry in said new data table is
replaced in said modified new data table by a distinct label mark;
(d) reconstituting said new data table utilizing directly or indirectly
at least said compact difference result and said modified new data
table.
The invention further provides for a method for generating a compact difference result between an old data table and a new data table; each data table including reference entries that contain reference that refer to other entries in the data table; the method comprising the steps of:
(a) generating a modified old data table utilizing at least said old
data table;
(b) generating a modified new data table utilizing at least said new
data table, said modified old data table and modified new data table
have at least the following characteristics: (i) substantially each reference in an entry in said old data table that is different than corresponding entry in said new data table due to delete/insert modifications that form part of the transition between said old data table and new data table are reflected as invariant references in the corresponding entries in said modified old and modified new data tables;
(c) generating said compact difference result utilizing at least
said modified new data table and modified old data table.
The invention provides for a method for performing an update in an old data table so as to generate a new data table; each data table including reference entries that contain reference that refer to other entries in the data table; the method comprising the steps of:
(a) receiving data that includes a compact difference result;
said compact difference result was generated utilizing a modified old
data table and a modified new data table;
(b) generating a modified old data table utilizing at least said
old data table;
(c) reconstituting a modified new data table utilizing directly
or indirectly at least said modified old data table and said compact
difference result; said modified old data table and modified new data
table have at least the following characteristics:
(i) substantially each reference in an entry in said
old data table that is different than corresponding entry in said new data table due to delete/inset modifications that form part of the transition between said old data table and new data table are reflected as invariant references in the corresponding entries in said modified old and modified new data tables;
(d) reconstituting said new data table utilizing directly or
indirectly at least said compact difference result and said modified new data table.
The invention further provides for a system for generating a compact difference result between an old data table and a new data table; each data table including reference entries that contain reference that refer to other entries in the data table; the system comprising a processing device capable of:
(a) scanning the old data table and for substantially each
reference entry perform steps that include:
(i) replacing the reference of said entry by a
distinct label mark, whereby a modified old data table is generated;
(b) scanning the new data table and for substantially each
reference entry perform steps that include:
(i) replacing the reference of said entry by a
distinct label mark, whereby a modified new data table is generated;
(c) generating said difference result utilizing directly or
indirectly at least said modified old data table and modified new data
table.
Still further, the invention provides for a system for performing an update in an old data table so as to generate a new data table; each data table including reference entries that contain reference that refer to other entries in the data table; the system comprising a processing device capable of:
(a) receiving data that includes a compact difference result;
said compact difference result was generated utilizing a modified old
data table and a modified new data table;
(b) scanning the old data table and for substantially each
reference entry perform steps that include:
(i) replacing the reference of said entry by a
distinct label mark, whereby the modified old data table is generated;
(c) reconstituting the modified new data table utilizing at least
said compact difference result and said modified old data table; said
modified new data table is differed from said new data table at least in
that substantially each reference entry in said new data table is
replaced in said modified new data table by a distinct label mark;
(d) reconstituting said new data table utilizing directly or
indirectly at least said compact difference result and said modified
new data table.
Moreover, the invention provides for a system for generating a compact difference result between an old data table and a new data table; each data table including reference entries that contain reference that refer to other entries in the data table; the system comprising a processing device capable of:
(a) generating a modified old data table utilizing at least said
old data table;
(b) generating a modified new data table utilizing at least said
new data table, said modified old data table and modified new data
table have at least the following characteristics:
(i) substantially each reference in an entry in said
old data table that is different than corresponding entry in said new data table due to delete/insert modifications that form part of the transition between said old data table and new data table are reflected as invariant references in the corresponding entries in said modified old and modified new data tables;
(c) generating said compact difference result utilizing at least
said modified new data table and modified old data table.
The invention provides for a system for performing an update in an old data table so as to generate a new data table; each data table including reference
entries that contain reference that refer to other entries in the data table; the system comprising a processing device capable of:
(a) receiving data that includes a compact difference result;
said compact difference result was generated utilizing a modified old
data table and a modified new data table;
(b) generating a modified old data table utilizing at least said
old data table;
(c) reconstituting a modified new data table utilizing directly
or indirectly at least said modified old data table and said compact
difference result; said modified old data table and modified new data
table have at least the following characteristics:
(i) substantially each reference in an entry in said
old data table that is different than corresponding entry in said new data table due to delete/inset modifications that form part of the transition between said old data table and new data table are reflected as invariant references in the corresponding entries in said modified old and modified new data tables;
(d) reconstituting said new data table utilizing directly or
indirectly at least said compact difference result and said modified
new data table.
BRIEF DESCRIPTION OF THE DRAWINGS
In order to understand the invention and to see how it may be carried out in practice, a preferred embodiment will now be described, by way of non-limiting example only, with reference to the accompanying drawings, in which:
Fig. 1 is a schematic illustration of a sequence of operation according to one embodiment of the invention;
Figs. 2A-2B show exemplary old and new programs and the various interim results that are obtained by applying the sequence of operation of Fig 1; and
Figs. 3A-3B illustrate an exemplary data table, presented in the form of graph which is subject to difference extraction in accordance with the invention.
DETAILED DESCRIPTION OF A PREFERRED EMBODIMENT
In Fig. 1, module (200) represents the sequence of operations performed e.g. at the provider site, for generating the difference result according to one embodiment of the invention. The sequence of operation will now be described with reference to exemplary old and new programs (Figs. 2A-2B). It should be noted that the specified sequence of operations may be earried out at any known per se platform including, but not limited to, a conventional P.C., a computer network, etc., all as known per se.
Thus, PI stands for the old program that includes entries (41), (42), (43), (44), (45) and (46) that contain references to entries 5,8,1,1,13, and 11 respectively, (as indicated by arrows (41') to (46').
Pj stands for the new program which was generated (or could have been generated) by the sequence of modifications as depicted in the imaginary memory table (80). Said sequence of modifications (either real or imaginary), constitutes a transition sequence between PI and P2.
As shown in entry no. 6, the reference to address '1' was replaced ('R' stands for replaced) by reference to address '11', e.g. due to a patch introduced by the programmer. Following the 6th entry, 3 new entries were inserted (T stands for inserted). The newly inserted entries reside at addresses 7 to 9. The next three entries which originally resided in addresses 7 and 9 at Pt are now shifted (due to the 3 inserted entries) to addresses 10 to 12 in P>.
Next, entries 10 and 11 in P, were deleted (D), and are therefore not assigned with any address at P: Entries 12 and 13 in PI remain intact and reside in
addresses 13 and 14 in P: Entry 14 in P/ was deleted (D) and it is marked as such (with no address) in the memory table (80). Lastly, entry (15) remains intact and therefore resides in entry 15 in P2
Having reviewed the sequence of modifications that constitute the transition from PI to P2, there follows a brief review on how the specified modifications affected the reference entries ofP1 and P2.
Thus, and as expected, the reference 5 in entry 2 remains intact and it will therefore not appear in the difference result between PI and P2:
The reference 8 in entry 4 of PI is now modified by reference 11 in entry 4 of P2 The modification in the reference (from 8 to 11) in entry 4 is caused by the insertion of entries 7 to 9 in P2. which obviously shifted entry 8 (in P1) to entry 11 (in P2). Before proceeding any further, it should be noted that applying conventional file difference application to P1 and P2 will obviously reflect that entry 4 has been changed since the reference 8 has been changed to 11. Those versed in the art will readily appreciate that according to the invention, it is desired to neutralize this change, since it has occurred solely due to the fact that other entries have been affected (i.e. entries 7 to 9). It is accordingly an object of the invention to give rise to a situation where modifications of this kind will be modified to invariant references with the obvious consequence that they are not reflected in the difference result, thereby keeping the latter relatively compact.
Reverting now to the example of Figs. 2A-2B, the next reference 1 resides in entry 6 of P1. As recalled, this entry was intentionally modified to 11, and as expected in entry 6 of P2 contains reference 11. Unlike the previous reference modification which stems from shifts in the program and which therefore should be neutralized from appearing in the difference results, the current modification is applied to the entry under question (i.e. the reference in entry 6 has been changed from 1 to 11) and should be reflected in the difference result. Turning now to entry 7 of P2, it forms part of the inserted entries, and therefore reference 9 thereof is obviously not reflected in PI, Of course, since entry 7 has been inserted, it is expected to appear in the difference results.
Entry 10, with its associated reference 13, has been deleted from Pj, and as expected, it does not appear in P2 and should, of course, be indicated in the difference results as an entry for deletion.
Entiy 9 with its associated reference 1 in P1, corresponds to entry 12 in P2. Since the reference in entry 12 remains 1, it will not appear in the difference result.
Turrning to the last reference entry 14 in P1, it does not appear in P2 (since it was deleted), and therefore it is expected to appear in the difference result as an entry for deletion.
Having described in general the differences between P1 and Pi, as well as their effect on the difference result, attention is now directed also to Fig. 1 for describing one non-limiting realization of a system and method of the invention for accomplishing the desired difference result.
By this particular embodiment, the desired invariant references are accomplished by generating modified old and new programs wherein address references in entries are replaced by label marks as follows:
a) Create P", table from P, (steps (201) and (202) in Fig. 1)
and
P"2 table from P2 (steps (203) and (204) in Fig. 1) by adding label marks and replacing references in entries with some fixed values. As shown in Fig. 2A, P"/ is generated from P/ by adding label marks to entries 1, 5, 8, 11 and 13 (designated (101) to (105), respectively). As also shown in Fig. 2A, the references at entries 2, 4, 6, 9 10 and 14 were set to a fixed value and by this particular example 0. Although not shown in Fig 2A, P"2 is generated in a similar manner;
Create a translation table L\ (step (205) in Fig. 1) between
entry references in P\ and label distinct values. Thus, and as shown in
Fig. 2A (110), a distinct label number is assigned to each label mark of
P"I. By this particular example, the distinct labels are assigned in
ascending order and, as shown, labels marks (101) to (105) are
assigned with the respective values 1 to 5;
P"] and P'\ are compared giving rise to difference table D(206) using file difference utilities of the kind specified above. As
shown in Fig. 2B, DI (120) contains list of entries each having the
structure of , where X stands for C (copy), I (insert), D(delete),
or T (Toggle) and n stands for the number of instructions. Dincludes, in fact, a list of instructions for generating P"2 from P'V By
this particular example, D\ includes the following entries: which
signifies that the first 6 entries of P"\ should be copied to P'V Note
that whilst the 6th entry is different in P\ and P2 (i.e. the reference has
been changed from 1 to 11), this entry is the same in P"\ and P'%
,since both references were set to 0 and, accordingly, the 6th entry

forms part of the copied part. The next entry ,signifies that three new entries should be inserted, and this accounts for the new three entries 7 to 9 that were inserted to P2 (and are also reflected in P"2). The next entry stands for the three entries'that reside in addresses 7 to 9 in P'\ (and PI), and are shifted (without affecting their contents), to addresses 10 to 12 in P"2 (and P2). The next entry stands for the two entries (10 and 11) that were deleted from P, (and obviously also from P"i). The next entry stands for the entry 12 in P'\ that was shitted (without affecting its contents) to entry 13 in P"2. The next entry is a special entry indicating that a change has occurred in the label of entry 13 of P"i, i.e,. it was removed in the corresponding entry 14 in P"2 for the simple reason that the entry that refers to this label was deleted (entry 10 in P"i (and PI). signifies, thus, that the entry 13 should be copied (to entry 14), whilst deleting the label mark. Next, stands for the deleted entry (14) in P"i, and stands for copying the last intact entry that is to be copied from P"i to P"2 (entry 15).
d) Analyzing £>, to determine the Position and size of deleted
or inserted program fragments and apply equivalent changes to L\ translation table to create L2 translation table (207), which translates entry references in P2 to their distinct label value in the following manner: For a non-inserted referred entry perform:
• L2[entry address] = L\ [matching entry address in PI]
(hereinafter the first condition)
For an inserted referred entry, perform:
• £2[entry address] = U( ) different than any value in L\',
U( ) signifies a label generation function for generating distinct labels (hereinafter the second condition). The
function is of repeatable nature, namely, when activated in the same scenario it will always generate the same result. The latter characteristics will be clarified when the subsequent program reconstruction phase is described below.
The resulting Z-2 table (130) is shown in Fig.2B. Thus, the first six instructions fall in the first condition (i.e. non inserted entry) and, accordingly, the distinct labels (1 and 2) are simply copied from L\.
The next three entries are inserted and, accordingly, the second condition applies and U( ) is activated to generate a distinct label value. Since, as shown in LI, five labels are "occupied", the next free one is 6 and, accordingly, the reference entry 9 is assigned with the value 6. Those versed in the art will readily appreciate that whilst in this example U( ) generates the distinct label values by simply incrementing the last occupied value by 1, this is only an example.
Turning now to the next three entries, , the reference entry 11 falls in the first criterion and, accordingly, the label value (3) is taken from LI.
The next entry in D/ is ignored, since it concerns two deleted entries.
The next entry, , has no reference entry and therefore need not be processed for generating L^_.
The next entry, ,corresponds to the deleted label (from entry 13 in L\) and in this respect, is resembles the previous delete modification that is ignored.
The last two entries, and , do not involve reference entries and therefore need not be processed for the purpose of generating L-±.

e) Create P', (208) and P\_ (209) for P\ and P: respectively, by
replacing entry references with their translated values using L\ and L2 tables and by coping label marks from P"| and FV
Step (e) will be described with reference to-P'i and applies mutatis mutandis also to P'2 (see 150 in Fig. 2B). Thus, the label marks (101) to (105) of P"| are copied to the respective locations in P'i (140 in Fig. 2A). Next, the reference entries of PI are replaced by their corresponding label marks as retrieved from L\. More specifically, the reference 5 in entry 2 of P\ is replaced by the corresponding label from L\. As shown, label 2 resides in entry 5 of L\ and, accordingly, the reference in-entry 2 in P\ is set to 2.
In a similar manner, the reference 8 in entry 4 of P, is replaced by label number 3 according to the label number (3) that resides in entry 8 of L\. In a similar manner, the references 1,1,13 and 11 of entries 6,9,10 and 14 of PI are replaced by respective label numbers 1,1,5 and 4.
f) Having generated P\ and P'2, the final difference result D2 is
generated. To this end, D\ is analyzed to determine the position of program fragments copied from P\ to P2 (i.e. in the example of Figs. 2A-2B, the entries that fall in or commands: the commands are ignored>). For copied entries as derived from D|, P'i and P'2 are compared so as to generate D2 (210) in the following manner:
fl) take each pair of matching entries in P'i and P'2 (neither deleted nor inserted) that contain a (replaced) reference, and compare their replaced reference values. In the case of discrepancy, add a special modification command to reflect the difference.
f2) attach all the inserted program fragments and replaced values. These fragments are taken from P'2. thus they contain label marks, and address references remain under L-> translation.
Step (fl-f2) will now be exemplified with reference to the specific example of Figs. 2A-2B. As recalled, only entries that fall in a command are of interest for the fl step analysis. Thus, the first non-inserted entry of D\, i.e. is analyzed. According to step fl, only the six"1 entry contains a replaced reference (reference 1 in P\ as compared to reference 3 in PV). Accordingly, The first command of D, is replaced in D2 by and a correction command standing for "replace label in entry 6" is added to D2. Entries 2 and 4 in P\ (that also fall in the first six entries and are encompassed by the command), contain the respective references 2 and 3, exactly as the corresponding entries in P\ and, accordingly, no correction command is required.
The rest of the entries that correspond to commands do not include replaced references in P\ and P\ and, accordingly, no replacement command is required.
Step f2 simply stipulates that the inserted data and replaced data (replaced reference) will be appended to D2 in order for the reconstructing party to be able to reconstitute PI from D2 and P\.
Thus the three entries (that should be inserted to entries 7 to 9 in P2) and which correspond to in D2, are added to D2 in section (161). Likewise, the replaced reference 3 (instead of 1) in the sixth entry which corresponds to in D? is added to D2 ,in section (161).
Depending upon the particular application, D2 may be stored on a storage medium, or transmitted through a communication network (212 in Fig. 1), all as required and appropriate.
There follows a description for a typical sequence of operations (220) for reconstructing P2 from P\ and the so received D2, according to the present embodiment. Reconstructing P2 may also be realized on
any desired platform, all as required and appropriate. A sequence of operation, according to this embodiment includes:
a) Generate L\ (222) from P\ (221); (see step b above in 200)
b) Generate P\ (223) from P\ and L\\ (see step e above in 200)
c) Generate P'2 (224) from /Y and D2 (210) by applying the
modification commands of D2 on P'\d) Analyze the so received D2 difference result to determine the
position and size of copied program fragments of P\ and use L\ to
create ALi (225 in Fig. 1 ), which translates the label enumeration
values appearing in P'2, back to their original address reference in
the following manner:
For a non-inserted referred address:
AL2[L\ [matching address in P\]] = address (first condition)
For an inserted referred address:
AL2[U()] = address (second condition)
Step (d) will now be exemplified with reference to the specific
example of Figs. 2A-2B. Thus, in order to generate AL2 (170), at first
LI (130) is reconstructed, using to this end L[, P'2 and D2 all of
which are available at the reconstruction side (220). Having
reconstructed L2, AL2 can be easily derived by reversing L2. More
specifically, entry 1 in L2 holds the value 1 and accordingly, entry 1 of
AL2 holds the value 1. Entry 5 of L2 holds the value 5 and
accordingl entry 2 in
AL2 holds the value 5. By following the same reverse logic, entry 9 of L2 holds the value 6 and accordingly entry 6 of AL2 holds the value 9 and lastly by following the same logic entry 3 of AL2 holds the value 11.
e) Lastly, P2 (226) is reconstructed from P\ (224) and AL2
(225) by translating address references in P'2 from label enumeration values back to the original address references using AL2.
Step (e) will now be exemplified with reference to the specific example of Figs. 2A-2B. Thus, in order to reconstruct P2 (180), the label references in P\ are translated according to AL2. More specifically, label reference 2 in entry 2 of P% is replaced by actual entry reference 5 in P2 according to the value 5 in entry # 2 of AL2. Likewise, label references 3 in entries 4 and 6 of P'2, are replaced by actual address reference 11 in P2, according to the value 11 in entry # 3 of AL>. In a similar manner, label references 1 in entry 12 of P'2 is replaced by actual address reference 1 in P2 according to the value 1 in entry # 1 ofAL?. Lastly, label reference 6 in entry 7 of P'2, is replaced by actual address reference 9 in P2 according to the value 9 in entry # 6 of AL2. As shown by this particular example, P2 was generated indirectly from the difference result data D2, by the intermediary data structure, AL2.
Entries 4 and 5 of AL2 hold the value 0, signifying that reference labels 4 and 5 need not be updated in P2. since they form part of entries in PI that were deleted.
Those versed in the art will readily appreciate that whilst the invention has been described with reference to a specific application of updating software through a communication network, the invention is by no means bound by this specific application. Thus, by way of another example, the invention is applicable for efficient version control. Consider, for example, a series of program versions PI Pi and Pj. Applying the technique of the invention gives rise to compact £>/_•> and £);.?•, which stand for the difference between P/ P? and P: P}, respectively. The resulting compact Dt: and D_\i .as compared to conventional, larger in size.
difference results, bring about the desired efficient version control tool. Other applications are, of course, feasible, all as required and appropriate.
Having described the invention with reference to _a specific application of extraction differences between old and new versions of computer programs, there follows a description with reference to a more generalized representation of data table depicted in the form of a graph.
Before turning to the specific example, few observations which apply to the data table representation are set forth below:
• The graph represents a collection of data-recordt inter-connected by
references which enable to access them.
• Data records are stored in a linear storage such as array according to a
pre-defined order.
• The amount of storage allocated for storing the references is not
negligible.
• The data that represents the references is not held as a contiguous
biock, but rather is dispersed among other items of the data table (e.g.
among the data records).
Bearing this in mind, attention is directed to Figs. 3A-3B. The graph (300) represents an (old version of an) abstract data structure in the form of a graph (which is applicable in many applications as will be explained in greater details below). The nodes A-E represent data-records and the links represent references to other data-records. In this example, the pre-defined order for the data records is an alphabetical sort of records' names. The storage of the graph would appear as:
Thus, for example, data-record A (301), having address 1, is linked by means of links (302 and 303) that stand for references 2 and 4 respectively, to data-records B ad D (304 and 305). As shown above, B and D reside in addresses 2 and 4 respectively.
Should it now be required to modify the above graph by adding a data-record named ABA (306 in Fig. 3B) that is linked by means of link (307) to data-record I.) (305), this would bring about the following new graph storage, where ABA is inserted in accordance with the said alphabetical order:
1. A, 3, 5
2. ABA. 5
3. 13.-I
4. C, 5,6
5. D
6. K, 3
li is accordingly appreciated that insertion of only one data-record gave rise to fairly large differences between the storage of the old and the storage of the new graphs.
It is readily appreciated that the above abstract data structure is similar to a computer program, except for the fact that in the specified data structure, alphabetical order is imposed as compared to a computer program, where the order of execution is imposed.
Accordingly, applying the technique described in detail with reference to Figs. 1, 2A and 2B above would give rise to an extraction of compact differences.

As specified above, the data table is by no means bound to the representation of a computer program. Thus, by way of non-limiting example, the specified graph (300) represents a map where ncdes stand for cities and links for roads linking the various cities. The technique of the invention would allow for compact representation of topographical modification in the map (e.g. in response to the construction of a new road between the City having the symbol ABA and the city having the symbol D).
By way of another non-limiting example, the specified graph represents electronic circuitry where the nodes stand for the components and the links stand for the wiring connections between the components.
Numbers, alphabetic characters and roman symbols that appear in the following claims are designated for convenience of explanations only, and do not necessarily imply the particular order of the steps.
The invention has been described with a certain degree of particularity, but those versed in the art will readily appreciate that various alterations and modifications may be carried out without departing from the spirit and scope of the following Claims:






We Claim:
1. A system for generating a compact difference result between an old data table
and a new data table; each data table including reference entries that contain
reference that refer to other entries in the data table; the system comprising:
(a) a database;
(b) a processor;

(c) first generator means operatively coupled to the processor for generating a modified old data table utilizing at least said old data table;
(d) second generator means operatively coupled to the processor for generating a modified new data table utilizing at least said new data table, wherein the said first and second generator means generating said modified old data table and modified new data table having at least the following characteristics:
(i) substantially each reference in an entry in said old data table that is different than corresponding entry in said new data table due to delete/insert modifications that form part of the transition between said old data table and new data table are reflected as invariant references in the corresponding entries in said modified old and modified new data tables; and
(e) a compact difference generation means for generating said compact
difference result utilizing at least said modified new data table and
modified old data table.
2. The system as claimed in Claim 1, wherein a transmitter transmits said compact difference result over a communication network.
3. The system as claimed in Claim 1, wherein a storing means stores said compact difference result on a storage medium.
4. The system as claimed in any one of the claims 1 to 3, wherein the first
generator means comprises:
a first scanning means for scanning the old data table; and
a first replacing means for replacing substantially each reference entry of
said entry by a distinct label mark to generate a modified old data table;
and
wherein the second generator means comprises:
a second scanning means for scanning the new data table; and
a second replacing means for replacing substantially each reference entry
of said entry by a distinct label mark, to generate a modified new data
table.
5. The system as claimed in any one of Claims 1 to 3, wherein said old data table
being an old program, and said new data table being a new program, and said
modified old data table being a modified old program and said modified new
data table being a modified new program.
6. The system as claimed in claim 2, wherein said network comprises the
Internet.
7. A method for generating a compact difference result between an old data table
and a new data table by a system as claimed in claim 1; each data table including
reference entries that contain reference that refer to other entries in the data table;
the method comprising:
(a) generating using a first generator means a modified old data table utilizing at least said old data table;
(b) generating using a second generator means a modified new data table
utilizing at least said new data table, said modified old data table and
modified new data table have at least the following characteristics:
(i) substantially each reference in an entry in said old data table that is different than corresponding entry in said new data table due to delete/insert modifications that form part of the transition between said old data table and new data table are reflected as invariant references in the corresponding entries in said modified old and modified new data tables; and
(c) generating using a compact difference generation means said compact
difference result utilizing at least said modified new data table and
modified old data table.
8. The method as claimed in Claim 7, wherein subsequent to step (c) the method
comprises:
transmitting said compact difference result over a communication network.
9. The method as claimed in Claim 7, wherein subsequent to step (c) the method
comprises:
storing said compact difference result on a storage medium.
10. The method according to any one of Claims 7 to 9, wherein step (a)
comprises:
scanning using first scanning means the old data table and for substantially each reference entry perform steps that include: replacing by first replacing means the reference of said entry by a distinct label mark, whereby a modified old data table is generated; and wherein step (b) comprises:
scanning using second scanning means the new data table and for substantially each reference entry perform steps that include: replacing by second replacing means the reference of said entry by a distinct label mark, whereby a modified new data table is generated:
11. The method as claimed in Claims 7 to 9, wherein said old data table being an
old program and said new data table being a new program and said modified
old data table being a modified old program and said modified new data table
being a modified new program.
12. The method as claimed in Claims 7, wherein said network comprises the
Internet.
13. A processing device having associated therewith a storage medium which holds compact difference result data that was generated by the method of any one of Claims 7 to 9.
14. A system for generating a compact difference result between an old data table and a new data table substantially as herein described with reference to the foregoing description and the accompanying drawings.
15. A method for generating a compact difference result between an old data table and a new data table substantially as herein described with reference to the foregoing description and the accompanying drawings.

Documents:

5013-delnp-2005-1-Correspondence Others-(09-07-2013).pdf

5013-delnp-2005-1-GPA-(09-07-2013).pdf

5013-delnp-2005-abstract.pdf

5013-delnp-2005-Claims-(09-07-2013).pdf

5013-delnp-2005-Claims-(26-03-2014).pdf

5013-DELNP-2005-Claims-(26-08-2011).pdf

5013-delnp-2005-claims.pdf

5013-DELNP-2005-Correspondence Others-(05-07-2012).pdf

5013-delnp-2005-Correspondence Others-(09-07-2013).pdf

5013-delnp-2005-Correspondence Others-(25-03-2013).pdf

5013-delnp-2005-Correspondence Others-(26-03-2014).pdf

5013-DELNP-2005-Correspondence Others-(26-08-2011).pdf

5013-DELNP-2005-Correspondence-Others-(12-08-2009).pdf

5013-DELNP-2005-Correspondence-Others-(13-06-2013).pdf

5013-delnp-2005-correspondence-others.pdf

5013-delnp-2005-description (complete).pdf

5013-delnp-2005-Drawings-(26-03-2014).pdf

5013-DELNP-2005-Drawings-(26-08-2011).pdf

5013-delnp-2005-drawings.pdf

5013-DELNP-2005-Form-1-(26-08-2011).pdf

5013-delnp-2005-form-1.pdf

5013-delnp-2005-form-13 (24-04-2006).pdf

5013-delnp-2005-form-13.pdf

5013-delnp-2005-form-18.pdf

5013-delnp-2005-Form-2-(26-03-2014).pdf

5013-DELNP-2005-Form-2-(26-08-2011).pdf

5013-delnp-2005-form-2.pdf

5013-delnp-2005-Form-24-(09-07-2013).pdf

5013-delnp-2005-form-26.pdf

5013-DELNP-2005-Form-3-(05-07-2012).pdf

5013-DELNP-2005-Form-3-(26-08-2011).pdf

5013-delnp-2005-form-3.pdf

5013-DELNP-2005-Form-4-(13-06-2013).pdf

5013-delnp-2005-form-5.pdf

5013-DELNP-2005-GPA-(12-08-2009).pdf

5013-delnp-2005-Petition-137-(26-03-2014).pdf

5013-DELNP-2005-Petition-137-(26-08-2011).pdf


Patent Number 260164
Indian Patent Application Number 5013/DELNP/2005
PG Journal Number 14/2014
Publication Date 04-Apr-2014
Grant Date 02-Apr-2014
Date of Filing 02-Nov-2005
Name of Patentee RED BEND LTD.
Applicant Address 11 HAAMAL STREET, PARK AFEK, 48092 ROSH HAAYIN, ISRAEL.
Inventors:
# Inventor's Name Inventor's Address
1 PELEG, SHARON BIALIK STREET 58, 47205 RAMAT HASHARON, ISRAEL
PCT International Classification Number G06F 9/44
PCT International Application Number PCT/IL99/00446
PCT International Filing date 1999-08-18
PCT Conventions:
# PCT Application Number Date of Convention Priority Country
1 125846 1998-08-19 Israel