WO2004092977A2 - System and method in a data table for creating recursive scalable template instances - Google Patents

System and method in a data table for creating recursive scalable template instances Download PDF

Info

Publication number
WO2004092977A2
WO2004092977A2 PCT/EP2004/003048 EP2004003048W WO2004092977A2 WO 2004092977 A2 WO2004092977 A2 WO 2004092977A2 EP 2004003048 W EP2004003048 W EP 2004003048W WO 2004092977 A2 WO2004092977 A2 WO 2004092977A2
Authority
WO
WIPO (PCT)
Prior art keywords
recursive
scalable template
instance
cells
meta
Prior art date
Application number
PCT/EP2004/003048
Other languages
French (fr)
Other versions
WO2004092977A3 (en
Inventor
Jean-Jacques Aureglia
Frederic Bauchot
Original Assignee
International Business Machines Corporation
Compagnie Ibm France
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by International Business Machines Corporation, Compagnie Ibm France filed Critical International Business Machines Corporation
Priority to US10/553,494 priority Critical patent/US7636882B2/en
Priority to DE602004003230T priority patent/DE602004003230T2/en
Priority to EP04715322A priority patent/EP1618491B1/en
Publication of WO2004092977A2 publication Critical patent/WO2004092977A2/en
Publication of WO2004092977A3 publication Critical patent/WO2004092977A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/166Editing, e.g. inserting or deleting
    • G06F40/177Editing, e.g. inserting or deleting of tables; using ruled lines
    • G06F40/18Editing, e.g. inserting or deleting of tables; using ruled lines of spreadsheets

Definitions

  • the present invention relates to the field of information processing by digital computers, more particularly to a method and system, in a data table, preferably an electronic spreadsheet, for creating recursive scalable template instances.
  • a typical, common, and valuable example of such a set of data organized into columns and rows is a range of cells. Even if a range of cells receives a formal and strict definition within electronic spreadsheet environments, it is flexible enough so that information can be included in either a single range of cells or in a set of several ranges of cells. Ranges of cells therefore are quite useful objects.
  • a range of cell can be defined and processed as a whole entity. For example it can be copied from one place to another place within the spreadsheet or from one spreadsheet file to another spreadsheet file. Ranges of cells are widely used in applications developed in the field of electronic spreadsheets.
  • the ranges of cells are arranged according to some kind of structure, thus becoming structured ranges of cells.
  • the contents of each cell is defined within an element, where an element is defined as a row of a structured range of cells, and then the same kind of element is repeated a certain number of times, to store/process a variable number of information pieces.
  • an element is defined as a row of a structured range of cells, and then the same kind of element is repeated a certain number of times, to store/process a variable number of information pieces.
  • several instances of similar structured ranges of cells are used.
  • instances of such similar structured ranges of cells are frequently created through cut/copy and paste operations.
  • human being needs to organize or structure this information.
  • the hierarchical model is often used, because allowing nested structures.
  • a typical and well known example of such a hierarchical structure is the directory tree of computer Operating Systems, such as DOS (Disk Operating System) or Microsoft Windows.
  • the root directory may contain files and/or a number of directories, which may themselves contain files and/or a number of directories, which may themselves contain files and/or a number of directories, etc.
  • Recursivity help structure the information and maintain intellectual control over it. This need for recursivity applies as well, in spreadsheet environment to structured ranges of cells. When several instances of structured ranges of cells are defined and used in an electronic spreadsheet file, they are often themselves structured according to a specific superstructure arrangement or "array of structured ranges of cells" which can be duplicated between different electronic spreadsheet files or even within a single electronic spreadsheet file.
  • This invention develops the concepts of pattern data and variable data that may be integrated to generate a worksheet file through a worksheet file generator.
  • this invention shows many limitations preventing it from solving the set of issues presented here above and, in particular : • It aims at producing a new output spreadsheet from a set of two input files, while there is a need, within a user application environment, to create and manipulate new entities within an existing electronic spreadsheet file, that the user is familiar with.
  • the present invention is directed to a method, system and program, in a multidimensional electronic data table comprising a plurality of data, preferably a multidimensional electronic spreadsheet comprising a plurality of cells, for creating one or plurality of recursive scalable template instances; a recursive scalable template instance comprising a variable number of contiguous recursive element instances ordered and aligned along a first data table dimension and structured according to a recursive scalable template; a recursive element instance being defined as comprising one or a plurality of scalable template instances; a scalable template instance comprising a variable number of elements structured according to a scalable template; an element being defined as a range of data; a range of data comprising one or a plurality of data; a recursive scalable template comprising a recursive element comprising one or a plurality of scalable templates.
  • the method comprises for each recursive scalable template instance to create, the steps of: • Selecting a recursive
  • Figure 1 A is a schematic view of a computer system in which the present invention may be embodied.
  • Figure 1B is a schematic view of a software system including an operating system, an application software, and a user interface for carrying out the present invention.
  • Figure 2 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for managing RST's.
  • Figure 3 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing EF's.
  • Figure 4 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing EP's.
  • FIG. 5 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing ST's.
  • Figure 6 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing RST's.
  • Figures 7A, 7B, 7C, 7D, and 7E respectively illustrate the structure of the EF Table (EFT), of the EP Table (EPT), of the ST Table (STT), of a ST Descriptor Table (STDT), of the STI Table (STIT), according to the preferred embodiment of the present invention.
  • ° Figure 7F gives a graphical illustration of the relationships established between the tables EFT, EPT, STT, STDT, STIT, RET, RSTT, RSTDT, RSTIT and RSTIDT according to the preferred embodiment of the present invention.
  • ° Figure 8 is a flow chart illustrating a preferred method for managing RST objects according to a preferred embodiment of the present invention.
  • ° Figure 9 is a flow chart illustrating a preferred method for editing EF's and MEF's according to a preferred embodiment of the present invention.
  • ° Figure 10 is a flow chart illustrating a preferred method for editing EP's and MEP's according to a preferred embodiment of the present invention.
  • ° Figures 11 is a flow chart illustrating a preferred method for editing a ST according to a preferred embodiment of the present invention.
  • Figures 12 is a flow chart illustrating a preferred method for editing a RST according to a preferred embodiment of the present invention.
  • Figure 13A shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for creating STI's.
  • Figure 13B illustrates the ST instanciation, according to a preferred embodiment of the present invention.
  • Figure 14A is a flow chart illustrating a preferred method for instanciating a ST according to a preferred embodiment of the present invention.
  • Figure 14B is a flow chart illustrating a preferred method for creating a STI according to a preferred embodiment of the present invention.
  • Figure 15A illustrates the logical structure of a RSTI, according to the preferred embodiment of the present invention.
  • Figure 15B illustrates the logical structure of a RST, according to the preferred embodiment of the present invention.
  • Figures 16A and 16B constitute a flow chart illustrating a preferred method for creating
  • RSTI's according to a preferred embodiment of the present invention.
  • FIGS 17A, 17B, 17C, 17D, 17E and 17F respectively illustrate the structure of the RE
  • RSTIT RSTI Descriptor Table
  • RSTIDT RSTI Descriptor Table
  • Figure 18A shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for creating RSTI's.
  • Figure 18B shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing RE's.
  • Figure 18C is a flow chart illustrating a preferred method for editing RE's in RST's according to a preferred embodiment of the present invention.
  • Figure 19A is a flow chart illustrating a preferred method for computing the number of rows comprised in a STI according to a preferred embodiment of the present invention.
  • Figure 19B is a flow chart illustrating a preferred method for computing the number of columns comprised in a STI according to a preferred embodiment of the present invention.
  • the present invention may be embodied on a computer system 100 comprising a central processor 101, a main memory 102, an input/output controller 103, a keyboard 104, a pointing device 105 (e.g., mouse, track ball, pen device, or the like), a display device 106, and a mass storage 107 (e.g., hard disk). Additional input/output devices, such as a printing device 108, may be included in the system 100 as desired. As illustrated, the various components of the system 100 communicate through a system bus 110 or similar architecture.
  • the computer system 100 includes an IBM-compatible personal computer, which is available from several vendors (including International Business Machine - IBM Corporation of Armonk, N.Y.).
  • a computer software system 150 is provided for directing the operation of the computer system 100.
  • Software system 150 which is stored in system memory 102 and on disk memory 107, includes a kernel or operating system 151 and a shell or interface 153.
  • One or more application programs, such as application software 152, may be "loaded” (i.e., transferred from storage 107 into memory 102) for execution by the system 100.
  • the system 100 receives user commands and data through user interface 153; these inputs may then be acted upon by the system 100 in accordance with instructions from operating module 151 and/or application module 152.
  • the interface 153 which is preferably a graphical user interface (GUI), also serves to display results, whereupon the user may supply additional inputs or terminate the session.
  • GUI graphical user interface
  • operating system 151 and interface 153 are Microsoft Win95, available from Microsoft Corporation of Redmond, Wash.
  • Application module 152 includes a spreadsheet notebook of the present invention as described in further detail herein below.
  • each meta-element of the header part may be defined in terms of attributes by a MEF, and in terms of contents by a MEP.
  • the structure of ail elements of the body part may be defined in terms of attributes by an EF, and in terms of contents by an EP.
  • each meta-element of the footer part may be defined in terms of attributes by a MEF, and in terms of contents by a MEP.
  • the ST defines a structure by specifying the number of fields, by referring to a couple of EF and EP that defines all body elements, and, optionally, by referring to one or several couples of MEF and MEP that define each meta-element of the header part or the footer part.
  • a RST can be seen as a two level structure.
  • the highest level is logically equivalent to the structure of a ST, as a set of structured RE and RME's which can be logically mapped to element and meta-elements.
  • the recursive nature of a RST appears at the lower structural level, because the RE and RME's are objects which themselves comprise STI's (instead of conventional spreadsheet cells, as it is the case for elements and meta-elements).
  • a RST is a tiered structure of ST's.
  • a RSTI presents a structure logically equivalent to the structure of a STI, but constituted by container ranges instead of individual cells. Within each container range, a lower level structure is present in the form of STI's. As a result a RSTI can be seen as a STI itself containing STI's in lieu of conventional cells. Such an object was therefore first introduced under the name of "an array of structured ranges of cells".
  • FIG 15A and 15B a simple example of such a RST and RSTI will be used to illustrate the present application.
  • the RST 2051 named "RST_customet" defines the structure followed by a Network Services Provider to record all the various data corresponding to a customer receiving networking services. This RST is organized around a structure comprising:
  • the customer data such as company name, address, business, contract schedule, etc.
  • a body part 2053 where is recorded, for each customer resource receiving services from the service provider, the information required to manage this resource (such as location,
  • a footer part 2054 where is recorded the billing status for this customer, according to the structure of a ST named "ST_billind', and where are recorded the problem statistics for the customer managed resources, according to the structure of a ST named "ST_stat ⁇ '.
  • ST_billind' the structure of a ST named "ST_billind'”
  • ST_stat ⁇ ' the problem statistics for the customer managed resources
  • the header part 2002 contains four STI's which are themselves organized according to the structure of the RST header part 2052, and which abide by the structures of the ST's ""ST_cust_data", “ST_contact ⁇ "ST_SLA”, and "ST_support_tea n .
  • the body part 2003 is constituted by three different records 2010, 200 ⁇ , and 2008, each of them organised according to the structure of the RST body part 2053, that is comprising two STI's which abide by the structures of the ST's "ST_res_infd and "ST_cpb_lod'.
  • the footer part 2004 contains two STI's which are themselves organized according lo the structure of the RST footer part 2054, and which abide by the structures of the ST's u ST_billind', and "ST_stat ⁇ '. Most often also, several instances of similar recursively structured ranges of cells are used. Within the logic of our example, as described above and illustrated in FIG 15A, a similar recursively structured range of cells is created for each customer in a new sheet. In the current context of electronic spreadsheet environment, where no other tool is really available, instances of such similar recursively structured ranges of cells are frequently created through cut/copy and paste operations. We have already described the limitations of conventional tools for creating STI's.
  • the creation of a RSTI is even more difficult and prone to errors due to the twofold structure of a RSTI. Indeed the additional difficulty appearing when manipulating such recursive objects is to determine the structural level at which should occur a given operation (such as copy-pasting a recursive object, identifying areas containing row data or structure specific data within a recursive object, adjusting the size of a recursive object, emptying some fields within a recursive object, correcting any error resulting from the previous operations applied to a recursive object, and filling default values in some fields within a recursive object).
  • a given operation such as copy-pasting a recursive object, identifying areas containing row data or structure specific data within a recursive object, adjusting the size of a recursive object, emptying some fields within a recursive object, correcting any error resulting from the previous operations applied to a recursive object, and filling default values in some fields within a recurs
  • each RME of the header part is defined as an ordered collection of superstructure fields, each corresponding to a ST.
  • the structure of all RE's of the body part is defined as an ordered collection of superstructure fields, each corresponding to a ST.
  • the structure of each RME of the footer part is defined as an ordered collection of superstructure fields, each corresponding to a ST.
  • This superstructure is called a RST.
  • the RST defines a superstructure by specifying the number of fields, by referring to a RE that defines the body part, and, optionally, by referring to one or several RME's that define the header part and/or the footer part.
  • RST's and underneath defined objects known as RE's and RME's. Create, or update RE's. • Create, or update RME's. Create, or update a RST. Create a RSTI abiding by a defined RST.
  • the above set of functions is supported by a set of tools : the "RST Manager” method, or RSTM method for short; • the “RE Editor” method, or REE method for short; the “RST Editor” method, or RSTE method for short; the "RSTInstanciator” method, or RSTI method for short. This set of functions is defined in much further details, in the following sections.
  • a RST is developed to define the generic structure of the "NSP Customer Repository” and thus to facilitate the creation of several instances of said "NSP Customer Repository".
  • the RST defining the structure of "NSP Customer Repository” : ° (i) Specifies the number of superstructure fields, 2 (two) in our example.
  • Structured Range of Cells is a range of cells that abides by some kind of structure organizing the data into rows and columns. Columns define fields aimed at containing the same kind of information on each row. Rows define records (or elements). Table : the word table can be used to designate a structured range of cells. Field : a field is a labeled column in a database or table that contains the same kind of information for each record (or element). For example, a customer table may contain fields labeled Name, Address and Tel #.
  • a given field refers to the cell located at the intersection of the record (or element) and the given field (labeled column).
  • the above definitions are for a 2D environment where columns define fields and rows define records. They can be transposed in a 2D environment where rows define fields and columns define record. They can also be transposed in a 3D environment, where, for example, sheets define records.
  • IN/OUT Cell a cell is specified as "IN” cell when assumed to be used for recording user provided information. A cell is specified as "OUT” cell when assumed to be used for producing information (generally obtained through formulas whose arguments refer directly or indirectly to "IN” cells).
  • Element Format is a spreadsheet object defining the structure of an element within a 2 dimensions or a 3 dimensions range of cells, in terms of format attribute :
  • Meta-Element Format is a spreadsheet object defining the structure of a meta-element within a 2 dimensions or a 3 dimensions range of cells, in terms of format attribute :
  • Element Profile an EP is a spreadsheet object defining the structure of an element within a 2 dimensions or a 3 dimensions range of cells, in terms of content and destination : s formulas for fields to be computed from data comprised in other fields of the same element, or in other fields of another element or meta-element of the same STI, or even in other fields outside the STI. • field default values to be assigned at element creation time.
  • Meta-Element Profile a MEP is a spreadsheet object defining the structure of a meta-element within a 2 dimensions or a 3 dimensions range, in terms of content and destination : • formulas for cells to be computed from data comprised in other cells of the same element, or in other cells of another element or meta-element of the same STI, or even in other cells outside the STI.
  • a ST is a spreadsheet object defining the structure of a 2 dimensions or a 3 dimensions range of cells, in terms of ⁇ element + meta-elements ⁇ layout.
  • the word “scalable” refers to the capability of the ST of defining a given structure for variable size (e.g. ranging from a minimum value to a maximum value) range of cells.
  • the ST defines a structure by : • specifying the number of fields,
  • such MEF's / MEP's are either located above the EF / EP, constituting the ST “header” part, or located below the EF / EP, constituting the ST “footer” “ part. Either the ST “header” part or the ST “footer” part, or both of them may be empty.
  • the ST only carries contents information and can thus be named Scalable Profiled Template.
  • the element and meta-element references are only constituted by EF's and MEF's, then the ST only carries format information and can thus be named Scalable Formatted Template.
  • Scalable Template Instance also referred to as "Instance” or “scalable instance” or “STI”
  • a STI is a spreadsheet object abiding by the structure of a defined ST : a scalable formatted template, or a scalable profiled template, or a scalable profiled & formatted template.
  • An STI may be viewed as a heir object of a ST.
  • An element is a spreadsheet object belonging to a STI, and made of elementary fields abiding either by an EF, or by an EP, or by a couple (EF, EP) found in the parent structure (respectively scalable formatted template, or scalable profiled template, or scalable profiled & formatted template). Without loosing any generality, it is assumed that an element always abides by a couple (EF, EP), where either the EF or the EP can be reduced to a void object.
  • Meta-Element is a spreadsheet object belonging to an STI, and made of elementary cells abiding either by a MEF, or by a MEP, or by a couple (MEF, MEP). Without loosing any generality, it is assumed that a meta-element always abides by a couple (MEF, MEP), where either the MEF or the MEP can be reduced to a void object.
  • Recursive Element A RE is a spreadsheet object belonging to a RST, constituting the body part of the RST, and made of elementary fields used to record the names of ST's. A RE has a structure similar to the structure of an element, but instead of being instanciated as a range of cells, is instanciated as a range of STI's.
  • a RME is a spreadsheet object belonging to a RST, belonging to the header and/or footer part of the RST, and made of elementary fields used to record the names of ST's.
  • a RME has a structure similar to the structure of a meta-element, but instead of being instanciated as a range of cells, is instanciated as a range of STI's.
  • Recursive Scalable Template also referred to as "Recursive Template” or “RST”:
  • a RST is a spreadsheet object defining the superstructure of a 2 dimensions or a 3 dimensions range of cells, in terms of ⁇ RE + RME's ⁇ layout.
  • the word “scalable” refers to the capability of the RST of defining a given superstructure for variable size (e.g. ranging from a minimum value to a maximum value) range of cells.
  • the RST defines a superstructure by :
  • RME's are either located above the RE, constituting the RST "header” part, or located below the RE, constituting the RST "footer” part. Either the RST "header” part or the RST “footer” part, or both of them may be empty.
  • a RST 2051 is illustrated in FIG 15B. It is constituted by a header part 2052, a body part 2053 and a footer part 2054. The header part comprises two RME's 2058 and
  • the body part comprises one RE 2056 with two fields which respectively contains the name of the ST's "ST_res_infd', "ST_pb_lod'.
  • the footer part comprises one RME 2055 with two fields which respectively contains the name of the ST's "ST_billind', "ST_stat ⁇ Recursive Scalable Template Instance (also referred to as "Recursive Instance” or “Recursive Scalable Instance” or as RSTI):
  • a RSTI is a spreadsheet object abiding by the structure of a defined RST.
  • a RSTI may be viewed as a heir object of a RST. It contains a variable number of container rows (at least one) containing one or a plurality of STI's, corresponding to the parent RE structure, and constituting the "body” part, plus optionally one or several other container rows containing one or a plurality of STI's, corresponding to the parent RME's structure, and constituting the "header" part and the "footer” part of the RSTI.
  • Example: A RSTI 2001 is illustrated in FIG 15A. This RSTI abides by the RST 2051 as illustrated in FIG 15B. It is constituted by a header part 2002, a body part 2003 and a footer part 2004.
  • the header part comprises two container rows 2012 and 2011.
  • the body part comprises three container rows 2010, 2009 and 2008.
  • the footer part comprises one container row 2007.
  • Each container row contains two container ranges, such as the container range 2014 which can be seen as the intersection of the top container row 2012 and of the right container column 2005.
  • Each container range contains a STI which abides by the structure of the ST defined as part of the RE or RME member of the RST 2051.
  • the STI 2034 comprised within the container range intersection of the container row 2010 and of the container column 2005 abides by the structure of the ST named "ST_pb_lod', as defined in the RME 2056 of the RST 2051, and is itself constituted by a header part 2015, a body part 2016 and a footer part 2017.
  • Container rows are a spreadsheet object belonging to a RSTI, and corresponding to the range of cells containing the STI's which are structured according to the definition of a RE or of a RME part of the RST that the RSTI abides by.
  • the number of rows of a container row is equal to the number of rows of the highest STI it contains.
  • a container row can also be referred to as a recursive element instance.
  • a container row can be seen within a RSTI as equivalent to an element within a STI.
  • Example : The container row 2012 is illustrated in FIG 15A, and corresponds to the range of cells comprising the STI's 2032 and 2013 which are defined within the RSTI 2001.
  • the number of rows of this container row is equal to the number of rows of the STI 2032 which is higher than the STI 2013.
  • Container columns are a spreadsheet object belonging to a RSTI, and corresponding to the range of cells containing the STI's which occupy the same superstructure position within the container rows of the RSTI.
  • the number of columns of a container column is equal to the number of columns of the widest STI it contains.
  • Example : The container column 2006 is illustrated in FIG 15A, and corresponds to the range of cells comprising the STI's occupying the leftmost position within the RSTI 2001.
  • the number of columns of this container column is equal to the number of columns of the STI 2030 which is the widest STI on the left side of the RSTI 2001.
  • Container ranges are a spreadsheet object belonging to a RSTI, and corresponding to the intersection of a container row and of a container column. Each container range contains a single STI which occupies the top and leftmost corner. A container range within a RSTI can be seen as equivalent to a single cell within a STI.
  • ⁇ a ⁇ corresponds to the multiplication of the terms a, the index i belonging to the set s.
  • LCM( ⁇ a ⁇ )te corresponds to the Least Common Multiplier of the terms a ⁇ , the index i belonging to the set s. If S is constituted by a single element a, then LCM( ⁇ ai ⁇ ) ie ⁇ is equal to a.
  • a Mod b corresponds to the remainder of the division of a by b.
  • the preferred embodiment of the present invention relies on different types of objects for managing RST's. These objects are recorded in different repositories, so that they can be accessed and updated by the different methods which are part of the preferred embodiment of the present invention.
  • Such repositories are referred to as tables:
  • the EFT, EPT, STT, STDT, STIT, RET, RSTT, RSTDT, RSTIT, and RSTIDT tables are saved as part of the spreadsheet disk file on the mass storage 107, whereas the RSTMT table is temporarily saved on the main memory 102.
  • C1. EF Table Referring now to FIG. 7A, the EFT Table 700 corresponds to a logical simple structure made of several records 701, each of them corresponding to an EF or to a MEF, according to the present invention. Each record includes six fields:
  • the "Name” 702 field is used for recording a character string which uniquely identifies the EF or the MEF described by the current record 701.
  • the "Last Change Date” 703 field is used for recording the date of the last update of the EF or the MEF described by the current record 701.
  • a The "Description Ptr” 704 field is a reference pointing to the memory location where is recorded an illustrative range of cells depicting the EF or MEF described by the current record 701. This memory location can either be on the Mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
  • the "Row #" 705 field is used for recording the number of rows present in the EF or in the MEF described by the current record 701. This field is relevant for 3D ST's where element or MEF's correspond to 2D structures. In the preferred embodiment of the present invention where 2D ST's are assumed, this field is always filled with the value 1.
  • the "Column #"706 field is used for recording the number of columns present in the EF or in the MEF described by the current record 701.
  • the "Type” 707 field is used for recording different attributes associated to the EF or to the MEF described by the current record 701 : this is the "META” attribute 708 specifying if the current record 701 describes an EF or a MEF (with respective values "NO” and “YES"), and the "REFERENCED” attribute 709 specifying through dedicated subfields (709a, 709b, 709c, 709d and 709e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED” attribute 2240. Conventional techniques can be used for encoding these different attributes in this "Typd' field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention. C2. EP Table
  • the EPT Table 710 corresponds to a logical simple structure made of several records 711, each of them corresponding to an EP or to a MEP, according to the present invention.
  • Each record includes six fields:
  • the "Name” 712 field is used for recording a character string which uniquely identifies the EP or the MEP described by the current record 711.
  • the "Last Change Date” 713 field is used for recording the date of the last update of the EP or the MEP described by the current record 711.
  • the "Description Ptr" 714 field is a reference pointing to the memory location where an illustrative range of cells depicting the EP or MEP described by the current record 711 is recorded.
  • This memory location can either be on the Mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
  • the "Row #”715 field is used for recording the number of rows present in the EP or in the MEP described by the current record 711. This field is relevant for 3D ST's where element or MEP's correspond to 2D structures. In the preferred embodiment of the present invention where 2D ST's are assumed, this field is always filled with the value 1. °
  • the "Column #”71 field is used for recording the number of columns present in the EP or in the MEP described by the current record 711.
  • the Type” 717 field is used for recording different attributes associated to the EP or to the MEP described by the current record 711: this is the "META” attribute 718 specifying if the current record 701 describes an EP or a MEP (with respective values "NO” and “YES"), and the "REFERENCED” attribute 719 specifying through dedicated subfields (719a, 719b, 719c, 719d and 719e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED” attribute 2240. Conventional techniques can be used for encoding these different attributes in this "Type” field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention.
  • the STT Table 720 corresponds to a logical simple structure made of several records 721 , each of them corresponding to a ST, according to the present invention.
  • Each record includes six fields: o
  • the "Name” 722 field is used for recording a character string which uniquely identifies the ST described by the current record 721.
  • the "Last Change Date” 723 field is used for recording the date of the last update of the ST described by the current record 721.
  • the "Description Ptr" 724 field is a reference pointing to the memory location where a description of the ST described by the current record 721 is recorded.
  • This memory location can either be on the mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
  • This description is structured according to the STDT table 760 illustrated in FIG 7D, that is as an ordered list of couples of names, each couple being made by the name of an element or MEF and by the name of an element or MEP.
  • the "Min Element #"725 field is used to record the minimum number of elements found in each STI abiding by the ST described by the current record 721.
  • the "Max Element #" 726 field is used to record the maximum number of elements found in each STI abiding by the ST described by the current record 721.
  • the "Type” 727 field is used for recording different attributes associated to the ST described by the current record 721 : this is the "META” attribute 728 which always take the value "NO”, and the "REFERENCED” attribute 729 specifying through dedicated subfields (729a, 729b, 729c, 729d and 729e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED” attribute 2240. Conventional techniques can be used for encoding these different attributes in this "Type” field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention. C4. ST Descriptor Table
  • the STDT Table 760 corresponds to a logical simple structure made of several couples of element or MEF 765 and of element or MEP 764. This structure is organized into three sub-sets:
  • the optional ST "Headei” part 767 made of a variable number (possibly null) of couples like the top couple 761.
  • Each of these couples is constituted by a MEF (column 765) and by a MEP (column 764).
  • the mandatory "Body” part 762 made of a single couple constituted by an EF (column 765) and by an EP (column 764).
  • the optional ST "Foote part 766 made of a variable number (possibly null) of couples like the bottom couple 763. Each of these couples is constituted by a MEF (column 765) and by a MEP (column 764).
  • the STIT Table 750 corresponds to a logical simple structure made of several records 751, each of them corresponding to a STI, according to the preferred embodiment of the present invention.
  • Each record includes six fields: •
  • the "Address" 752 field is used for locating the STI described by the current record 751 : its value corresponds to the conventional character string used to record the address of any range of cells.
  • the "ST" 753 field is used for recording the name of the ST abided by the STI described by the current record 751.
  • the "Element #” 754 field is used for recording the number of elements within the STI described by the current record 751.
  • ° The "Critical” 755 field is used for recording if the STI described by the current record
  • the RET Table 2210 corresponds to a logical simple structure made of several records 2211 , each of them corresponding to a RE or to a RME, according to the present invention. Each record includes six fields:
  • the "Name” 2212 field is used for recording a character string which uniquely identifies the RE or the RME described by the current record 2211.
  • the "Last Change Date” 2213 field is used for recording the date of the last update of the RE or of the RME described by the current record 2211.
  • the "Description Ptr" 2214 field is a reference pointing to the memory location where is recorded an illustrative range of cells depicting the RE or the RME described by the current record 2211.
  • This memory location can either be on the Mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
  • the "Row #"2215 field is used for recording the number of rows present in the RE or in the RME described by the current record 2211. This field is relevant for 3D RST's where RE's or RME's correspond to 2D structures. In the preferred embodiment of the present invention where 2D RST's are assumed, this field is always filled with the value 1.
  • the "Column #" 2216 field is used for recording the number of columns present in the RE or in the RME described by the current record 2211.
  • the ype" 2217 field is used for recording different attributes associated to the RE or to the RME described by the current record 2211 : this is the "META” attribute 2218 specifying if the current record 2211 describes a RE or a RME (with respective values "NO” and “YES"), and the "REFERENCED” attribute 2219 specifying through dedicated subfields (2219a, 2219b, 2219c, 2219d and 2219e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED" attribute 2240. Conventional techniques can be used for encoding these different attributes in this 'Type” field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention. C7. RST Table
  • the RSTT Table 2220 corresponds to a logical simple structure made of several records 2221 , each of them corresponding to a RST, according to the present invention.
  • Each record includes six fields: e
  • the "Name" 2222 field is used for recording a character string which uniquely identifies the RST described by the current record 2221.
  • the "Last Change Date” 2223 field is used for recording the date of the last update of the RST described by the current record 2221.
  • the "Description Ptr” 2224 field is a reference pointing to the memory location where a description of the RST described by the current record 2221 is recorded. This memory location can either be on the mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
  • This description is structured according to the RSTDT table 2250 illustrated in FIG 17D, that is as an ordered list of RME or RE names.
  • the "Min Element #"2225 field is used for recording the minimum number of RE's found in every RSTI abiding by the RST described by the current record 2221.
  • the "Max Element #" 2226 field is used for recording the maximum number of RE's found in every RSTI abiding by the RST described by the current record 2221.
  • the Type" 2227 field is used for recording different attributes associated to the RST described by the current record 2221 : this is the "META” attribute 2228 which always take the value "NO”, and the "REFERENCED” attribute 222 ⁇ specifying through dedicated subfields (2229a, 2229b, 2229c, 2229d and 2229e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED” attribute 2240. Conventional techniques can be used for encoding these different attributes in this "Type” field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention.
  • the flSTMTTable 2230 corresponds to a logical simple structure made of several records 2231 , each of them corresponding to an object managed by the RST manager, according to the preferred embodiment of the present invention.
  • Each record includes seven fields:
  • the "Name” 2232 field is used for recording a character string which uniquely identifies the object described by the current record 2231.
  • the "Last Change Date” 2233 field is used for recording the date of the last update of the object described by the current record 2231.
  • the "Description Ptr" 2234 field is a reference pointing to the memory location where is recorded a description of the object described by the current record 2231.
  • This memory location can either be on the Mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
  • the "Info Field 1" 2235 field is used for recording a first piece of information associated to the object described by the current record 2231.
  • the "Info Field 2" 2236 field is used for recording a second piece of information associated to the object described by the current record 2231.
  • the Type" 2237 field is used for recording different attributes associated to the object described by the current record 2231 , such as:
  • FR E yOR, x LCiVi( ⁇ FR, ⁇ ), e y
  • the above formula allows to dynamically link the object described by the record 2231 with the objects constituting it, because any change in the value of one of the factors OR, or FR, will be automatically reflected into FR. If the set is empty (for instance when the object described by the record 2231 is an EP, or a MEP, or an EF, or a MEF), then the FR subfield defaults to the value 1 (one). • The "INSTANCE REFERENCE" (or IR for short) subfield 2240c. This subfield is initiated to the value 1 (one) when the object described by the record 2231 is created.
  • this subfield is multiplied by 2 (two) each time a new instance abiding by this object is created, and is divided by 2 (two) each time an existing instance abiding by this object is deleted.
  • This subfield is a Boolean variable specifying if the object described by the record 2231 participates to the definition of another object. For instance an EF, or a MEF, or an EP, or a MEP can participate to the definition of a ST. Similarly a ST can participate to the definition of a RE which can itself participate to the definition of a RST.
  • the above formula allows to dynamically link the object described by the record 2231 with the objects belonging to the -Pset, because any change in the value of one of the factors FRi will be automatically reflected into RO. If the object described by the record 2231 is an EF, or a MEF, or an EP, or a MEP, then the T set corresponds to the set of ST's. If the object described by the record 2231 is a
  • the fP set corresponds to the set or RE's. If the object described by the record 2231 is a RE, then the fPset corresponds to the set or RST's. If the object described by the record 2231 is a RST, then the set is empty (the top of the hierarchy being reached), so that the RO subfield defaults to the value "NO”. • The "SELECTED CHILDREN" (or SC for short) subfield 2240e. This subfield is a
  • the other "REFERENCED" attributes 709, 719, 729, 780, 2219, and 2229, as defined within the tables EFT 700, EPT 710, STT 720, RSTEIT 770, RET 2210, and RSTT 2220, are based on the same set of five subfields.
  • the "NATURE" attribute 2241 reflecting whether the object is a (M)EF, or a (M)EP, or a ST, or a R(M)E, or a RST (with respective values "FORMAT”, or “PROFILE” or “TEMPLATE” or “RECELEMENT” or “RECTEMPLATE” ).
  • Conventional techniques can be used for encoding these different attributes in this "Type” field 2237, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention.
  • the "Index” 2238 field is used for sorting the RSTMT table, as performed by the RST Manager method. C9.
  • RST Descriptor Table Referring now to FIG. 17D, the flSTDTTable 2250 corresponds to a logical simple structure made of several names of RE's or RME's 2254. This structure is organized into three sub-sets:
  • the optional RST "Headei" part 2256 made of a variable number (possibly null) of RME names like the top name 2251.
  • RSTIT Table 2260 corresponds to a logical simple structure made of several records 2261 , each of them corresponding to a RSTI, according to the preferred embodiment of the present invention. Each record includes six fields:
  • the "Address” 2262 field is used for locating the RSTI described by the current record 2261 : its value corresponds to the conventional character string used to record the address of any range of cells.
  • the "ST" 2263 field is used for recording the name of the RST abided by the RSTI described by the current record 2261.
  • the "Element #” 2264 field is used for recording the number of RE's within the RSTI described by the current record 2261.
  • the "Critical” 2265 field is used for recording if the RSTI described by the current record 2261 is considered as critical. Its content can take the values "YES” or "NO".
  • the "Header Size” 2266 field is used for recording the number of RME's constituting the Header part of the RSTI described by the current record 2261.
  • the "Footer Size” 2267 field is used for recording the number of RME's constituting the Footer part of the RSTI described by the current record 2261.
  • the RSTIDT Table 2270 corresponds to a logical simple structure made of several records 2271 , each of them made of several cells 2272, each of them corresponding to a STI member of the RSTI, according to the preferred embodiment of the present invention.
  • the RSTIT table 2270 is mapped to the structure of the associated RSTI with a top header part 2275 (possibly empty) constituted by one or several records 2271, with a middle body part 2274 constituted by one or several records 2271, and with a bottom footer part 2273 (possibly empty) constituted by one or several records 2271.
  • Each record 2271 comprises one or a plurality of individual cells 2272, the number of which corresponding to the number of STI's per RE.
  • Each record 2272 includes seven fields characterizing a STI member of the RSTI:
  • the "container_range” 2276 field is used for recording the address of the container range hosting the STI described by the record 2272. By referring to the FIG 15A, this field records the address of the container 2014 (intersection of the container row 2012 and of the container column 2005) if the record 2272 describes the STI 2013.
  • the "container_col” 2277 field is used for recording the number of columns of the container range hosting the STI described by the record 2272. By referring to the FIG 15A, this field records the column number 2028 if the record 2272 describes the STI 2013. • The "STI_col” 2278 field is used for recording the number of columns of the STI described by the record 2272. By referring to the FIG 15A, this field records the column number 2026 if the record 2272 describes the STI 2013.
  • the "STl_row” 2279 field is used for recording the number of rows of the STI described by the record 2272. By referring to the FIG 15A, this field records the row number 2027 if the record 2272 describes the STI 2013.
  • the "ST_name” 2280 field is used to record the name of the ST abided by the STI described by the record 2272.
  • the "container row' '2281 field is used for recording the number of rows of the container range hosting the STI described by the record 2272. By referring to the FIG 15A, this field records the row number 2029 if the record 2272 describes the STI 2013.
  • the "STIT_rec_ptr" 2282 field is used for pointing, within the STIT table 750, to the record 751 describing the STI described by the record 2272.
  • FIG. 7F some previously introduced tables RSTIT 2260, RSTIDT 2270, RSTT 2220, RSTDT 2250, RET 2210, STIT 750, STT 720, STDT 760, EFT 700 and EPT 710 are presented altogether to illustrate the relationships established between these tables and with either a RSTI RSTI 730 or a STI STI 797.
  • a solid bold arrow illustrates a pointer based relationship towards a table or a record
  • a dashed bold arrow illustrates an address based relationship towards a range of cells
  • a solid unbold arrow illustrates a name based relationship towards an object
  • a dashed unbold arrow illustrates a size based relationship towards an object.
  • the pointer based, address based and named relationships are identified by an index represented within a circle, according to the following sequence:
  • STI STI 797 made of the three parts "STI Header", "STI Bod and "STI Foote , a first address based relationship ⁇ is established between this STI STI 797 and a record 751 of the STIT table 750. • A second name based relationship ⁇ is then established between this record 751 and a record 721 of the STT table 720. This record 721 corresponds to the ST abided by the STI 797.
  • a third pointer based relationship ® is established between this record 721 and a STDT table 760 which describes the structure of the ST.
  • Each record of the STDT table 760 corresponds to a pair of an element or MEF name and of an element or MEP name.
  • a fourth name based relationship ⁇ is established between the element or MEF name and a record 701 of the EFT table 700.
  • a fifth name based relationship ⁇ is established between the element or MEP name and a record 711 of the EPT table 710.
  • a sixth pointer based relationship ⁇ is established between the record 701 and an illustrative range of cells 798 specifying the format attributes.
  • a seventh pointer based relationship ⁇ is established between the record 711 and an illustrative range of cells 799 specifying the profile content.
  • a ninth pointer based relationship ⁇ is established between this record 2261 and a RSTIDT table 2270 which describes the structure of the RSTI 730.
  • Each cell 2272 of the RSTIDT table 2270 comprise several fields 2276, 2277, 2278, 2279, 2280, 2281 and 2282 related to a given STI (like STI 797) member of the RSTI 730.
  • a tenth address based relationship ® is thus established between the 2276 field of the cell 2272 of the RSTIDT table 2270, and the container range comprising the STI STI 797.
  • An eleventh pointer based relationship ®® is also established between the 2282 field of the cell 2272 of the RSTIDT table 2270, and the record 751 of the STIT table 750 corresponding to the STI STI 797.
  • ⁇ A twelfth name based relationship ® ⁇ is then established between the record 2261 and a record 2221 of the RSTT table 2220. This record 2221 corresponds to the RST abided by the RSTI 730.
  • ° A thirteenth pointer based relationship ®® is established between this record 2221 and a RSTDT table 2250 which describes the structure of the RST. Each record of the RSTDT table 2250 corresponds to a RE or RME.
  • • A fourteenth name based relationship ®@ is established between the RE or RME name and a record 2211 of the RET table 2210.
  • a fifteenth pointer based relationship ⁇ ® is established between the record 2211 and a RE descriptor range of cells 731 containing the names of ST's.
  • a sixteenth name based relationship ⁇ ® is established between the RE descriptor range of cells 731 and a record 721 of the STT table 720.
  • a similar seventeenth name based relationship ®® is established between the cell 2272 of the RSTIDT table 2270 and a record 721 of the STT table 720.
  • the present invention is used within a scenario which articulates as a sequence of operations : * 1.
  • First Operation Creation of a STI or of a RSTI
  • the first operation occurs when the spreadsheet user decides, based on some criteria not detailed here, to either create a STI abiding by the structure of a ST or to create a
  • RST Manager The spreadsheet user invokes first an original specific command called "RST Manager" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to visualize through a dedicated user interface any existing EF or MEF or EP or MEP or RE or RME or ST or RST.
  • This RST manager offers different alternatives for further managing these entities. This can be illustrated with the user interface described with the FIG 2, showing the RST Manager Dialog Box 200, as displayed on the display device 106. Within this RST Manager Dialog Box 200, the user can visualize already defined objects (EF's, MEF's, EP's, MEP's, RE's, RME's, ST's and
  • RST's in the "list boxes" 213, 214 and 202 where are respectively specified the names of the objects, the types of the objects and their last date of update. If a large number of objects have been defined, then the user can navigate among them by clicking with the pointing device 105 either upwards on downwards on the scroll bar
  • the objects shown within the list boxes 213, 214 and 202 move back and forth between the top object and the bottom object.
  • the objects have been sorted by date of last update, but any other sorting scheme could be also used without departing from the spirit of the invention.
  • the user can use the pointing device
  • the pointing device 105 can click on a check box on the left side of the RST Manager Dialog Box 200 like the check box 212, in order to either select or deselect the object whose name is displayed within the list box 213 just on the right of the clicked check box.
  • One or multiple objects can be selected or deselected. List scrolling is of course reflected on the check boxes.
  • a conventional dialog box is displayed on the display device 106 to first alert the user about this situation and second to invite him to either cancel the deletion operation or to confirm it. If the user decision is to cancel the operation, then no action is taken, otherwise the selected objects are immediately deleted, so that they do no longer appear on the list boxes 213, 214 and 202.
  • the user can use the pointing device 105 to click on the "Edit' push-button 211 if he/she wants to edit the selected object which is assumed to be unique.
  • a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention.
  • the RST Manager Dialog Box 200 is first closed and afterwards the nature of this single selected object is taken into account to determine the new dialog box to be opened.
  • the selected object was an EF or a MEF
  • the EF Editor command is issued, so that the EF Editor method takes control by first displaying on the display device 106 the EF Editor Dialog Box 301, as illustrated in FIG 3. The following steps of this scenario case are detailed in a subsequent section.
  • the EP Editor command is issued, so that the EP Editor method takes control by first displaying on the display device 106 the EP Editor Dialog Box 401, as illustrated in FIG 4. The following steps of this scenario case are detailed in a subsequent section.
  • the RE Editor command is issued, so that the RE Editor method takes control by first displaying on the display device 106 the RE Editor Dialog Box 2321, as shown in FIG 18B. The following steps of this scenario case are detailed in a subsequent section.
  • the ST Editor command is issued, so that the ST Editor method takes control by first displaying on the display device 106 the ST Editor Dialog Box 501, as illustrated in FIG 5. The following steps of this scenario case are detailed in a subsequent section.
  • the user can use the pointing device 105 to click on the "Instanciate" push-button 204 if he/she wants to generate either a STI or a RSTI which abides by the selected object which is assumed to be unique and to be respectively a ST or a RST. If no object or multiple objects have been previously selected, as shown within the
  • RST Manager Dialog Box 200 by the presence of no or multiple check marks (visible or not) within the check boxes located on the left side, like the check box 212, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention.
  • a single object was previously selected, as shown by the presence of a single check mark (visible or not) within a check box located on the left side, like the check box 212, then the method checks if this object is a ST or a RST. If it is not the case, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. If a single ST (respectively RST) object was previously selected, then the RST Manager Dialog Box 200 is first closed and afterwards the ST Instanciator (resp. RST Instanciato ⁇ command is issued, so that the ST Instanciator (resp.
  • RST Instanciato ⁇ method takes control by first displaying on the display device 106 the ST Instanciator Dialog Box 1300 (resp. RST Instanciator Dialog Box 2300), as shown in FIG 13A (resp. 18A). The following steps of this scenario case are detailed in subsequent sections.
  • the user can use the pointing device 105 to click on the "Export' push-button 206 if he/she wants to export a non-empty set of objects from the current spreadsheet file to another spreadsheet file. If the check box "Including child objects (for Export)" 220 is filled with a check mark, then all the child objects of the selected objects will also benefit from the export operation, even if these child objects are not selected through the check boxes located on the left side, like the check box 212. If no object has been previously selected, as shown within the RST Manager Dialog
  • the RST Manager Dialog Box 200 is first closed and afterwards a specific RST Export Manager command is issued, so that a dedicated method, not described in the present invention, takes control to handle the export operation.
  • the user can use the pointing device 105 to click on the "Import' push-button 205 if he/she wants to import one or several objects from another spreadsheet file to the current spreadsheet file.
  • the RST Manager Dialog Box 200 is first closed and afterwards a specific RST Import Manager command is issued, so that a dedicated method, not described in the present invention, takes control to handle the import operation.
  • the user can use the pointing device 105 to click on one of the five option-buttons 217 "Format', 209 “Profile”, 216 "Template", 218 "RE', 219 "Recursive Template”, on the bottom left side of the RST Manager Dialog Box 200, if he/she wants to specify which type of new object may be created afterwards.
  • the user has the choice to specify either a EF, or a EP or a RE or a ST or a RST as the type of the new object to be created afterwards.
  • the user can use the pointing device 105 to click on the check-box 208 entitled “From current selection”, if he/she wants to specify if the next object to be created afterwards will be derived or not from the range of cells currently selected in the spreadsheet file.
  • the user can use the pointing device 105 to click on the "Create New" push-button 210 if he/she wants to create a new object whose type has been previously specified thanks to the three option-buttons like
  • a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. If one of these five option-buttons 209, 216, 217, 218 and 219 shows a previous user choice, then the RST Manager Dialog Box 200 is first closed and afterwards the single selected option-button is taken into account to determine the new dialog box to be opened. a If the "Format option-button 217 shows a selection, then the EF Editor command is issued, so that the EF Editor method takes control by first displaying on the display device 106 the EF Editor Dialog Box 301, as shown in
  • FIG 3. The following steps of this scenario case are detailed in a subsequent section.
  • the resulting effect is to close the RST Manager Dialog Box 200 on the display device 106.
  • EP Editor an original specific command called "EP Editor” thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new EP or to create a new MEP or to update an existing EP or to update an existing MEP.
  • PCT/EP 02/09483 IBM's reference FR9 2001 0029 entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al. d.
  • RE Editor an original specific command called "RE Editor” thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new RE or to create a new RME or to update an existing RE or to update an existing RME.
  • RE Editor an original specific command
  • FIG 18B shows the RE Editor Dialog Box 2321, as displayed on the display device 106 within the GUI window of the electronic spreadsheet office application.
  • the RE Editor Dialog Box 2321 is displayed on the display device 106, it contains some pieces of information.
  • option-buttons 2330 and 2331 which specifies if it is either a RE or a RME.
  • the spreadsheet user can click with the pointing device 105 on one of these two option-buttons 2330 and 2331 to swap between a RE definition and a RME definition.
  • the number of fields within the edited object is specified in the text-box 2326.
  • a new RE or RME the spreadsheet user having previously clicked with the pointing device 105 on the option-button 218 to put a point on it and on the push-button 210, all contained within the RST Manager Dialog Box 200, as illustrated by FIG 2)
  • the value shown by the text box 2326 corresponds to a default value set to 3 in a preferred embodiment of the present invention.
  • the value shown by the text box 2326 corresponds to the number of fields previously defined for this object.
  • the spreadsheet user can change the value shown in the text box 2326 by clicking with the pointing device 105 on the spin-button 2327, either on the ascending or on the descending side, so that the value can get increased or decreased (within predefined boundaries).
  • the name of the edited RE or RME is displayed on the label box 2324.
  • the name shown by the label box 2324 corresponds to the name previously assigned to this object.
  • the name displayed on the label box 2324 corresponds to a default value which, in a preferred embodiment of the present invention, takes the form "New XX" where XX is a counter ensuring the uniqueness of the assigned name.
  • the text box 2335 specifies a field rank, which by convention takes the value 1 for the leftmost field of the edited RE or RME, and takes the same value as the one displayed in the text box 2326 for the rightmost field of the edited RE or RME.
  • the text box 2334 specifies the name of the ST for the field whose rank is specified by the text box 2335.
  • the RE Editor Dialog Box 2321 contains several graphical objects which allow the spreadsheet user to take some actions.
  • the spreadsheet user can assign a new name to the currently edited RE or RME. For this purpose he/she will first use conventional means such as the keyboard 104 to specify within the text box 2325 the new name to be given to the edited RE or RME. Then he/she will use the pointing device 105 to click on the "Save As" push-button 2332. If the specified name entered within the text box 2325 was already assigned to an existing object or was not a valid name, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. This warning message informs the spreadsheet user about this situation and then prompts him for acknowledgment.
  • conventional means such as the keyboard 104 to specify within the text box 2325 the new name to be given to the edited RE or RME. Then he/she will use the pointing device 105 to click on the "Save As" push-button 2332. If the specified name entered within
  • the text box 2325 is cleared without further action. If the specified name entered within the text box 2325 was not yet assigned to an existing object and was a valid name, then the text box 2325 is cleared and the edited object is saved on the spreadsheet file under the new name which is in turn displayed within the label box 2324.
  • the spreadsheet user can save on the spreadsheet file the current definition of the edited object by clicking with the pointing device 105 on the "Save" push-button 2333. This event results in checking if the updated RE or RME is already referenced by an existing RST. If it is not the case, then the updated definition of the RE or RME is saved on the spreadsheet file. If it is the case, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. This warning message informs the spreadsheet user about this situation and then prompts him for either canceling the operation or for pursuing it.
  • the updated RE or RME definition is not saved while it is saved on the spreadsheet file in the second case.
  • the spreadsheet user can change the definition of the ST's constituting the edited RE or RME. For this purpose he/she will first navigate within the fields of the edited object by clicking with the pointing device 105 on the spin-button 2329 to either decrement or increment the rank of the field, as displayed in the text box 2335, and whose ST name is displayed in the text box 2334. The value taken by the field rank is kept within an interval lower bounded by the value 1 (one) and upper bounded by the value of the text box 2326.
  • the spreadsheet user can update the name of the ST for the field whose rank is displayed in the text box 2335 by clicking with the pointing device 105 on the spin-button 2328 to select an available ST name. Finally the user can use the pointing device 105 to click on the "Dond' push-button
  • the resulting effect is to close the RE Editor Dialog Box 2321 on the display device 106.
  • ST Editor thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new ST or to update an existing ST.
  • PCT/EP 02/09483 IBM's reference FR9 2001 0029 entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al.
  • RST Editor an original specific command called "RST Editor” thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new RST or to update an existing RST.
  • RST Editor an original specific command
  • FIG 6 shows the RST Editor Dialog Box 601, as displayed on the display device 106 within the GUI window 611 of the electronic spreadsheet office application.
  • the current sheet becomes a dedicated sheet entitled "Editor Spaed' 615 in a preferred embodiment of the present invention.
  • the RST to be edited appears as a range of cells 614 in the top left angle, with the top left cell at address B2.
  • the edited RST corresponds to a regular range of cells 614 within a sheet
  • conventional tools available in electronic spreadsheet environments cannot be used to update this range of cells 614.
  • the spreadsheet user will only be able to navigate within the range of cells 614 illustrating the RST, and to either insert or delete rows within the range of cells 614 illustrating the RST, by using dedicated means which are part of the RST Editor Dialog Box 601. Row insertion or deletion in the "Editor Spaed' sheet 615 will be disabled.
  • the "Editor Spaed' sheet 615 is write-protected to prevent the user to inadvertently modify the settings of the RE's or RME's defined as part of the RST illustrated by the range of cells 614.
  • the RST Editor Dialog Box 601 When the RST Editor Dialog Box 601 is displayed on the display device 106, it contains some pieces of information which either relate to the whole RST, as illustrated by the range of cells 61 , or which relate to the RE or RME pointed by the cell currently selected within this same range of cells 61 .
  • First the RE or RME pointed by the cell currently selected is shown by the "RE' combo box 610.
  • the spreadsheet user By clicking with the pointing device 105 on the arrow located on the right side of this "RE' combo box 610, the spreadsheet user can display and navigate within the list of defined RE's and RME's, then select a RE or RME of his/her choice and his/her choice appearing on the row where is located the currently selected cell within the range of cells 614.
  • the spreadsheet user changes the selected row within the range of cells 614, by clicking with the pointing device 105 on the "Up" push-button 619, or on the "Dowrt' push-button 616, then the name displayed within the combo box 610 is updated to specify the name of the RE or RME corresponding to the new selected row.
  • the spreadsheet user wishes to insert a new RME either in the header or in the footer part of the RST, he/she has just to click with the pointing device 105 on the "Add' push-button 617 to insert a new row within the range of cells 614, at the desired place above the last position of the currently selected cell. Then the range of cells 614 is updated with a new row being displayed on the window 611. Then the RST Editor Dialog Box 601 is updated by showing within the combo boxes 610 the name assigned by default to the introduced
  • the RST Editor Dialog Box 601 is updated by showing within the combo box 610 the name of the unique RE defined within the RST.
  • the minimum number of RE's allowed within a RSTI abiding by the edited RST is specified in the "MIN' text-box 606.
  • the maximum number of RE's allowed within a RSTI abiding by the edited RST is specified in the "MAX' text-box 609.
  • the value shown by the "MIN' text box 606 corresponds to a default value set to 1 in a preferred embodiment of the present invention
  • the value shown by the "MAX' text box 609 corresponds to a default value set to 16 in a preferred embodiment of the present invention.
  • the values shown by the text boxes 606 and 609 correspond respectively to the minimum and maximum number of RE's allowed in any RSTI abiding by the currently edited RST, as previously defined by the spreadsheet user.
  • the spreadsheet user can change the values shown in the text box "MIN' 606 or in the text box "MAX' 609 by clicking with the pointing device 105 respectively on the spin-button 607 or on the spin-button 608, either on the ascending or on the descending side, so that the values can get increased or decreased (within predefined boundaries), while ensuring that the value specified in the "MIN' text box 606 remains less than or equal to the value specified in the "MAX' text box 609.
  • the name of the edited RST is displayed on the label box 604.
  • the name shown by the label box 604 corresponds to the name previously assigned to this object.
  • the name displayed on the label box 604 corresponds to a default value which, in a preferred embodiment of the present invention, takes the form "New XX" where XX is a counter ensuring the uniqueness of the assigned name.
  • the RST Editor Dialog Box 601 comprises several graphical objects which allow the spreadsheet user to take some actions.
  • the spreadsheet user can assign a new name to the currently edited RST, if this RST is currently constituted by RE's and RME's having all the same number of fields. Indeed in this case the "Save As" push-button 612 is enabled, so that any click on it with the pointing device 105 is recognized as a valid event.
  • the spreadsheet user will first use conventional means such as the keyboard 104 to specify within the text box 605 the new name to be given to the edited RST. Then he/she will use the pointing device 105 to click on the "Save Ad' push-button 612.
  • a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. This warning message informs the spreadsheet user about this situation and then prompts her/him for acknowledgment. Then the text box 605 is cleared without further action. If the specified name entered within the text box 605 was not yet assigned to an existing object and is a valid name, then the text box 605 is cleared and the edited RST is saved on the spreadsheet file under the new name which is in turn displayed within the label box 604.
  • the spreadsheet user can save on the spreadsheet file the current definition of the edited RST, if this RST is currently constituted by RE's and RME's having all the same number of fields. Indeed in this case the "Savd' push-button 613 is enabled, so that any click on it with the pointing device 105 is recognized as a valid event. This event results in checking if the updated RST is already referenced by an existing RSTI. If it is not the case, then the updated definition of the RST is saved on the spreadsheet file. If it is the case, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention.
  • This warning message informs the spreadsheet user about this situation and then prompts him for either canceling the operation or for pursuing it.
  • the updated RST definition is not saved while it is saved on the spreadsheet file in the second case.
  • the user can use the pointing device 105 to click on the "Done" push-button 603 or on the closing-window push-button 602 if he/she wants to quit the RST Editor method.
  • the resulting effect is to close the RST Editor Dialog Box 601 on the display device 106 and to revert to the sheet which was active when the RST Editor command was first invoked.
  • ST Instanciator According to the previous scenario illustrating the RST
  • the spreadsheet user may then invoke an original specific command called "ST Instanciator" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to create a STI abiding by a selected ST and located according to the currently selected cell.
  • ST Instanciator an original specific command
  • PCT/EP 02/09483 IBM's reference FR9 2001 0029
  • RST Instanciator According to the previous scenario illustrating the RST Manager method, the spreadsheet user may then invoke an original specific command called "RST instanciator" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to create a RSTI abiding by a selected RST and located according to the currently selected cell.
  • RST instanciator an original specific command
  • FIG 18A shows the RST Instanciator Dialog Box 2300, as displayed on the display device 106.
  • the current sheet remains still active, so that the spreadsheet user can visualise the data present on it.
  • the RST Instanciator Dialog Box 2300 contains some pieces of information which relate to the instanciation operation.
  • the number of RE's to be present at RSTI creation time is shown in a text box 2311.
  • This number takes a default value equal to the minimum number of RE's, as specified in the definition of the RST that abides by the RSTI to be created. If the spreadsheet user wished to create a RSTI with another number of RE's, then he/she will have to click with the pointing device 105 on the upper or lower side of the spin-button 2303 to either increase or decrease the number of RE's.
  • This number of RE's will vary within a range delimited by the minimum and maximum number of RE's, as specified within the definition of the RST (fields "Min Element #" 2225 and
  • This push-button "Create Instancd' 2310 when first enabled and second clicked with the pointing device 105 by the spreadsheet user, is the trigger launching the operation of RST instanciation.
  • This push-button "Create Instancd' 2310 is enabled (meaning that the method recognises the click event with the pointing device 105 on this push-button "Create Instancd' 2310) when the instanciation operation is possible.
  • the fact that this RST instanciation is possible or not depends on different factors: the position of the currently selected cell within the current sheet of the electronic spreadsheet, the size of the RSTI to be created, the presence of any existing STI belonging to the same sheet as the currently selected cell.
  • the possibility to create or not a new RSTI with the size specified in the text box 2303, abiding by a RST whose name is specified by the label box 2302, with the top left corner located on the currently selected cell, is reflected by several label boxes, taking the values "YES" or "NO", which are part of the RST Instanciation Dialog Box 2300: the label box 2304 which reflects if the new RSTI is or not too wide, the label box 2305 which reflects if the new RSTI is or not too high, the label box 2306 which reflects if any existing STI is already defined on the sheet comprising the currently selected cell, and the label box 2307 which reflects if the creation of the new RSTI may lead to loose any existing data present in one or several spreadsheet cells.
  • the push-button "Create instance in a new sheet' 2309 when first enabled and second clicked with the pointing device 105 by the spreadsheet user, is an alternative trigger launching the operation of RST instanciation, but in a sheet which is created as part of this instanciation operation.
  • the new sheet is created after the sheet comprising the currently selected cell. Any other sheet position could be used instead, without departing from the spirit of the current invention.
  • This push-button "Create instance in a new sheet' 2309 is enabled (meaning that the method recognises the click event with the pointing device 105 on this push-button "Create instance in a new sheet' 2309) when the instanciation operation is possible in a new sheet.
  • this RST instanciation is possible or not in a new sheet depends on the size of the RSTI to be created.
  • the possibility to create or not a new RSTI in a new sheet with the size specified in the text box 2303, abiding by a RST whose name is specified by the label box 2302, is reflected by several label boxes, taking the values "YES" or "NO", which are part of the RST Instanciation Dialog Box 2300: the label box 2304 which reflects if the new RSTI is or not too wide, and the label box 2305 which reflects if the new RSTI is or not too high.
  • the second operation occurs when the spreadsheet user decides, based on his or her own criteria not detailed here, to introduce new elements within a defined STI.
  • the corresponding scenario is described in international patent application PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al. • 3.
  • Third Operation Removal of Elements from a Defined STI
  • the fourth operation occurs when the spreadsheet user decides, based on his or her own criteria not detailed here, either to remove some elements from a defined STI, or to clear the content of some elements within a defined STI, or to delete a whole defined
  • PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al.
  • the method is in its default state, waiting for an event to initiate the process.
  • the RST Manager command is detected, as a result of a user action. This action can be for instance:
  • ° the local variable RSTM_seleci is set to the value 0 (zero)
  • ° the local variable RSTM_new is set to the value "NONE”
  • ° the local variable RSTM_range is set to the value "NO”
  • ° the local variable RSTMJndex is set to the value 1 (one)
  • 9 The local variable RSTM_child is set to the value "NO”.
  • the five tables EFT 700, EPT 710, STT 720, RET 2210 and RSTT 2220 are parsed to derive the table RSTMT 2230.
  • this construction is done by copying in sequence all the fields defined in the record 701 ("Name” field 702, "Last Change Date” field 703, “Description Ptf field 704, "Row #” field 705, “Column #” field 706 and “Type” field 707), or in the record 711 ("Namd' field 712, “Last Change Date 9 field 713, “Description Ptf field 714, “Row #” field 715, “Column #” field 716 and 'Type” field 717), or in the record 721 (“Namd' field 722, "Last Change Date” field 723, “Description Ptf' field 724, "Min Element #” field 725, “Max Element #” field 726 and “Type” field 727), or in the record 2211 ("Namd' field 2212, “Last Change Date” field 2213, "Description Ptf' field 2214, "Row
  • the "Type” information appearing on the top of the list box 214 is derived from the "Type” field 2237 (attributes “NATURE” 2241 and “META” 2239) of the record 2231 in the RSTMT table 2230 whose "Index" field 2238 is equal to the local variable RSTMJndex. Underneath "Type” information's within this list box 213 are derived from the "Type” field 2237 (attributes “NATURE” 2241 and “META” 2239) of the following records 2231 of the RSTMT table 2230.
  • the "Modified” information appearing on the top of the list box 202 corresponds to the "Last Change Date” field 2233 of the record 2231 in the RSTMT table 2230 whose "Index " ' field 2238 is equal to the local variable RSTMJndex.
  • Underneath "Modified” information's within this list box 213 correspond to the "Last Change Datd' field 2233 of the following records 2231 of the RSTMT table 2230.
  • the check box 212 is filled with a check mark if the 'Type" field 2237 of the record 2231 in the RSTMT table 2230 whose "Index " ' field 2238 is equal to the local variable RSTMJndex has the "SELECTED" attribute 2242 equal to "YES”. Underneath check boxes on the left of the list box 213 are also derived from the 'Type" field 2237
  • the option button "Format” 217 displays a black point if and only if the local variable RSTM_new is equal to "FORMAT”.
  • the option button “Profile” 209 displays a black point if and only if the local variable RSTM_new is equal to "PROFILE”.
  • the option button "Template” 216 displays a black point if and only if the local variable
  • RSTM_new ⁇ s equal to "TEMPLATE”.
  • the option button “RE” 218 displays a black point if and only if the local variable RSTM_new is equal to "RECELEMENT”.
  • the option button “Recursive Template” 219 displays a black point if and only if the local variable
  • RSTM_new is equal to "RECTEMPLATE”.
  • the check box "From current selection” 208 displays a check mark if and only if the local variable RSTM_range is equal to "YES”.
  • the check box "Including child objects (for Export)” 220 displays a check mark if and only if the local variable RSTM_child is equal to "YES”.
  • step 806 the method is waiting for any user action on the RST Manager Dialog Box 200.
  • user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
  • step 807 a user action on the RST Manager Dialog Box 200 is detected.
  • step 808 If the user action is a click on the push-button "Delete” 207, then control is given to step 808; if the user action is a click on the push-button "Import” 205, then control is given to step 810; • if the user action is a click on the push-button “Done” 201 or on the closing-window push-button 215, then control is given to step 834; if the user action is a click on the push-button "Export” 206, then control is given to step 811 ; if the user action is a click on the scrolling bar 203, either on the up direction or on the down direction, then control is given to step 814; if the user action is a click on the option buttons "Format" 217, or “Profile” 209, or “Template” 216, or “RE” 218, or “Recursive Template” 219, then control is given to step 815; if the user action is a click on the check box "From current
  • a test is performed on each of the records 2231 of the RSTMT table 2230 whose "Type" field 2237 has the "SELECTED" attribute 2242 with the subfield "REFERENCED OBJECT” (RO) 2240d equal to “YES” or with the subfield "INSTANCE REFERENCE” (IR) 2240C larger than 1 (one) (this test determines if there exist some objects referring to one of the selected objects, or if there exist some instance abiding by one of the selected objects).
  • step 835 meaning that at least one record 2231 of the RSTMT table 2230 previously selected was referenced by a ST, or by a STI, or by a RE, or by a RST, or by a RSTI);
  • each respective record 701 , 711 , 721 , 2211 and 2221 is removed from the EFT table 700, EPT table 710, STT table 720, RET table 2210, and RSTT table 2220, if the corresponding respective "Namd' field 702, 712, 722, 2212, and 2222 matches the "Namd' field 2232 of a record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", as resulting from the step 817. Then the local variable RSTM_select is reset to the value 0 (zero).
  • step 804 rebuilding the RSTMT table 2230.
  • step 810 the RST Import Manager command is issued and then control is given to step 834.
  • step 311 a test is performed to determine if the local variable RSTM_select is equal to 0 (zero).
  • step 813 If it is the case, then control is given to step 813;
  • step 812 the RST Export Manager command is issued and then control is given to step 834.
  • step 813 a warning message notification is issued for informing the user that at least one object must be selected prior clicking on the "Export" push-button 206. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • control is given to step 805.
  • step 814 the local variable RSTMJndex is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the scrolling bar 203, and as long as it value remains positive and less than or equal to the number of records 2231 defined within the RSTMT table 2230. Then control is given to step 805.
  • the local variable RSTM_new is updated to reflect the option button hit by the user with the pointing device 105.
  • the local variable RSTM_new takes the value "PROFILE”. • If the user has clicked on the "Template” option button 216, then the local variable RSTM_new takes the value "TEMPLATE”.
  • step 805. the local variable RSTM_range is updated, so that its value swaps between "YES” and "NO".
  • a check mark is respectively added within or removed from the check box 206 if it was previously absent or present in this same check box 206.
  • step 805. the method updates the value of the 'Type" field 2237 of the record 2231 within the RSTMT table 2230, whose "Name" field 2232 is found equal to the character string located within the list box 213 immediately on the right of the check box on which the user has just clicked.
  • the value update consists in turning this "SELECTED” attribute 2242 to "NO” ; reversibly if the previous value of the "SELECTED” attribute 2242 was equal to "NO”, then the value update consists in turning this "SELECTED” attribute 2242 to "YES”.
  • the local variable RSTM_select is decremented by 1
  • the local variable RSTM_seleci is incremented by 1.
  • step 818 a test is performed to determine if the local variable RSTM_new is equal to
  • step 819 If it is the case, then control is given to step 819; otherwise control is given to step 820.
  • a warning message notification is issued for informing the user that at least one option ("Format” option button 217, or “Profile” option button 209, or “Template” option button 216, or “RE” option button 218, or “Recursive Template” option button 219) must be selected prior clicking on the "Create New" push-button 210.
  • This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • a test is performed to determine the value taken by the local variable RSTM_new.
  • step 821 If found equal to "FORMAT”, then control is given to step 821 ; • If found equal to "PROFILE”, then control is given to step 822;
  • step 821 the EF Editor command is issued with passing two parameters ("NEW” ; RSTM_range) and then control is given to step 834.
  • step 822 the EP Editor command is issued with passing two parameters ("NEW” ; RSTM_range) and then control is given to step 834.
  • step 823 the ST Editor command is issued with passing one parameter ("NEW") and then control is given to step 834.
  • step 824 a test is performed to determine if the local variable RSTM_select is equal to 1 (one). If it is the case, then control is given to step 825; otherwise control is given to step 829.
  • step 825 a test is performed to determine the nature of the selected object, as specified by the "Type” field 2237 "NATURE" attribute 2241 of the corresponding record 2231 of the RSTMT table 2230. ⁇ If found equal to "FORMAT”, then control is given to step 826; ° if found equal to "PROFILE”, then control is given to step 827;
  • step 828 control is given to step 828.
  • step 838 • if found equal to "RECELEMENT”, then control is given to step 838. ° if found equal to "RECTEMPLATE”, then control is given to step 839.
  • step 826 the EP Editor command is issued with passing one parameter equal to the "Namd' field 2232 of the unique record 2231 of the RSTMT table 2230 whose "Type” field 2237 has the "SELECTED” attribute 2242 equal to "YES", and then control is given to step 834.
  • step 827 the EF Editor command is issued with passing one parameter equal to the "Name” field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED” attribute 2242 equal to "YES", and then control is given to step 834.
  • step 828 the ST Editor command is issued with passing one parameter equal to the
  • a warning message notification is issued for informing the user that a single object must be selected within the ST Manager Dialog Box (thanks to check boxes like 212) prior clicking on the "Edit" push-button 211 or on the "Instanciate” push-button 204.
  • This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • control is given to step 805.
  • step 830 a test is performed to determine if the local variable RSTM_select is equal to 1 (one). If it is the case, then control is given to step 831; otherwise control is given to step 829.
  • a test is performed to determine the nature of the selected object, as specified by the "Type” field 2237 "NATURE" attribute 2241 of the corresponding record
  • step 840 If found equal to "RECTEMPLATE”, then control is given to step 840;
  • step 833 the ST Instanciator command is issued with passing one parameter equal to the "Namd' field 2232 of the unique record 2231 of the RSTMT table 2230 whose "Type" field 2237 has the "SELECTED” attribute 2242 equal to "YES", and then control is given to step 834.
  • a warning message notification is issued for informing the user that a single ST object or a single RST object must be selected within the RST Manager Dialog Box
  • step 834 the RST Manager Dialog Box 200 is closed so that it disappears from the display device 106 and then control is given back to the initial step 801 for processing any future RST Manager command.
  • step 835 a warning message notification is issued for informing the user that at least one selected object to be deleted is referenced by another object. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Then the user is prompted to either cancel the current "Delete" operation, or to pursue it.
  • step 805 if the spreadsheet user decision is to cancel the "Delete" operation, or to step 809 if the spreadsheet user decision is to continue the "Delete” operation.
  • step 836 the RE Editor command is issued with passing one parameter (“NEW") and then control is given to step 834.
  • step 837 the RST Editor command is issued with passing one parameter (“NEW”) and then control is given to step 834.
  • step 838 the RE Editor command is issued with passing one parameter equal to the "Name” field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type” field 2237 has the "SELECTED” attribute 2242 equal to "YES”, and then control is given to step 834.
  • step 839 the RST Editor command is issued with passing one parameter equal to the "Namd' field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type” field 2237 has the "SELECTED” attribute 2242 equal to "YES”, and then control is given to step 834.
  • step 840 the RST Instanciator command is issued with passing one parameter equal to the "Name” field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED” attribute 2242 equal to "YES", and then control is given to step 834.
  • step 841 the value of the local variable RSTM_child is updated by swapping the values "YES” and "NO". Then control is given to step 805.
  • the method for creating or updating EF's or MEF's used in the preferred embodiment of the present invention is summarised in flowchart 900 of FIG 9. This method can be seen as the processing of the EF Editor command. • At step 901 , the method is in its default state, waiting for an event to initiate the process.
  • step 902 the EF Editor command is detected, as a result of an user action.
  • This action can be for instance:
  • the parameters of the command are retrieved. They correspond to:
  • a first mandatory parameter EFEjname which can either take a reserved value "NEW” or another value corresponding to a character string name, as found in the "Name" field 2232 of a record 2231 within the RSTMT table 2230;
  • step 904 some local variables are initialized: the local variable EFE_meta is set to the value "NO”, the local variable EFEjsize is set to the value 8 (eight). " At step 905, a test is performed to determine the value taken by the local variable
  • step 909 If found equal to "NEW”, then control is given to step 909; otherwise control is given to step 906. • At step 906, the EFT table 700 is looked up to locate a record 701 whose "Name" field
  • step 702 is found equal to the value taken by the local variable EFEjname. If such a record is found, then control is given to step 908; otherwise control is given to step 907.
  • step 907 an exception handler is invoked to treat this "should not occur" condition. Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to step 925.
  • step 908 an exception handler is invoked to treat this "should not occur" condition. Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to step 925.
  • the local variable EFE_meta is set to the value "YES” or “NO” according to the value of the "META” attribute 708 within the "Type” field 707 of the record 701 found at step 906, ° the local variable EFEjsize is set to the value found in the "Column #" field 706 of the record 701 found at step 906, and
  • a new name for the newly created EF or MEF is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Namd' fields 702, 712, 722, 2212 and 2222 found in the respective records 701 , 711 , 721, 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured.
  • the "Row #' field 705 is set to the value 1 (as in the preferred embodiment of the present invention the ST's are managed in a 2D environment; this field would carry the number of defined rows for the created EF or MEF in a 3D environment) ; « the "Column #" field 706 is set to the value of the local variable EFEjsize ; and
  • OR subfield 709a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or
  • the "INSTANCE REFERENCE” (IR) subfield 709c is initialized with the value 1 (one).
  • the "REFERENCED OBJECT” (RO) subfield 709d is initialized with the following formula, where the fPset corresponds to the set of ST's:
  • step 910 a test is performed to determine the value taken by the local variable EFEjange. If found equal to "YES”, then control is given to step 911 ; otherwise control is given to step 912. ⁇ At step 911 , the currently selected range of cells is copied onto the clipboard and the local variable EFEjsize is set equal to the number of columns of the selected range.
  • the "Editor Space" sheet 315 is made the current sheet and the content of the clipboard is pasted on this blank sheet at a fixed cell address 314 (address B2 in a preferred embodiment of the present invention, as shown on FIG 3), so that the user can visualize on the display device 106 an illustration of the EF or MEF.
  • the EF Editor Dialog Box 301 is displayed on the display device 106.
  • the label box 304 is initialized with the value of the local variable EFEjname.
  • the top (respectively bottom) option button 310 is filled with a black point if the local variable EFEj eta is found equal to "NO” (respectively "YES”). • The text box 306 is filled with the value of the local variable EFEjsize.
  • step 914 the method is waiting for any user action on the EF Editor Dialog Box 301.
  • user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
  • step 915 a user action on the EF Editor Dialog Box 301 is detected. If the user action is a click on the push-button "Save & Refresh” 308, then control is given to step 916; if the user action is a click on the push-button "Save” 312, then control is given to step 917; if the user action is a click on the push-button “Save As” 311 , then control is given to step 918; « if the user action is a click on the push-button "Clear” 309, then control is given to step 919; if the user action is a click on the spin button 307, then control is given to step 920; if the user action is a click on one of the two option buttons 310, then control is given to step 921 ; • if the user action is a click on the push-button "Done” 303, or on the closing-window push-button 302, then control is given to step 925.
  • the EFT table 700 is updated and saved as part of the electronic spreadsheet file by refreshing the record 701 whose "Name" field 702 is equal to the local variable EFEjname.
  • ° the "Last Change Date” field 703 is set to the system time reference, as known by the central processor 101 ;
  • the EFT table 700 is updated and saved as part of the electronic spreadsheet file by refreshing the record 701 whose "Namd' field 702 is equal to the local variable EFEjname. For this purpose,
  • the 'Type" field 707 is set as follows: the attribute "META” 708 is set equal to the value of the local variable EFEjmeta.
  • the range of cells 314 illustrating on the "Editor Space” sheet 315 the current definition of the EF or MEF is copied onto the memory location pointed by the "Description Ptf field 704. Then control is given to step 913.
  • step 918 a test is performed on the value found in the text box 305 to determine if it corresponds to a valid new name.
  • the corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Name" fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 923; otherwise control is given to step 924.
  • MEF receives these same default attributes. Then control is given to the step 913.
  • the local variable EFEjsize is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 307, and as long as it value remains positive and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 913.
  • step 921 the local variable EFEjmeta is updated, so that its value becomes "YES” (respectively “NO") if the bottom (respectively top) option button 310 has been clicked on. Then control is given to step 913.
  • step 922 the ST Refresh Manager command is issued with the following parameters: EFEjname, "FORMAT" and then control is given to step 913.
  • step 923 memory space is allocated within the main memory 102 to later record the illustrative range of cells for the EF or MEF. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 701 is created in the EFT table 700 which is saved as part of the electronic spreadsheet file, and this new record 701 is initialized as follows:
  • the "Namd' field 702 is set to the value found in the text box 305 and validated at step 918; this field 702 becoming then the new value of the EFEjname local variable; • the "Last Change Datd' field 703 is set to the system time reference, as known by the central processor 101 ; ° the "Description Ptf field 704 is set to the memory location which has just been allocated ;
  • the "Row #' field 705 is set to the value 1 (as in the preferred embodiment of the present invention the ST's are managed in a 2D environment; this field would carry the number of defined rows for the created EF or MEF in a 3D environment) ;
  • OR subfield 709a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or
  • ° The "FILIATION REFERENCE” (FR) subfield 709b is initialized with the value 1 (one).
  • the "INSTANCE REFERENCE” (IR) subfield 709c is initialized with the value 1 (one).
  • the "REFERENCED OBJECT” (RO) subfield 709d is initialized with the following formula, where the !Pset corresponds to the set of ST's:
  • a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 305 prior to clicking on the "Save As" push-button 311. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • step 913 Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 913.
  • step 925 the EF Editor Dialog Box 501 is closed so that it disappears from the display device 106, then the "Editor Space" sheet 515 is removed from the displayed window so that it is replaced by the original sheet present at EF Editor invocation time.
  • EP Editor method The method for creating or updating EP's or MEP's used in the preferred embodiment of the present invention is summarized in flowchart 1000 of FIG 10. This method can be seen as the processing of the EP Editor command.
  • the method is in its default state, waiting for an event to initiate the process.
  • the EP Editor command is detected, as a result of an user action. This action can be for instance:
  • the parameters of the command are retrieved. They correspond to:
  • a first mandatory parameter EFEjname which can either take a reserved value "NEW” or another value corresponding to a character string name, as found in the "Name" field 2232 of a record 2231 within the RSTMT table 2230;
  • a second optional parameter EPEjange which can take only two predefined values "YES” and "NO". This second optional parameter must be present when the first mandatory parameter value differs from the "NEW”. These two parameters are recorded as local variables. • At step 1004, some local variables are initialized: the local variable EFEjmeta is set to the value "NO”, the local variable EPEjsize is set to the value 8 (eight).
  • step 1005 a test is performed to determine the value taken by the local variable EPEjname. If found equal to "NEW”, then control is given to step 1009; otherwise control is given to step 1006.
  • step 1006 the EPT table 710 is looked up to locate a record 711 whose "Namd' field 712 is found equal to the value taken by the local variable EPEjname. If such a record is found, then control is given to step 1008; otherwise control is given to step 1007. ° At step 1007, an exception handler is invoked to treat this "should not occur" condition. Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to step 1025. a At step 1008,
  • a new name for the newly created EP or MEP is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Namd' fields 702, 712, 722, 2212 and 2222 found in the respective records 701 , 711 , 721 , 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured.
  • the "Row #' field 715 is set to the value 1 (as in the preferred embodiment of the present invention the ST's are managed in a 2D environment; this field would carry the number of defined rows for the created EP or MEP in a 3D environment) ;
  • the "OWN REFERENCE" (OR) subfield 719a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a.
  • OR subfield 709a OR subfield 709a
  • 719a OR subfield 719a
  • 729a OR subfield 780a
  • 2219a or 2229a
  • 2240a Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
  • the "INSTANCE REFERENCE” (IR) subfield 719c is initialized with the value 1 (one).
  • the "REFERENCED OBJECT” (RO) subfield 719d is initialized with the following formula, where the Pset corresponds to the set of ST's:
  • step 1010 a test is performed to determine the value taken by the local variable EPEjrange. If found equal to "YES”, then control is given to step 1011; otherwise control is given to step 1012.
  • the currently selected range of cells is copied onto the clipboard and the local variable EPEjsize is set equal to the number of columns of the selected range.
  • the "Editor Space" sheet 315 is made the current sheet and the content of the clipboard is pasted on this blank sheet at a fixed cell address 314 (address B2 in a preferred embodiment of the present invention, as shown on FIG 3), so that the user can visualize on the display device 106 an illustration of the EP or MEP.
  • the EP Editor Dialog Box 401 is displayed on the display device 106.
  • the label box 404 is initialized with the value of the local variable EPEjname.
  • the top (respectively bottom) option button 410 is filled with a black point if the local variable EPEjmeta is found equal to "NO” (respectively "YES").
  • the text box 406 is filled with the value of the local variable EPEjsize.
  • the push-buttons "Savd' 412 and "Save & Refresh' 408 are enabled if the local variable EPEjsize is found equal to the "Column #" field 716 of the current record 711, or if the attribute "REFERENCED” 719 within the "Type” field 717 of this same record 711 is found with the subfield "REFERENCED OBJECT" 719d (RO) equal to "NO”, SO that any future click with the pointing device 105 on one of these two push-buttons "Save” 412 and "Save & Refresh' 408 will be recognized as a valid event.
  • the method is waiting for any user action on the EP Editor Dialog Box 401.
  • user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
  • step 1016 If the user action is a click on the push-button "Save & Refresh" 408, then control is given to step 1016; • if the user action is a click on the push-button “Save” 412, then control is given to step 1017; ° if the user action is a click on the push-button "Save As” 411 , then control is given to step 1018;
  • step 1020 • if the user action is a click on the spin button 407, then control is given to step 1020; • if the user action is a click on one of the two option buttons 410, then control is given to step 1021;
  • step 1025 the EPT table 710 is updated and saved as part of the electronic spreadsheet file by refreshing the record 711 whose "Name" field 712 is equal to the local variable EPEjname.
  • ° the "Last Change Datd' field 713 is set to the system time reference, as known by the central processor 101 ; ° the "Column #' field 716 is set to the value of the local variable EPEjsize ; and
  • the "Type” field 717 is set as follows: the attribute "META” 718 is set equal to the value of the local variable EPEjmeta.
  • the range of cells 414 illustrating on the "Editor Space” sheet 415 the current definition of the EP or MEP is copied onto the memory location pointed by the "Description Ptf field 714. Then control is given to step 1022.
  • the EPT table 710 is updated and saved as part of the electronic spreadsheet file by refreshing the record 711 whose "Namd' field 712 is equal to the local variable EPEjname. For this purpose,
  • step 1018 a test is performed on the value found in the text box 405 to determine if this value corresponds to a valid new name.
  • the corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Name" fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 1023; otherwise control is given to step 1024.
  • step 1019 the default attributes currently defined in the spreadsheet environment are applied to the "Editor Space" sheet 415, so that the displayed illustration of the EP or MEP receives these same default attributes. Then control is given to the step 1013.
  • step 1020 the local variable EPEjsize is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 407, and as long as it value remains positive and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 1013.
  • step 1021 the local variable EPEjmeta is updated, so that its value becomes "YES"
  • step 1013 control is given to step 1013.
  • the ST Refresh Manager command is issued with the following parameters'. EPEjname, "PROFILE”, and EPEjdesc. Then the local variable EPEjdesc is updated with the current EP or MEP description, as recorded in the memory location pointed by the "Description Ptf field 714 and then control is given to step 1013.
  • step 1023 memory space is allocated within the main memory 102 to later record the illustrative range of cells for the EP or MEP. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 711 is created in the EPT table 710 which is saved as part of the electronic spreadsheet file, and this new record 711 is initialized as follows:
  • ° the "Last Change Date” field 713 is set to the system time reference, as known by the central processor 101 ; ° the "Description Ptf field 714 is set to the memory location which has just been allocated; ° the "Row #' field 715 is set to the value 1 (as in the preferred embodiment of the present invention the ST's are managed in a 2D environment; this field would carry the number of defined rows for the created EP or MEP in a 3D environment); ⁇ the "Column #” field 71 is set to the value of the local variable EPEjsize; ° the "Type” field 717 is set as follows: the attribute "META” 718 is set equal to the value of the local variable EPEjmeta, and the attribute "REFERENCED” 719 is initialized as follows:
  • the "OWN REFERENCE" (OR) subfield 719a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a.
  • OR subfield 709a OR subfield 709a
  • 719a OR subfield 719a
  • 729a OR subfield 780a
  • 2219a or 2229a
  • 2240a Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
  • a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 405 prior to clicking on the "Save As" push-button 411.
  • This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 1013.
  • step 1025 the EP Editor Dialog Box 401 is closed so that it disappears from the display device 106, then the "Editor Space" sheet 415 is removed from the display window so that it is replaced by the original sheet present at EP Editor invocation time. Finally control is given back to the initial step 1001 for processing any future EP Editor command.
  • the method for creating or updating ST's used in the preferred embodiment of the present invention is summarized in flowchart 1100 of FIG 11. This method can be seen as the processing of the ST Editor command.
  • step 1101 the method is in its default state, waiting for an event to initiate the process.
  • step 1102 the ST Editor command is detected, as a result of an user action. This action can be for instance:
  • the parameter of the command is retrieved. It corresponds to a mandatory parameter STEjname which can either take a reserved value "NEW” or another value corresponding to a character string name, as found in the "Name" field 2232 of a record 2231 within the RSTMT table 2230. This parameter is recorded as a local variable.
  • some local variables are initialized: the local variable STEjmin is set to the default value 1 (one), the local variable STEjmax is set to the default value 255.
  • a test is performed to determine the value taken by the local variable STEjname. If found equal to "NEW”, then control is given to step 1109; otherwise control is given to step 1106.
  • step 1106 the STT table 720 is looked up to locate a record 721 whose "Namd' field 722 is found equal to the value taken by the local variable STEjname. If such a record is found, then control is given to step 1108; otherwise control is given to step 1107.
  • step 1107 an exception handler is invoked to treat this "should not occur" condition.
  • Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then. control is given to step 1128.
  • step 1106 where is recorded the description of the ST according to the STDT table 760 illustrated in FIG 7D
  • step 1106 is copied in a working buffer which in turns follows the same STDT table 760.
  • This structure is then used to build on the clipboard within the main memory 102 a spreadsheet range of cells illustrating the ST definition copied in the working buffer.
  • This construction is achieved by loading in the clipboard within the main memory 102 an ordered sequence of ranges of cells, each of them successively abiding by the EF (column 765) and the EP (column 764) definition corresponding to each pair of EF and EP names, starting with the first pair 761 up to the last one 763. Then control is given to step 1110.
  • a new name for the newly created ST is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Name" fields 702, 712, 722, 2212 and 2222 found in the respective records 701, 711, 721, 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured. Then the new name is recorded in the local variable STEjname.
  • memory space is allocated within the main memory 102 to later record the illustrative range of cells for the new ST.
  • This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file and follows the STDT table 760 illustrated in FIG 7D.
  • a new record 721 is created in the STT table 720, and this new record 721 is initialized as follows:
  • the "OWN REFERENCE" (OR) subfield 729a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a.
  • OR subfield 709a or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a.
  • Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
  • the "INSTANCE REFERENCE” (IR) subfield 729c is initialized with the value 1 (one).
  • a working buffer is allocated in main memory 102 and initialized with a default ST description which corresponds to a single pair 762 of default EF and default EP.
  • This default ST description is then used to build on the clipboard within the main memory 102 a spreadsheet range of cells illustrating the new ST. This construction is achieved as explained at the end of the step 1108. Then control is given to step 1110.
  • the "Editor Space" sheet 515 is made the current sheet and this sheet is turned to write-protect mode while regular row insertion and deletion are disabled. Then the top left cell of the range of cells 514 is selected. Then the local variable STEJormat is filled with the name of the EF or of the MEF corresponding to the row where is located the currently selected cell within the range of cells 514. Finally the local variable STEjprofile is filled with the name of the EP or of the MEP corresponding to the row where is located the currently selected cell within the range of cells 514.
  • the ST Editor Dialog Box 501 is displayed on the display device 106.
  • the label box 504 is initialized with the value of the local variable STEjname.
  • the text box 506 is filled with the value of the local variable STEjmin.
  • the text box 509 is filled with the value of the local variable STEjmax.
  • the combo box 511 is filled with the value of the local variable STEJormat.
  • the combo box 510 is filled with the value of the local variable STEjprofile.
  • the range of cells 514 is updated according to the description recorded in the memory clipboard: the content of the clipboard is pasted on this blank sheet at a fixed cell address 514 (address B2 in a preferred embodiment of the present invention, as shown on FIG 5), so that the user can visualize on the display device 106, within the window 500 an illustration of the ST. Then a test is performed to check if all the EF's, EP's, MEF's and MEP's contributing to the ST definition illustrated by the range of cells 514, have the same number of fields.
  • the two push-buttons "Savd' 513 and "Save Ad' 512 are enabled, so that the click with the pointing device 105 on one of these two push-buttons is recognized as a valid event. Otherwise the two push-buttons "Savd' 513 and "Save Ad' 512 are disabled, so that the click with the pointing device 105 on one of these two push-buttons is not recognized as a valid event.
  • the method is waiting for any user action on the ST Editor Dialog Box 501.
  • Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
  • a user action on the ST Editor Dialog Box 501 is detected.
  • step 1116 If the user action is a click on the push-button "Save” 513, then control is given to step 1116; ° if the user action is a click on the push-button "Save As” 512, then control is given to step 1119; ° if the user action is a click on the push-button "Add” 517, then control is given to step
  • step 1124 ° if the user action is a click on the push-button "Delete" 518, then control is given to step 1125;
  • step 1126 • if the user action is a click on the push-button "Up” 519 or on the push-button “Down” 520, then control is given to step 1126;
  • step 1114 • if the user action is an update of the combo box 511 , then control is given to step 1114; • if the user action is an update of the combo box 510, then control is given to step 1115;
  • step 1122 • if the user action is a click on the spin button 507, then control is given to step 1122;
  • step 1123 • if the user action is a click on the spin button 508, then control is given to step 1123;
  • step 1128 control is given to step 1128.
  • step 1114 the ST description is updated in the working buffer by replacing by the EF or MEF name found in the text box 511 the previous EF or MEF specification corresponding to the element or meta-element illustrated by the currently selected cell within the range of cells 514. Then the local variable STEJormat is also set equal to the name found in the text box 511. Then control is given to step 1111.
  • step 1115 the ST description is updated in the working buffer by replacing by the EP or MEP name found in the text box 510 the previous EP or MEP specification corresponding to the element or meta-element illustrated by the currently selected cell within the range of cells 514. Then the local variable STE_profile is also set equal to the name found in the text box 510. Then control is given to step 1111.
  • a test is performed to check if the currently edited ST is already referenced by an existing RE or RME or is already instanciated as a STI.
  • RO REFERENCED OBJECT
  • IR INSTANCE REFERENCE
  • the STT table 720 is updated by refreshing the record 721 whose "Name" field 722 is equal to the local variable STE_name.
  • the "Last Change Datd' field 723 is set to the system time reference, as known by the central processor 101 ;
  • ° the "Min Element #” field 725 is set to the value of the local variable STE_min;
  • the 'Type" field 727 is updated as the "FILIATION REFERENCE” (FR) subfield 729b of the "REFERENCED” attribute 729 is automatically updated thanks to its definition formula depending on the set of EF's, MEF's, EP's and MEP's belonging to the STDT table 760 pointed by the "Description Ptf field 724.
  • the EFT table 700 is automatically updated within the corresponding records 701 whose "Namd' field 702 matches this element or MEF name, as the subfield
  • “REFERENCED OBJECT" (RO) 71 d (within the "REFERENCED” attribute 719) is recalculated according to its definition formula. Then control is given to step 1111. ° At step 1118, a warning message notification is issued for informing the user that the edited ST is already referenced by a RE or RME or is already instanciated as an existing STI. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Then the user is prompted to either cancel the current "Save” operation, or to pursue it.
  • step 1111 if the spreadsheet user decision is to cancel the operation, or to step 1117 if the spreadsheet user decision is to continue the operation.
  • step 1119 a test is performed on the value found in the text box 505 to determine if it corresponds to a valid new name.
  • step 1120 memory space is allocated within the main memory 102 to later record the descriptor of the ST. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 721 is created in the STT table 720, and this new record 721 is initialized as follows:
  • FILIATION REFERENCE (FR) subfield 729b is initialized according to the following formula, where the set corresponds to the set of EF's, MEF's, EP's and MEP's constituting the new ST, according to the structure recorded in the "Description Ptf field 724:
  • FR ⁇ tey ORi x LCM( ⁇ FRi ⁇ °
  • the "INSTANCE REFERENCE” (IR) subfield 729c is initialized with the value 1 (one).
  • the EFT table 700 is automatically updated within the corresponding records 701 whose "Name” field 702 matches this element or MEF name, as the subfield "REFERENCED OBJECT" (RO) 709d (within the "REFERENCED” attribute 709) is recalculated according to its definition formula.
  • the EPT table 710 is automatically updated within the corresponding records 711 whose "Namd' field 712 matches this element or MEP name, as the subfield "REFERENCED OBJECT" (RO) 719d (within the "REFERENCED” attribute 719) is recalculated according to its definition formula. Then control is given to step 1111.
  • a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 505 prior to clicking on the "Save As" push-button 512.
  • This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • the local variable STE_min is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 507, and as long as its value remains positive and less than or equal to both an upper limit set equal to 254 in a preferred embodiment of the present invention and to the value shown in the text box 509. Then control is given to step 1111.
  • the local variable STE_max is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 508, and as long as its value remains positive, greater than the value shown in the text box 506 and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 1111. ° At step 1124, a new row is inserted in the range of cells 514 illustrating the edited ST, above the row where the last selected cell was previously located. Then the left most cell located on the new row within the range of cells 514 is selected.
  • the ST definition is updated in the working buffer by introducing a new meta-element which is described, like the other ones, by a couple (MEF 765, MEP 764) which defaults to a couple of default MEF and default MEP, which are also respectively assigned to the local variable STEJormat and STEjprofile.
  • a couple MEF 765, MEP 764
  • MEF 765, MEP 764 defaults to a couple of default MEF and default MEP, which are also respectively assigned to the local variable STEJormat and STEjprofile.
  • the current description of the ST as illustrated by the range of cells 514, as recorded in the working buffer, and following the STDT table 760 is copied onto the memory location pointed by the "Description Ptf field 724.
  • control is given to step 1111. o At step 1125, the row containing the selected cell is removed from the range of cells 514.
  • the left most cell located within the range of cells 514 on the row representing the element defined within the edited ST is selected.
  • the ST definition is updated by removing the deleted meta-element which was described by a couple (MEF, MEP).
  • the current description of the ST as illustrated by the range of cells 514, as recorded in the working buffer, and following the STDT table 760 is copied onto the memory location pointed by the "Description Ptf field 724. Then control is given to step 1127.
  • the current cell within the "Editor Space” sheet 515 is respectively moved up or down if the spreadsheet user has clicked with the pointing device 105 on the "Up” push-button 519, or on the "Down” push-button 520, and also if this movement does not move the current cell away from the range of cells 514 illustrating the ST.
  • step 1127 the local variables STEJormat and STEjprofile are respectively set equal to the name of the EF or MEF and to the name of the EP or MEP corresponding to the element or the meta-element illustrated by the currently selected cell within the range of cells 514. Then control is given to step 1111.
  • step 1128 the ST Editor Dialog Box 501 is closed so that it disappears from the display device 106, then the "Editor Space" sheet 515 is removed from the display window so that it is replaced by the original sheet present at EP Editor invocation time. All the means which were temporarily disabled while the "Editor Space” sheet 515 was displayed are now enabled again. Finally control is given back to the initial step 1101 for processing any future ST Editor command.
  • E5. RST Editor method The method for creating or updating RST's used in the preferred embodiment of the present invention is summarized in flowchart 1230 of FIG 12. This method can be seen as the processing of the RST Editor command.
  • the method is in its default state, waiting for an event to initiate the process.
  • the RST Editor command is detected, as a result of an user action. This action can be for instance:
  • the parameter of the command is retrieved. It corresponds to a mandatory parameter RSTEjname which can either take a reserved value "NEW” or another value corresponding to a character string name, as found in the "Namd' field 2232 of a record 2231 within the RSTMT table 2230. This parameter is recorded as a local variable.
  • step 1234 some local variables are initialized: the local variable RSTEjmin is set to the default value 1 (one), the local variable RSTEj ax is set to the default value 16. ⁇ At step 1235, a test is performed to determine the value taken by the local variable RSTEjname. If found equal to "NEW", then control is given to step 1239; otherwise control is given to step 1236.
  • step 1236 the RSTT table 2220 is looked up to locate a record 2221 whose "Name" field 2222 is found equal to the value taken by the local variable RSTEjname. If such a record is found, then control is given to step 1238; otherwise control is given to step 1237.
  • step 1237 an exception handler is invoked to treat this "should not occur” condition. Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to the initial step 1231 for processing any future RST Editor command. ° At step 1238,
  • step 1236 the memory location pointed by the "Description Ptf field 2224 of the record 2221 found at step 1236 (where is recorded the description of the RST according to the RSTDT table 2250 illustrated in FIG 17D) is copied in a working buffer which in turns follows the same RSTDT table 2250.
  • This structure is then used to build on the clipboard within the main memory 102 a spreadsheet range of cells illustrating the RST definition copied in the working buffer, each cell successively corresponding to RE or RME names, starting with the first name 2251 up to the last one 2253. Then control is given to step 1240.
  • a new name for the newly created RST is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Name" fields 702, 712, 722, 2212 and 2222 found in the respective records 701, 711, 721, 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured. Then the new name is recorded in the local variable RSTEjname.
  • memory space is allocated within the main memory 102 to later record the illustrative range of cells for the new RST.
  • This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file and follows the RSTDT table 2250 illustrated in FIG 17D.
  • a new record 2221 is created in the RSTT table 2220, and this new record 2221 is initialized as follows:
  • the "OWN REFERENCE” (OR) subfield 2229a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
  • the "FILIATION REFERENCE” (FR) subfield 2229b is initialized according to the following formula, where the f set corresponds to the set of RE's and RME constituting the new RST, according to the structure recorded in the "Description Ptf field 2224:
  • FR I OR, x LCM( ⁇ FR, ⁇ ) iey °
  • the "INSTANCE REFERENCE” (IR) subfield 2229c is initialized with the value 1 (one).
  • the "REFERENCED OBJECT” (RO) subfield 2229d is initialized with the value "NO”.
  • a working buffer is allocated in main memory 102 and initialized with a default RST description which corresponds to a RE 2252.
  • This default RST description is then used to build on the clipboard within the main memory 102 a spreadsheet range of cells illustrating the new RST. This construction is achieved as explained at the end of the step 1238. Then control is given to step 1240.
  • the "Editor Space" sheet 615 is made the current sheet and this sheet is turned to write-protect mode while regular row insertion and deletion are disabled. Then the top left cell of the range of cells 614 is selected. Then the local variable REjname is filled with the name of the RE corresponding to the row where is located the currently selected cell within the range of cells 614.
  • the RST Editor Dialog Box 601 is displayed on the display device 106.
  • the label box 604 is initialized with the value of the local variable RSTEjname.
  • the text box 609 is filled with the value of the local variable RSTEjmax.
  • the combo box 610 is filled with the value of the local variable REjname.
  • the range of cells 614 is updated according to the description recorded in the memory clipboard: the content of the clipboard is pasted on this blank sheet at a fixed cell address 614 (address B2 in a preferred embodiment of the present invention, as shown on FIG 6), so that the user can visualize on the display device 106, within the window 611 an illustration of the ST. Then a test is performed to check if all the RE's and RME's contributing to the RST definition illustrated by the range of cells 614, have the same number of fields. If it is the case, then the two push-buttons "Savd' 613 and "Save Ad' 612 are enabled, so that the click with the pointing device 105 on one of these two push-buttons is recognized as a valid event. Otherwise the two push-buttons "Save” 613 and "Save Ad' 612 are disabled, so that the click with the pointing device 105 on one of these two push-buttons is not recognized as a valid event.
  • step 1242 the method is waiting for any user action on the RST Editor Dialog Box 601.
  • user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
  • step 1243 a user action on the RST Editor Dialog Box 601 is detected. If the user action is a click on the push-button "Save” 613, then control is given to step 1246; if the user action is a click on the push-button “Save As” 612, then control is given to step 1249; if the user action is a click on the push-button "Add” 617, then control is given to step 1243;
  • step 1254 if the user action is a click on the push-button "Delete” 618, then control is given to step 1255; • if the user action is a click on the push-button "Up” 619 or on the push-button "Down"
  • step 1256 control is given to step 1256; ° if the user action is an update of the combo box 610, then control is given to step 1256;
  • step 1252 * if the user action is a click on the spin button 607, then control is given to step 1252; ° if the user action is a click on the spin button 608, then control is given to step 1253;
  • step 1258 the ST description is updated in the working buffer by replacing by the RE or RME name found in the combo box 610 the previous RE or RME name corresponding to the RE or RME illustrated by the currently selected cell within the range of cells 614. Then the local variable REjname is also set equal to the name found in the combo box 610. Then control is given to step 1241.
  • a test is performed to check if the currently edited RST is already referenced by an existing RSTI. For this purpose is considered the value of the "REFERENCED" attribute 2229 within the "Type" field 2227 of the record 2221 within the RSTT table 2220 whose "Namd' field 2222 is equal to the local variable RSTEjname. If the value of the "INSTANCE REFERENCE” (IR) subfield 2229c is equal to 1 (one), then control is given to step 1247; otherwise control is given to step 1248. ° At step 1247, the RSTT table 2220 is updated by refreshing the record 2221 whose "Namd' field 2222 is equal to the local variable RSTEjname. For this purpose, ° the "Last Change Date" field 2223 is set to the system time reference, as known by the central processor 101 ;
  • the "Type” field 2227 is updated as the "FILIATION REFERENCE” (FR) subfield 2229b of the "REFERENCED” attribute 2229 is automatically updated thanks to its definition formula depending on the set of RE's, and RME's belonging to the RSTDT table 2250 pointed by the "Description Ptf field 2224. • For each RE name or RME name found in the column 2254 of this RSTDT table
  • the RET table 2210 is automatically updated within the corresponding record
  • “REFERENCED OBJECT” (RO) 2219d (within the "REFERENCED” attribute 2219) is recalculated according to its definition formula.
  • a warning message notification is issued for informing the user that the edited RST is already instanciated as a RSTI. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Then the user is prompted to either cancel the current "Save” operation, or to pursue it. This can typically be done by displaying on the display device
  • step 1241 if the spreadsheet user decision is to cancel the operation, or to step 1247 if the spreadsheet user decision is to continue the operation.
  • step 1249 a test is performed on the value found in the text box 605 to determine if it corresponds to a valid new name.
  • the corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Namd' fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 1250; otherwise control is given to step 1251.
  • step 1250 memory space is allocated within the main memory 102 to later record the descriptor of the RST. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 2221 is created in the RSTT table 2220, and this new record 2221 is initialized as follows:
  • ° the "Last Change Date” field 2223 is set to the system time reference, as known by the central processor 101 ; ° the "Description Ptf field 2224 is set to the memory location which has just been allocated ; o the "Min Element #” field 2225 is set to the value of the local variable RSTEjmin;
  • the "Type” field 2227 is set as follows: the attribute "META” 2228 is set equal to "NO”, and the attribute "REFERENCED” 2229 is initialized as follows: ⁇
  • the "OWN REFERENCE” (OR) subfield 2229a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a.
  • OR subfield 2229a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a.
  • Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
  • the "FILIATION REFERENCE” (FR) subfield 2229b is initialized according to the following formula, where the T set corresponds to the set of RE's and RME constituting the new RST, according to the structure recorded in the "Description Ptf field 2224:
  • the "SELECTED CHILDREN" (SC) subfield 2229e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED” attribute 2242 equal to the value "YES” in the RSTMT table 2230):
  • the RET table 2210 is automatically updated within the corresponding record
  • a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 605 prior to clicking on the "Save As" push-button 612. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 1241.
  • the local variable RSTEjmin is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 607, and as long as its value remains positive and less than or equal to both an upper limit set equal to 254 in a preferred embodiment of the present invention and to the value shown in the text box 609. Then control is given to step 1241.
  • the local variable RSTEjmax is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 608, and as long as its value remains positive, greater than the value shown in the text box 606 and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 1241. ° At step 1254, a new row is inserted in the range of cells 614 illustrating the edited RST, above the row where the last selected cell was previously located.
  • the RST definition is updated in the working buffer by introducing a new RME which is identified, like the other ones, by a name, which is also assigned to the local variable REjname.
  • step 1255 the row containing the selected cell is removed from the range of cells 614, so that the next RE or meta-element gets selected.
  • the RST definition is updated by removing the deleted RME which was identified by its name.
  • the current description of the RST as illustrated by the range of cells 614, as recorded in the working buffer, and following the RSTDT table 2250 is copied onto the memory location pointed by the "Description Ptf field 2224. Then control is given to step 1257.
  • the current cell within the "Editor Space” sheet 615 is respectively moved up or down if the spreadsheet user has clicked with the pointing device 105 on the "Up” push-button 619, or on the "Down” push-button 616, and also if this movement does not move the current cell away from the range of cells 614 illustrating the RST.
  • the local variable REjname is set equal to the name of the RE or RME corresponding to either the RE or the RME identified by the currently selected cell within the range of cells 614. Then control is given to step 1241.
  • step 1258 the RST Editor Dialog Box 601 is closed so that it disappears from the display device 106, then the "Editor Space” sheet 615 is removed from the display window so that it is replaced by the original sheet present at RST Editor invocation time. All the means which were temporarily disabled while the "Editor Space” sheet 615 was displayed are now enabled again. Finally control is given back to the initial step 1231 for processing any future RST Editor command.
  • the method for creating a STI abiding by a defined ST used in the preferred embodiment of the present invention is summarized in flowchart 1400 of FIG 14A and FIG 14B, where the later corresponds to the CreateSTI routine. This method can be seen as the processing of the ST Instanciator command.
  • step 1401 the method is in its default state, waiting for an event to initiate the process.
  • step 1402 the ST Instanciator command is detected, as a result of a user action.
  • This action can be for instance a specific combination of key on the keyboard 104, or the click of the pointing device 105 on a specific button, or any other similar means not further specified here.
  • a test is performed to check if the currently selected cell is contained within a sheet where a RSTI is present. This test can be done by parsing the RSTIT table 2260 to identify any record 2261 whose Address field 2262 corresponds to the same sheet as the currently selected cell. If it is the case, then control is given to step 1404 ; otherwise control is given to step 1405.
  • a warning message notification is issued for informing the user that a STI cannot be individually created on a sheet where a RSTI already exists. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • the command parameter STjname is first retrieved: it corresponds to the name of the ST that the STI to be created will abide by.
  • This parameter STjname is used to parse the STT table 720 in order to find the record 721 whose "Namd' field 722 matches the parameter STjname.
  • its fields "Min Element #"725 and "Max Element #” 726 are respectively memorized as local variables STIjmin and STIjmax.
  • its field "Description Ptf 724 is used to determine, according to the referenced STDT table 760, the number of meta-elements defined within the ST, and the number of cells defined within each element or meta-element member of the ST.
  • the first number is memorized in a local variable STIj eta
  • the second number is memorized in a local variable STLwidth 1325 (representing the number of columns of the future STI).
  • another local variable STIjalement is initialized with the value taken by STIjmin.
  • another local variable STI_critical is initialized with the default value "YES”.
  • another local variable STI_sheet_width 1321 is initialized with the total number of columns in the current sheet 1320.
  • another local variable STIjsheetjheight 1322 is initialized with the total number of rows in the current sheet 1320.
  • another local variable STIjmode is initialized with the value OVERLAY.
  • step 1406 some other local variables are first built or updated.
  • the position of the currently selected cell 1327 is first represented by the local variables STI_offset_width 1323 and STIjoffsetjheight 1324 corresponding respectively to the number of columns and of rows between the top left cell of the current sheet 1320 and the currently selected cell 1327.
  • the number of rows of the future STI is represented by the local variable STljheight 1326, computed as the sum of the local variables STI_meta and STIjelement.
  • Second some working ranges of cells are determined through the evaluation of their addresses.
  • the range of cells STIjange 1328 corresponding to the future STI is first determined as the range of cells with the currently selected cell 1327 as the top left cell, and with a number of rows and columns respectively equal to STljheight 1326 and STLwidth 1325. Then the range of cells STIjhorizontalJlushedjange 1330 is determined as the range of cells sharing the same rows as STIjange 1328, and occupying the STLwidth 1325 rightmost columns of the current sheet 1320.
  • the range of cells STIjhorizontaljkeptjange 1329 is determined as the range of cells sharing the same rows as STIjange 1328, and occupying the columns located between those of STIjange 1328 and STIJiorizontalJlushed ange 1330.
  • the range of cells STI /erticalJlushed ange 1332 is determined as the range of cells sharing the same columns as STIjange 1328, and occupying the STI_heighf ⁇ Z26 bottom columns of the current sheet 1320.
  • the range of cells STIj eriicalJ ⁇ epl ange 1331 is determined as the range of cells sharing the same columns as STIjange 1328, and occupying the rows located between those of STIjange 1328 and STIj/erticalJlushedjange 1332.
  • step 1407 two sums are performed to check if the future STI will fit within the boundaries of the current sheet 1320. • If the sum of the local variables STI_offset_width 1323 and STLwidth 1325 is found greater than the local variable STIjsheetjwidth 1321, then a local variable STIJoojA/ide is set to "YES"; otherwise it is set to "NO".
  • STIJooj igh is set to "YES”; otherwise it is set to "NO”.
  • steps 1408 several tests are performed to evaluate the potential impact of the creation of the future STI, according to the five possible instanciation modes, on any already existing STI or data. These tests require to parse the STIT table 750, and to visit each record 751 to learn the address ("Addresd' field 752) and the importance ("Critical' field 755) of every already defined STI.
  • STIjhorizontaljdata takes the value "NO”; otherwise the local test variable STIjhorizontaLdata takes the value "YES”.
  • the ST Instanciator Dialog Box 1300 is displayed on the display device 106.
  • the "Critical' check box 1314 displays a check mark if the local variable STLcritical takes the value "YES”; otherwise (value "NO"), the "Critical' check box 1314 is kept with a blank empty display.
  • the label box 1315 is initialized with the value of the local variable STjname.
  • the text box 1 12 is filled with the value of the local variable STIjelement
  • the label box 1311 is filled with the value of the local variable STIJoo_wide and the label box 1310 is filled with the value of the local variable STIJoo_high.
  • the 15 label boxes 1304 are filled row after row, starting with the top row, from the left to the right, with the values of the following local variables in the following order: STI_overlay_critical, STIjjverlayjother, STLoverlayjdata, STIjhorizontaLcritical, STIjhorizontaljother, STIjhorizontaljdata, STIjhorizontal ange_critical, STIjhorizontaljangejJther, STIjhorizontaljangejdata, STLverticaljohtical, STI /erticaljoiher, STIj/erticaljdata, STl_vertical ange_critical, STI_verticaljange_other, STLverticaljangejdata.
  • HORIZONTALJNSERT Or HORIZONTAL_lNSERT_BY_RANGE, Or VERTICALJNSERT, Or
  • STI_horizontal ange_critical (only taken into account if the local variable STIjmode is equal to HORIZONTAL JNSERT_BY_RANGE), STLvertical angej ritical (only taken into account if the local variable STIjmode is equal to VERTICALJNSERT_BY_RANGE); otherwise the "Creatd' push-button 1303 is enabled.
  • the method is waiting for any user action on the ST Instanciator Dialog
  • Step 1411 a user action on the ST Instanciator Dialog Box 1300, or a change of the currently selected cell is detected.
  • step 1416 If the user action is a click on the "Creatd' push-button 1303, then control is given to step 1416; if the user action is a click on the upper part of the spin button 1313, then control is given to step 1415; if the user action is a click on the lower part of the spin button 1313, then control is given to step 1414; if the user action is a click on the "Critical' check box 1314, then control is given to step 1413; • if the user action is a click on one of the option buttons 1309, or 1308, or 1307, or 1306, or 1305, then control is given to step 1412; ° if the user action is a click on the "Cancel' push-button 1302, or on the closing-window push-button 1301, then control is given to step 1418; • finally if the user action is a change in the position of the currently selected cell, then control is given to step 1406.
  • the local variable STIjmode takes the value OVERLAY, or HORIZONTALJNSERT, or HORIZONTAL INSERT BY RANGE, or VERTICALJNSERT, or VERTICAL INSERT BY_RANGE if the spreadsheet user has respectively clicked with the pointing device 105 on the option button 1309, or 1308, or 1307, or 1306, or 1305. Then control is given to step 1406.
  • step 1413 the local variable STLcritical is updated in order to swap between the values "YES” and "NO”. Then control is given to step 1406. °
  • step 1414 the local variable STIjelement is decremented by 1 (one), as long as its value remains greater than or equal to the value of the local variable STIjmin. Then control is given to step 1406.
  • step 1415 the local variable STIjelement is incremented by 1 (one), as long as its value remains less than or equal to the value of the local variable STIjmax. Then control is given to step 1406.
  • the STIT table 750 is visited to remove from it every record 751 corresponding to a STI corrupted by the introduction of the new instance, as identified during the step 1408 for the insertion mode represented by the local variable STIjmode. Then the STT table 720 is updated to reflect the removal of each STI. For each removed STI, the INSTANCE REFERENCE (IR) field 729c of the "REFERENCED" attribute 729 of the record 721 whose "Namd' field 722 is equal to the "ST field 753 of the record 751 of the STIT table 750 corresponding to the removed STI, is divided by 2 (two).
  • IR INSTANCE REFERENCE
  • step 1417 the routine CreateSTI is called.
  • step 1418 the ST Instanciator Dialog Box 1300 is closed so that it disappears from the display device 106. Finally control is given back to the initial step 1401 for processing any future ST Instanciator command.
  • the following steps, all part of FIG 14B, correspond to the execution of the CreateSTI routine, as used in the preferred embodiment of the present invention •
  • step 1419 a new record 751 is introduced in the STIT table 750.
  • the "Addresd' field 752 is initialized with the address of the range of cells STIjange 1328
  • the "ST field 753 is initialized with the value of the local variable STjname
  • the "Element #' field 754 is initialized with the value of the local variable STIjelement
  • the "Critical' field 755 is initialized with the value of the local variable STLcritical
  • the "Header Sizd' field 756 is initialized with the number of meta-elements constituting the header part of the new STI (this number being equal to the number of pairs in the header part 767 of the STDT table 760 associated to the ST that the new STI will abide by)
  • the "Footer Sizd' field 757 is initialized with the number of meta-elements constituting the footer part of the new STI (this number being equal to the number of pairs in the footer part 766 of the STDT table 760 associated to the ST abided by the new STI).
  • the STT table 720 is scanned to identify the record 721 whose "Namd' field is found equal to the local variable STjname. Once found, the "REFERENCED" attribute 729 within the "Typd' field 727 of this record 721 is updated by multiplying the "INSTANCE REFERENCE” subfield 729c by 2 (two). • At step 1420 a test is performed to check the value of the local variable STIjmode.
  • step 1422 If this value is found equal to HORIZONTALJNSERT_BY_RANGE then control is given to step 1422, • If this value is found equal to VERTICALJNSERT then control is given to step 1423, ⁇ If this value is found equal to VERTICALJNSERT_BY_RANGE then control is given to step
  • step 1421 the range of cells STIjange 1328 is selected to become the currently selected range of cells, with the currently selected cell being kept in its former position 1327 and then a regular operation of "column insertion within selected range" is performed. Then control is given to step 1425.
  • step 1422 the range of cells STIjange 1328 is selected to become the currently selected range of cells, with the currently selected cell being kept in its former position 1327 and then a regular operation of "row insertion within selected range" is performed. Then control is given to step 1425.
  • step 1423 the range of cells STIjange 1328 is selected to become the currently selected range of cells, with the currently selected cell being kept in its former position 1327 and then a regular operation of "column insertion" is performed. Then control is given to step 1425.
  • the range of cells STIjange 1328 is selected to become the currently selected range of cells, with the currently selected cell being kept in its former position
  • step 1425 control is given to step 1425.
  • a local variable STIJndex is initialized to the value taken by the local variable STIjelement. Then the STT table 720 is parsed to identify the record 721 whose "Name" field 722 matches the value of the local variable STjname. Within this record 721 is retrieved the "Description Ptf field 724 allowing to locate in memory the STDT table 760 associated to the ST that the new STI to be created will abide by. Then the first pair 761 of element or MEF name and element or MEP name found within this STDT table 760 is set as the current pair of names: (EF or MEF name, EP or MEP name).
  • the EPT table 710 is parsed to find the record 711 whose "Name" field 712 is found equal to the EP or MEP name within the current pair. Once this record 711 is found, its "Description Ptf field 714 is retrieved to locate in memory the range of cells illustrating the EP or MEP. This description of the EP or MEP is copy-pasted by value only onto the currently selected cell, so that the corresponding row within the STIjange receives the EP or MEP initial values. Then the EFT table 700 is parsed to find the record 701 whose "Namd' field 702 is found equal to the EF or MEF name within the current pair.
  • this record 701 Once this record 701 is found, its "Description Ptf field 704 is retrieved to locate in memory the range of cells illustrating the EF or MEF. This description of the EF or MEF is copy-pasted by attribute only onto the currently selected cell, so that the corresponding row within the STIjange receives the EF or MEF attributes. • At step 1427 a test is performed to check if the current pair (EF or MEF name, EP or MEP name) corresponds to an element or to a meta-element. In the first case, control is given to step 1428, and in the second case control is given to step 1429.
  • step 1428 the local variable STIJndex is decremented by 1 (one). Then control is given to step 1430.
  • step 1429 a test is performed to check if the current pair (EF or MEF name, EP or MEP name) is the last one 763 within the STDT table 760. If it is the case, the execution of the CreateSTI routine completes by returning control to the routine caller, otherwise control is given to step 1431.
  • step 1430 a test is performed to check if the local variable STIJndex is equal to 0 (zero). If it is the case, then control is given to step 1429, otherwise control is given to step 1432.
  • the pair of names (EF or MEF name, EP or MEP name) following the current one in the STDT table 760 becomes the current pair of names.
  • step 1432 the currently selected cell is moved downwards by one row. Then control is given to step 1426.
  • the method for instanciating a RST used in the preferred embodiment of the present invention is summarized in flowchart 2100 of FIG 16A and 16B. This method can be seen as the processing of the ST Instanciator command. ° At step 2101, the method is in its default state, waiting for an event to initiate the process.
  • the RST Instanciator command is detected, as a result of a user action. This action can be for instance a specific combination of keys on the keyboard 104, or the click of the pointing device 105 on a specific button, or any other similar means no further specified here.
  • the command parameter is retrieved and some local variables are initialized: ° The command parameter is recorded in the RSTJMame variable. ° The local variable Element# is initialized with the value 0 (zero). 0 The local variable toojMide is initialized with the default value FALSE. 0 The local variable toojhigh is initialized with the default value FALSE. 0 The local variable Maxjool is initialized with the maximum number of available columns on a sheet.
  • the local var iiable STIjpresent is initialized with the default value FALSE.
  • the local vari iable RSTLbusy is initialized with the default value FALSE.
  • the RSTT table 2220 is parsed to identify the record 2221 (identified by the local variable CurrjRSTTjec) whose "Namd' field 2222 is equal to the command parameter RSTjName. Then the local variable RSTIj ⁇ # is set equal to the value of the "Min Elements field 2225 of this record CurrjRSTTjec 2221. • At step 2105, the local variable CurrjRSTDT is set equal to the RSTDT table 2250 pointed by the "Description Ptf field 2224 of the record CurrjRSTT ec 2221.
  • the local variable CurrjRSTDT ec is set equal to the first single-cell record 2251 of the CurrjRSTDT table 2250.
  • the local variable CurrJRET ec is set equal to the record 2211 of the RET table 2210, with a "Namd' field 2212 equal to the local variable CurrjRSTDTjec.
  • the local variable CurrjREDjRoC is set equal to the range of cells pointed by the "Description Ptf field 2214 of the record CurrjRET ec 2211.
  • a RSTIDT table 2270 is loaded in memory and named through the local variable CurrjRSTlDT.
  • This table has a number of rows equal to the numbers of rows of the CurrjRSTDT table 2250, incremented by the value of the local varaibel RSTI_E# and decremented by 1 (one).
  • This table has a number of columns equal to the number of columns of the Curr_RED_RoC range of cells.
  • the local variable CurrjRSTIDT ec is initialized as the first record 2271 of the Ct// ⁇ _ftS77D7 " table 2270.
  • the local variable CurrjRSTIDTjoell is initialized as the first cell 2280 of the CurrjRSTIDT ec 2271. Then the local variable CurrjRECjRocjoell is initialized as the first cell of the CurrjRECjRoC range of cells.
  • the "STIjoof field 2278 of the CurrjRSTIDTjoell 2280 is set equal to the value returned by the function STI_col when called with the unique parameter equal to the value of the local variable Curr_RET_RoC_cell.
  • the "STI ow” field 2279 of the CurrjRSTIDTjoell 2230 is set equal to the value returned by the function STIJ ⁇ W when called with the two parameters respectively equal to the value of the local variable CurrjRETjRoCjoell and to 0 (zero).
  • the "STjname" field 2280 of the CurrjRSTIDTjoell 2280 is set equal to the value of the local variable Curr_RET_RoC_cell.
  • CurrjRSTIDTjec 2271 If it is the case, then control is given to step 2111 ; otherwise control is given to step 2110.
  • step 2110 the cell located on the right of the cell represented by the local variable CurrjRSTIDTjoell 2280 becomes the new CurrjRSTIDTjoell 2280. Then the cell located on the right of the cell represented by the local variable CurrjRETjRoCjoell becomes the new CurrjRETjRoCjoell. Then control is given to step 2108.
  • a test is performed to check if the record represented by the local variable Curr RET rec 2211 describes a RE. This can be determined if the "META" attribute 2218 of the "Type” field 2217 of the CurrjRETjec record 2211 is equal to the value "NO". If it is the case, then control is given to step 2112; otherwise control is given to step 2114.
  • step 2113 a test is performed to determine if the local variable ElemenW is equal to the local variable RSTIjE#. If it is the case, then control is given to step 2114; otherwise control is given to step 2115. 0
  • step 2114 a test is performed to check if the cell represented by the local variable CurrjRSTIDTjoell 2280 is the last cell of the record represented by the local variable CurrjRSTIDT ec 2271. If it is the case, then control is given to step 2116; otherwise control is given to step 2117.
  • step 2115 the record following the CurrjRSTIDTjec record 2271 in the CurrjRSTlDT table 2270 becomes the new CurrjRSTIDTjec record 2271. Then control is given to step 2107.
  • step 2116 the record following the CurrjRSTDTjec record in the CurrjRSTDT table 2250 becomes the new CurrjRSTDTjec. Then control is given to step 2115.
  • step 2117 for each cell CurrjRSTIDTjoell 2280 belonging to the CurrjRSTlDT table 2270, the " container ow" attribute 2281 is set equal to the maximum value of the "STIjow" attribute 2279 of the cells Samejowjoell located within the CurrjRSTlDT table 2270 on the same row as CurrjRSTIDTjoell.
  • the " container joot' attribute 2277 is set equal to the maximum value of the "STIjoof attribute 2278 of the cells Samejooljoell located within the CurrjRSTlDT able 2270 on the same column as CurrjRSTIDTjoell.
  • the local variable RSTljool is set equal to the sum of the " container jool' attributes 2277 of the cells belonging to the first row of the CurrjRSTlDT table 2270. Then the local variable RSTIjow is set equal to the sum of the " container ow" attributes 2281 of the cells belonging to the first column of the CurrjRSTlDT tab ⁇ e 2270.
  • step 2119 a test is performed to determine if the sum of the local variable RSTljool and of the column index of the individual cell RSTI_ topjeftjoell decremented by 1 (one) is strictly greater than the local variable Maxjool. If it is the case, then control is given to step 2120; otherwise control is given to step 2121.
  • the local variable too_wide is set equal to the value TRUE.
  • step 2121 a test is performed to determine if the sum of the local variable RSTIjow and of the row index of the individual cell RSTIJopJeftjoell decremented by 1 (one) is strictly greater than the local variable Max ow. If it is the case, then control is given to step 2122; otherwise control is given to step 2123.
  • the local variable toojhigh is set equal to the value TRUE.
  • step 2123 a test is performed to determine if there is any existing STI present on the same sheet as the individual cell RSTIJopJeftjoell. This test can simply be done by parsing the STIT table 750 for identifying any record 751 with an "Addresd' field 752 pointing to the same sheet as the individual cell RSTIJopJeftjoell. If it is the case, then control is given to step 2124; otherwise control is given to step 2125.
  • the local variable STIjpresent is set equal to the value TRUE.
  • the local variable RSTI ange is initialized as being the range of cells with RSTIJopJeftjoell as the top left cell, with a number of rows equal to the value of the local variable RSTIjow, and with a number of columns equal to the value of the local variable RSTljool. 0
  • a test is performed to check if there is any data present within the range of cells RSTIjange. If it is the case, then control is given to step 2127; otherwise control is given to step 2128.
  • the local variable RSTLbusy is set equal to the value TRUE.
  • the RST Instanciator dialog box 2300 is displayed on the display device 106.
  • the text field 2302 is filled with the value of the local variable RST name
  • the text field 2311 is filled with the value of the local variable RSTIj ⁇ #
  • the text field 2304 is filled with the value of the local variable toojwide
  • the text field 2305 is filled with the value of the local variable toojhigh
  • the text field 2306 is filled with the value of the local variable STLpresent
  • the text field 2307 is filled with the value of the local variable RSTLbusy.
  • the "Create Instancd' push-button 2310 is enabled if and only if the three local variables too_wide, toojhigh and STLpresent take the same value FALSE.
  • the "Create instance in a new sheet' push-button 2309 is enabled if and only if the two local variables too_wide and toojiigh take the same value FALSE.
  • the method is waiting for any user action on the RST Instanciator dialog box 2300. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of keys on the keyboard 104, or any other similar means not further specified here.
  • a user action on the RST Instanciator dialog box 2300 is detected.
  • step 2133 If the user action is a click with the pointing device 105 on one "Up” arrow of the spin-button 2303, then control is given to step 2133. ⁇ If the user action is a click with the pointing device 105 on one "Down” arrow of the spin-button 2303, then control is given to step 2134.
  • step 2138 If the user action is a click with the pointing device 105 on the "Create instancd' push-button 2310, then control is given to step 2138.
  • step 2136 If the user action is a click with the pointing device 105 on the "Create instance in a new sheet' push-button 2309, then control is given to step 2136.
  • step 2131 If the user action is a click with the pointing device 105 on the "Cancel' push button 2308, or on the closing-window push-button 2301, then control is given to step 2131.
  • step 2132 the RST Instanciator dialog box 2300 is closed on the display device 106 and then control is given back to the initial step 2101 for processing any future RST
  • step 2135 the range of cells CurrjRSTlDT is released from memory, and then control is given to the step 2105.
  • the top left cell of the sheet currjsheet becomes the new individual cell RSTIJopJeftjoell.
  • the local variable STIjmode is initialized with the value OVERLAY. Then the local variable STLcritical is initialized with the value YES. Then the local variable
  • CurrjRSTIDTjec is initialized as being the first record 2271 of the CurrjRSTlDT table 2270. Then the local variable CurrjRSTIDTjoell is initialized as being the first cell 2280 of the record CurrjRSTIDTjec 2271. Then the local variable Currjoell is initialized as being equal to RSTIJopJeftjoell.
  • the " container jange" attribute 2276 of the CurrjRSTIDTjoell 2280 is initialized as the range of cell having as the top left cell the individual cell Currjoell, having ' a number of rows equal to the value of the "container ow” attribute 2281 , and having a number of columns equal to the value of the " container jcot' attribute 2277.
  • the local variable STIjange is set equal to the " container jangd' attribute 2276 of the CurrjRSTIDTjoell 2280.
  • the local variable STjname is set equal to the "STjnamd' attribute 2280 of the CurrjRSTIDTjoell 2280.
  • the local variable STIjelement is set equal to the "Min Element!?' field 2225 of the record 721 of the STT table 720 with a "Namd' field 722 equal to STj ame. 9
  • the CreateSTI command is invoked (as a sub-routine). When this command completes and returns control to the current process, the control is given to the next step 2142.
  • the "STIT ecjptf attribute 2282 of the CurrjRSTIDTjoell 2280 is set as pointing to the STIT record 751 that has just been created during the previous step 2141.
  • CurrjRSTIDTjec 2271 If it is the case, then control is given to step 2143; otherwise control is given to step 2144.
  • the individual cell currjoell is moved to the right by a number of columns equal to the value of the " container joof attribute 2277 of CurrjRSTIDTjoell 2280. Then the cell located on the right of the individual cell CurrjRSTIDTjoell 2280 becomes the new CurrjRSTIDTjoell 2280.
  • ° At step 2145 a test is performed to check if the record represented by the local variable
  • CurrjRSTIDTjrec 2271 is the last record of the RSTIDT table represented by the local variable CurrjRSTlDT 2270. If it is the case, then control is given to step 2147; otherwise control is given to step 2146.
  • the individual cell RSTIJopJeftjoell is moved down by a number of rows equal to the value of the "container ow" attribute 2281 of the CurrjRSTIDTjoell 2280. Then the individual cell currjoell is set equal to the individual cell RSTIJopJeftjoell. Then the record 2271 following CurrjRSTIDTjec in CurrjRSTlDT 2270 becomes the new record CurrjRSTIDTjec 2271. Then the first cell of CurrjRSTIDTjec 2271 becomes the new individual cell CurrjRSTIDTjoell 2280.
  • a new record 2261 is created in the RSTIT table 2260 for describing the RSTI that has just been created.
  • the "Addresd' field 2262 is filled with the address of the rir range of cell 2001.
  • the "RST field 2263 is filled with the local variable RSTjName.
  • the "Element #” field 2264 is filled with the local variable Elements
  • the "RSTIDT Ptf field 2265 is filled with the local variable CurrjRSTlDT.
  • the "Header Size” field 2266 is filled with the number of rows of the container rows constituting the RSTI header 2002.
  • the "Footer Sizd' field 2267 is filled with the number of rows of the container rows constituting the RSTI footer 2004.
  • REFERENCED attribute 2229 within the "Type” field 2227 of this record 2221 is updated by multiplying the "INSTANCE REFERENCE” subfield 2229c by 2 (two). Then control is given to step 2132.
  • RE Editor method The method for creating or updating RE's or meta-elements used in the preferred embodiment of the present invention is summarized in flowchart 2340 of FIG 18C. This method can be seen as the processing of the RE Editor command.
  • the method is in its default state, waiting for an event to initiate the process.
  • the RE Editor command is detected, as a result of an user action. This action can be for instance:
  • the parameter of the command is retrieved. It corresponds to a mandatory parameter REjname which can either take a reserved value "NEW" or another value corresponding to a character string name, as found in the "Namd' field 2232 of a record
  • This parameter is recorded as a local variable.
  • step 2344 some local variables are initialized: the local variable REjmeta is set to the value "NO”, the local variable REjsize is set to the value 3 (three), and the local variable RE ank is set to the value 1 (one). •
  • step 2345 a test is performed to determine the value taken by the local variable REjname. If found equal to "NEW”, then control is given to step 2349; otherwise control is given to step 2346.
  • step 2346 the RET table 2210 is looked up to locate a record 2211 whose "Name" field 2212 is found equal to the value taken by the local variable REjname. If such a record is found, then control is given to step 2348; otherwise control is given to step
  • step 2348 Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to step 2341. » At step 2348,
  • a new name for the newly created RE is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Name" fields 702, 712, 722, 2212 and 2222 found in the respective records 701 , 711 , 721 , 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured. Then the new name is recorded in the local variable REjname.
  • memory space is allocated within the main memory 102 to later record the illustrative range of cells for the RE or RME.
  • This allocated memory recorded as the local variable REjouffer is part of the memory space corresponding to the currently opened electronic spreadsheet file.
  • a new record 2211 is created in the RET table 2210, and this new record 2211 is initialized as follows:
  • the "Row #" field 2215 is set to the value 1 (as in the preferred embodiment of the present invention the RST's are managed in a 2D environment; this field would carry the number of defined rows for the created RE in a 3D environment) ;
  • the "FILIATION REFERENCE” (FR) subfield 2219b is initialized according to the following formula, where the jset corresponds to the set of ST's constituting the new RE or meta-element, according to the structure recorded in the "Description Ptf field 2214:
  • FR ⁇ , ef OR, x LCM( ⁇ FR, ⁇ ), e;F •
  • the "INSTANCE REFERENCE” (IR) subfield 2219c is initialized with the value 1 (one).
  • the "SELECTED CHILDREN" (SC) subfield 221 e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the
  • the label box 2324 is initialized with the value of the local variable REjname.
  • the top option button 2331 (respectively bottom option button 2330) is filled with a black point if the local variable REjmeta is found equal to "NO” (respectively "YES").
  • the text box 2326 is filled with the value of the local variable REjsize.
  • the push-button "Savd' 2333 is enabled if the local variable REjsize is found equal to the "Column #" field 2216 of the current record 2211 , or if the attribute "REFERENCED” 2219 within the "Typd' field 2217 of this same record 2211 is found with the subfield "REFERENCED OBJECT" 2219d (RO) equal to "NO”, SO that any future click with the pointing device 105 on this push-button "Savd' 2333 will be recognized as a valid event.
  • the text box 2335 is initialized with the value of the local variable RE ank.
  • the list box 2334 is initialized with the content of the cell belonging to REjouffer and whose offset is equal to RE ank.
  • the list of names available within this list box 2334 (by clicking on the spin button 2328) is constituted by the names of the ST's recorded in the STT table 720.
  • step 2351 the method is waiting for any user action on the RE Editor Dialog Box 2321.
  • user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
  • step 2353 If the user action is a click on the spin button 2328, to select a ST name, then control is given to step 2353;
  • step 2354 • if the user action is a click on the push-button "Save” 2333, then control is given to step 2354;
  • step 2355 • if the user action is a click on the push-button "Save As" 2332, then control is given to step 2355; f the user action s a click on the spin button 2329, then control is given to step 2358; f the user action s a click on the spin button 2327, then control is given to step 2359; f the user action s a click on one of the two option buttons 2330 or 2331 , then control s given to step 2360; • if the user action is a click on the push-button "Done" 2323, or on the closing-window push-button 2322, then control is given to step 2361.
  • the local variable REjouffer is updated by setting equal to the content of the list box 2334 the content of the cell with offset equal to the value of the local variable REjrank. Then control is given to step 2350.
  • the RET table 2210 is updated and saved as part of the electronic spreadsheet file by refreshing the record 2211 whose "Name" field 2212 is equal to the local variable REjname. For this purpose,
  • the "Typd' field 2217 is set as follows: the attribute "META" 2218 is set equal to the value of the local variable REjmeta.
  • the range of cells REjouffer illustrating the current definition of the RE or meta-element is copied onto the memory location pointed by the "Description Ptf field 2214. Then control is given to step 2350.
  • step 2355 a test is performed on the value found in the text box 2325 to determine if it corresponds to a valid new name.
  • the corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Name" fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 2356; otherwise control is given to step 2357.
  • step 2356 memory space is allocated within the main memory 102 to later record the illustrative range of cells for the EF or MEF. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 2211 is created in the RET table 2210 which is saved as part of the electronic spreadsheet file, and this new record 2211 is initialized as follows:
  • the "Description Ptf field 2214 is set to the memory location REjouffer which has just been allocated ;
  • the "Row #' field 2215 is set to the value 1 (as in the preferred embodiment of the present invention the RST's are managed in a 2D environment; this field would carry the number of defined rows for the created RE in a 3D environment) ;
  • the "OWN REFERENCE” (OR) subfield 2219a is initialized with a prime number not yet assigned to any other subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
  • the "SELECTED CHILDREN" (SC) subfield 2219e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED” attribute 2242 equal to the value "YES" in the RSTMT table 2230):
  • step 2350 a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 2325 prior to clicking on the "Save Ad' push-button 2332. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention.
  • step 2350 Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 2350.
  • the local variable REjank is decremented by 1 (one) as long as it remains strictly positive if the user has clicked with the pointing device 106 on the down side of the spin button 2329, and the local variable REjank is incremented by 1 (one) as long as it remains lower than or equal to the value of the local variable REjsize, if the user has clicked with the pointing device 106 on the up side of the spin button 2329. Then control is given to step 2350.
  • the local variable REjsize is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 2327, and as long as it value remains positive and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 2350.
  • the local variable REjmeta is updated, so that its value becomes "YES” (respectively “NO") if the bottom option button 2330 (respectively the top option button
  • step 23331 has been clicked on. Then control is given to step 2350.
  • the method for counting the number of columns or rows within a STI used in the preferred embodiment of the present invention is summarized in flowcharts 2400 and 2420 of FIG 19A and 19B. These methods can be seen as the processing of the STIjRow and STI_col functions. • At step 2401 , the first method is in its default state, waiting for a call to the STIjRow function.
  • the STIjRow function call is detected, as a result of a user action.
  • the function is called with two parameters named STjName and STIj ⁇ lement.
  • the first record 721 of the STT table 720 is set as CurrjRecord.
  • the fields Name 722, Min Elements 725, and Max Element* 726 of the record CurrjRecord 721 are respectively set as the local variables CurrJName,
  • Curr ⁇ in and Curr_Max a At step 2405, a test is performed to check if the local variable Curr_Name is equal to the function parameter ST Name. If it is the case, then control is given to step 2409; otherwise control is given to step 2406.
  • step 2406 a test is performed to check if the record 721 CurrjRecord is the last record of the STT table 720. If it is the case, then control is given to step 2408; otherwise control is given to step 2407. • At step 2407, the record following CurrjRecord in the STT table 720 becomes the new record 721 CurrjRecord. Then control is given to step 2404.
  • the local variable STIjRow is set equal to the value 0 (zero). Then control is given to step 2412. °
  • the range of cells pointed by the description Ptr field 724 of the record 721 CurrjRecord is set as STDTjaddress.
  • the local variable ElementJNbr is set equal to the input parameter STIJ ⁇ Iement, upper bounded by the local variable CurrJMax, and minored by the local variable CurrjMin.
  • the local variable STI jow is set equal to the number of rows of the range of cells STDTjadress, incremented by the value of the local variable STIjElement, and decremented by 1 (one).
  • the execution of the STljrow function completes as control is returned to the function caller.
  • the second method is in its default state, waiting for a call to the STIjCol function.
  • the STIjCol function call is detected, as a result of a user action.
  • the function is called with one parameter named STjName .
  • the first record 721 of the STT table 720 is set as CurrjRecord.
  • the field Name 722 of the record CurrjRecord 721 is set as the local variables CurrjName.
  • step 2425 a test is performed to check if the local variable CurrJMame is equal to the function parameter STjName. If it is the case, then control is given to step 2429; otherwise control is given to step 2426.
  • step 2426 a test is performed to check if the record 721 CurrjRecord is the last record of the STT table 720. If it is the case, then control is given to step 2428; otherwise control is given to step 2427.
  • step 2427 the record following CurrjRecord in the STT table 720 becomes the new record 721 CurrjRecord. Then control is given to step 2424.
  • the local variable STIjRow is set equal to the value 0 (zero). Then control is given to step 2431.
  • the local variable STIjool is set equal to the number of columns of the range of cells STDTjadress.
  • step 2431 the execution of the STIj ol function completes as control is returned to the function caller.
  • the methods and systems according to the present invention may be used advantageously in those environments where elements of information are organized as vertically structured two dimensions tables.
  • the methods and systems according to the present invention may be used advantageously in those environments where elements of information are organized as multidimensional tables having more than two dimensions. While the invention has been particularly shown and described with reference to a preferred embodiment, it will be understood that various changes in form and detail may be made therein without departing from the spirit, and scope of the invention.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Health & Medical Sciences (AREA)
  • Computational Linguistics (AREA)
  • General Health & Medical Sciences (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Artificial Intelligence (AREA)
  • Document Processing Apparatus (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Stored Programmes (AREA)
  • Image Generation (AREA)
  • Electron Beam Exposure (AREA)

Abstract

The present invention is directed to a method, system and program, in a multi-dimensional electronic data table comprising a plurality of data, for creating one or plurality of recursive scalable template instances; a recursive scalable template instance comprising a variable number of contiguous recursive element instances ordered and aligned along a first data table dimension and structured according to a recursive scalable template; a recursive element instance being defined as comprising one or a plurality of scalable template instances; a scalable template instance comprising a variable number of elements structured according to a scalable template; an element being defined as a range of data; a range of data comprising one or a plurality of data; a recursive scalable template comprising a recursive element comprising one or a plurality of scalable templates. The method comprises for each recursive scalable template instance to create, the steps of: • Selecting a recursive scalable template; • Defining a location for creating a recursive scalable template instance; • Creating at the defined location one or a plurality of contiguous recursive element instances ordered and aligned along a first data table dimension; each recursive element instance having a variable size along said first data table dimension and a same size along a second data table dimension; • Structuring each recursive element instance according to the recursive element defined for the recursive scalable template; • Aligning each scalable template instance of each recursive element instance along said first data table dimension; • Aligning within each recursive element instance, each scalable template instance along said second data table dimension.

Description

SYSTEM AND METHOD IN A DATA TABLE FOR CREATING RECURSIVE SCALABLE TEMPLATE INSTANCES
Technical Field of the invention
The present invention relates to the field of information processing by digital computers, more particularly to a method and system, in a data table, preferably an electronic spreadsheet, for creating recursive scalable template instances.
Background art One essential value of electronic spreadsheets is to organize data into columns and rows, while automating tedious calculations. A typical, common, and valuable example of such a set of data organized into columns and rows is a range of cells. Even if a range of cells receives a formal and strict definition within electronic spreadsheet environments, it is flexible enough so that information can be included in either a single range of cells or in a set of several ranges of cells. Ranges of cells therefore are quite useful objects. A range of cell can be defined and processed as a whole entity. For example it can be copied from one place to another place within the spreadsheet or from one spreadsheet file to another spreadsheet file. Ranges of cells are widely used in applications developed in the field of electronic spreadsheets. Most often, the ranges of cells are arranged according to some kind of structure, thus becoming structured ranges of cells. The contents of each cell is defined within an element, where an element is defined as a row of a structured range of cells, and then the same kind of element is repeated a certain number of times, to store/process a variable number of information pieces. Most of the time, several instances of similar structured ranges of cells are used. In the current context where no other tool is really available, instances of such similar structured ranges of cells are frequently created through cut/copy and paste operations. In order to keep a high level of intellectual control over growing quantities of information, human being needs to organize or structure this information. The hierarchical model is often used, because allowing nested structures. A typical and well known example of such a hierarchical structure is the directory tree of computer Operating Systems, such as DOS (Disk Operating System) or Microsoft Windows. The root directory may contain files and/or a number of directories, which may themselves contain files and/or a number of directories, which may themselves contain files and/or a number of directories, etc. Recursivity help structure the information and maintain intellectual control over it. This need for recursivity applies as well, in spreadsheet environment to structured ranges of cells. When several instances of structured ranges of cells are defined and used in an electronic spreadsheet file, they are often themselves structured according to a specific superstructure arrangement or "array of structured ranges of cells" which can be duplicated between different electronic spreadsheet files or even within a single electronic spreadsheet file. Within such an array of structured ranges of cells, it is common to find several structured ranges of cells which follow the same intermediate superstructure, and also some other structured ranges of cells following other intermediate superstructures. The array of structured ranges of cells may then be viewed as a set of aggregated intermediate superstructures of structured ranges of cells. In the current context of conventional electronic spreadsheets, instances of such arrays of structured ranges of cells are frequently created through cut/copy and paste operations. Creating a new instance of a structured range of cells is complex and lengthy, particularly because a conventional range of cells shows strong limitations :
• (i) structure information (such as number of columns, number of rows), format information (such as font style, color or border), and contents information (such as formulas or raw - or informative - data) are mixed,
• (ii) the size of the range of cell is fixed at a given instant. Therefore, when a spreadsheet user wants to create another range of cells with an identical structure, he/she needs to perform successively several operations. He/she needs to : 1. copy-paste an existing structured range of cells, 2. distinguish between areas containing raw - or informative - data and areas containing generic content such as formulas,
3. empty the copied structured range of cells of the copied raw data while trying to keep the structure, format and generic contents, 4. adjust the size of the structured copied range of cells to his new needs.
5. eventually, fill the raw data area with default values, in order to ease subsequent data entry.
Furthermore, before copying and pasting a structured range of cells, the user must prepare the place for the copied structured range of cells, with the risk of overwriting, and therefore loosing the preexisting information at the destination location. This chain of operations rapidly becomes tedious, lengthy and prone to error, especially when manipulated structured ranges of cells increase in size and complexity.
When reeusivity is involved, creating a new instance of an array of structured ranges of cells is even more complex and lengthy, particularly because an array of structured range of cells involves a twofold level of structure:
• At the lower level a set of multiple, and even different, instances of structured ranges of cells must be created. As previously mentioned, this operation is itself complex, lengthy and prone to error due to the limitations of conventional ranges of cells.
• At the higher level, the creation of an instance of an array of structured range of cells would require that the spreadsheet user carry on several operations:
1. Identify an existing instance of an array of structured ranges of cells, used as a reference for creating the new instance.
2. Prepare the place, at the destination location, to hold the new instance, at the risk of possibly overwriting, and then loosing, any pre-existing information. 3. Copy-Paste the reference instance of the array of structured range of cells onto the destination location. 4. Adjust the structure of the newly created instance of an array of structured ranges of cells to his/her new needs, by either deleting or introducing within the array one or several intermediate superstructures of instances of structured ranges of cells. 5. Clean the content of each instance of structured ranges of cells comprised within the array. 6. Eventually fill each instance of structured ranges of cells with the relevant default values. US Patent 5,033,009 entitled "System for generating worksheet files for electronic spreadsheets" Steven J. Dubnoff, March 3rd, 1989, is an interesting document of prior art. This invention develops the concepts of pattern data and variable data that may be integrated to generate a worksheet file through a worksheet file generator. However, this invention shows many limitations preventing it from solving the set of issues presented here above and, in particular : • It aims at producing a new output spreadsheet from a set of two input files, while there is a need, within a user application environment, to create and manipulate new entities within an existing electronic spreadsheet file, that the user is familiar with.
• It contains no mechanism allowing the direct update of the output spreadsheet, other than the regular spreadsheet tool. • It contains no capability to manipulate within the same spreadsheet file, a variable number of different structures and a variable number of instances of each of those structure. The granularity is limited to the spreadsheet file, while the required granularity is that of a structured range of cells.
The so called "file format specification" really mixes structure information (such as number and relative position of columns and rows), presentation information (such as font, color, background, etc.), contents information (such as formulas, etc.). Summary of the invention
As defined in independent claims, the present invention is directed to a method, system and program, in a multidimensional electronic data table comprising a plurality of data, preferably a multidimensional electronic spreadsheet comprising a plurality of cells, for creating one or plurality of recursive scalable template instances; a recursive scalable template instance comprising a variable number of contiguous recursive element instances ordered and aligned along a first data table dimension and structured according to a recursive scalable template; a recursive element instance being defined as comprising one or a plurality of scalable template instances; a scalable template instance comprising a variable number of elements structured according to a scalable template; an element being defined as a range of data; a range of data comprising one or a plurality of data; a recursive scalable template comprising a recursive element comprising one or a plurality of scalable templates. The method comprises for each recursive scalable template instance to create, the steps of: • Selecting a recursive scalable template;
• Defining a location for creating a recursive scalable template instance;
• Creating at the defined location one or a plurality of contiguous recursive element instances ordered and aligned along a first data table dimension; each recursive element instance having a variable size along said first data table dimension and a same size along a second data table dimension;
• Structuring each recursive element instance according to the recursive element defined for the recursive scalable template;
• Aligning each scalable template instance of each recursive element instance along said first data table dimension; • Aligning within each recursive element instance, each scalable template instance along said second data table dimension. Further embodiments of the invention are provided in the appended dependent claims.
Acronyms The following acronyms will be used for more conciseness: • EF stands for Element Format
• EP stands for Element Profile
• MEF stands for Meta-element Format
• EP stands for Meta-element Profile
• RE stands for Recursive Element • RME stands for Recursive Meta-Element
• RST stands for Recursive Scalable Template
• RSTI stands for Recursive Scalable Template Instance
• ST stands for Scalable Template
• STI stands for Scalable Template Interface Brief description of the drawings
• Figure 1 A is a schematic view of a computer system in which the present invention may be embodied.
• Figure 1B is a schematic view of a software system including an operating system, an application software, and a user interface for carrying out the present invention. • Figure 2 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for managing RST's.
• Figure 3 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing EF's.
• Figure 4 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing EP's.
° Figure 5 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing ST's.
• Figure 6 shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing RST's. • Figures 7A, 7B, 7C, 7D, and 7E respectively illustrate the structure of the EF Table (EFT), of the EP Table (EPT), of the ST Table (STT), of a ST Descriptor Table (STDT), of the STI Table (STIT), according to the preferred embodiment of the present invention. ° Figure 7F gives a graphical illustration of the relationships established between the tables EFT, EPT, STT, STDT, STIT, RET, RSTT, RSTDT, RSTIT and RSTIDT according to the preferred embodiment of the present invention. ° Figure 8 is a flow chart illustrating a preferred method for managing RST objects according to a preferred embodiment of the present invention. ° Figure 9 is a flow chart illustrating a preferred method for editing EF's and MEF's according to a preferred embodiment of the present invention. ° Figure 10 is a flow chart illustrating a preferred method for editing EP's and MEP's according to a preferred embodiment of the present invention. ° Figures 11 is a flow chart illustrating a preferred method for editing a ST according to a preferred embodiment of the present invention.
• Figures 12 is a flow chart illustrating a preferred method for editing a RST according to a preferred embodiment of the present invention.
Figure 13A shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for creating STI's. • Figure 13B illustrates the ST instanciation, according to a preferred embodiment of the present invention.
Figure 14A is a flow chart illustrating a preferred method for instanciating a ST according to a preferred embodiment of the present invention.
Figure 14B is a flow chart illustrating a preferred method for creating a STI according to a preferred embodiment of the present invention.
Figure 15A illustrates the logical structure of a RSTI, according to the preferred embodiment of the present invention.
Figure 15B illustrates the logical structure of a RST, according to the preferred embodiment of the present invention. • Figures 16A and 16B constitute a flow chart illustrating a preferred method for creating
RSTI's according to a preferred embodiment of the present invention.
Figures 17A, 17B, 17C, 17D, 17E and 17F respectively illustrate the structure of the RE
Table (RET), of the RST Table (RSTT), of the RST Manager Table (RSTMT), of a RST
Descriptor Table (RSTDT), of the RSTI Table (RSTIT), and of a RSTI Descriptor Table (RSTIDT).
Figure 18A shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for creating RSTI's.
Figure 18B shows a preferred spreadsheet user interface, according to the preferred embodiment of the present invention, for editing RE's. • Figure 18C is a flow chart illustrating a preferred method for editing RE's in RST's according to a preferred embodiment of the present invention.
Figure 19A is a flow chart illustrating a preferred method for computing the number of rows comprised in a STI according to a preferred embodiment of the present invention.
Figure 19B is a flow chart illustrating a preferred method for computing the number of columns comprised in a STI according to a preferred embodiment of the present invention.
Detailed description of the preferred embodiment SYSTEM HARDWARE : As shown in FIG. 1A, the present invention may be embodied on a computer system 100 comprising a central processor 101, a main memory 102, an input/output controller 103, a keyboard 104, a pointing device 105 (e.g., mouse, track ball, pen device, or the like), a display device 106, and a mass storage 107 (e.g., hard disk). Additional input/output devices, such as a printing device 108, may be included in the system 100 as desired. As illustrated, the various components of the system 100 communicate through a system bus 110 or similar architecture. In a preferred embodiment, the computer system 100 includes an IBM-compatible personal computer, which is available from several vendors (including International Business Machine - IBM Corporation of Armonk, N.Y.). As illustrated in FIG. 1B, a computer software system 150 is provided for directing the operation of the computer system 100. Software system 150, which is stored in system memory 102 and on disk memory 107, includes a kernel or operating system 151 and a shell or interface 153. One or more application programs, such as application software 152, may be "loaded" (i.e., transferred from storage 107 into memory 102) for execution by the system 100. The system 100 receives user commands and data through user interface 153; these inputs may then be acted upon by the system 100 in accordance with instructions from operating module 151 and/or application module 152. The interface 153, which is preferably a graphical user interface (GUI), also serves to display results, whereupon the user may supply additional inputs or terminate the session. In a preferred embodiment, operating system 151 and interface 153 are Microsoft Win95, available from Microsoft Corporation of Redmond, Wash. Application module 152, on the other hand, includes a spreadsheet notebook of the present invention as described in further detail herein below.
INTERFACE : The following descriptions will focus on the presently preferred embodiments of the present invention implementing the user interfaces described in international patent application PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al. RECURSIVE SCALABLE TEMPLATE MANAGEMENT A. Introduction The concept of scalable templates (ST's)
Conventional electronic spreadsheets include built-in means allowing the spreadsheet users to easily organize data into columns and rows, while automating tedious calculations. This set of organized data can be included in either a single range of cells or in a set of several ranges of cells. The range of cells is a quite useful, and widely used object in an electronic spreadsheet environment. It can be defined and processed as a whole entity. According to the invention described in international patent application PCT/EP 02/09483 (IBM's reference FR9 2001 0029), systems and methods are available to allow an electronic spreadsheet user to:
• Define a structure, for a range of cells, including :
• (i) an optional header part made of one or more meta-elements ; • (ii) a mandatory body part made of one or more elements ;
• (iii) an optional footer part made of one or more meta-elements.
The structure of each meta-element of the header part may be defined in terms of attributes by a MEF, and in terms of contents by a MEP.
The structure of ail elements of the body part, may be defined in terms of attributes by an EF, and in terms of contents by an EP.
The structure of each meta-element of the footer part may be defined in terms of attributes by a MEF, and in terms of contents by a MEP.
This structure is called a ST. In summary, the ST defines a structure by specifying the number of fields, by referring to a couple of EF and EP that defines all body elements, and, optionally, by referring to one or several couples of MEF and MEP that define each meta-element of the header part or the footer part.
• Manage ST's and underneath defined objects, known as EF's, EP's, MEF's and MEP's. ° Create, or update EF's, MEF's.
• Create, or update EP's, MEP's. ° Create, or update a ST.
° Create a STI abiding by a defined ST.
• Insert one or a plurality of elements within a STI.
• Remove one or a plurality of elements from a STI. The above set of functions is supported by a set of tools :
• the "RST Manager" method, or RSTM method for short;
• the "EF Editor" method, or EFE method for short;
• the "EP Editor" method, or EPE method for short; β the "ST Editor" method, or STE method for short;
° the "ST Instanciator" method, or STI method for short;
The concept of Recursive Scalable Templates (RST's)
Having introduced the concept of ST's and of STI's, the concept of RST's and RSTI's becomes easier to capture. Indeed a RST can be seen as a two level structure. The highest level is logically equivalent to the structure of a ST, as a set of structured RE and RME's which can be logically mapped to element and meta-elements. The recursive nature of a RST appears at the lower structural level, because the RE and RME's are objects which themselves comprise STI's (instead of conventional spreadsheet cells, as it is the case for elements and meta-elements). In other words, a RST is a tiered structure of ST's. When a RST is instanciated, the same similarities can be articulated to describe the structure of the resulting RSTI. At a higher level, a RSTI presents a structure logically equivalent to the structure of a STI, but constituted by container ranges instead of individual cells. Within each container range, a lower level structure is present in the form of STI's. As a result a RSTI can be seen as a STI itself containing STI's in lieu of conventional cells. Such an object was therefore first introduced under the name of "an array of structured ranges of cells". Referring now to FIG 15A and 15B, a simple example of such a RST and RSTI will be used to illustrate the present application. By referring first to FIG 15B, the RST 2051 named "RST_customet" defines the structure followed by a Network Services Provider to record all the various data corresponding to a customer receiving networking services. This RST is organized around a structure comprising:
• A header part 2052 where the customer data (such as company name, address, business, contract schedule, etc.) are recorded according to the structure of a ST named "ST_cust_data" , where the customer contact points (such as CEO, CIO, CFO, managers, etc.) are recorded according to the structure of a ST named "ST_contactέ', where the contracted service level agreements are recorded according to the structure of a ST named "ST_SLA", and where the customer support team (such as the transition manager, the delivery manager, the solution manager, etc.) is recorded according to the structure of a ST named "ST_support_team".
• A body part 2053 where is recorded, for each customer resource receiving services from the service provider, the information required to manage this resource (such as location,
IP address, configuration file, etc.) according to the structure of a ST named "ST_ms_infd', and where is recorded the current problem log for the same resource according to the structure of a ST named "ST_pb_lod
• A footer part 2054 where is recorded the billing status for this customer, according to the structure of a ST named "ST_billind', and where are recorded the problem statistics for the customer managed resources, according to the structure of a ST named "ST_statέ'. By referring then to FIG 15B, the RSTI 2001 follows the structure of the RST 2051 "RST_customθi". Indeed it is also organized around a structure comprising a header part 2002, a body part 2003, and a footer part 2004. The header part 2002 contains four STI's which are themselves organized according to the structure of the RST header part 2052, and which abide by the structures of the ST's ""ST_cust_data", "ST_contactέ "ST_SLA", and "ST_support_tea n. The body part 2003 is constituted by three different records 2010, 200Θ, and 2008, each of them organised according to the structure of the RST body part 2053, that is comprising two STI's which abide by the structures of the ST's "ST_res_infd and "ST_cpb_lod'. Finally the footer part 2004 contains two STI's which are themselves organized according lo the structure of the RST footer part 2054, and which abide by the structures of the ST's uST_billind', and "ST_statέ'. Most often also, several instances of similar recursively structured ranges of cells are used. Within the logic of our example, as described above and illustrated in FIG 15A, a similar recursively structured range of cells is created for each customer in a new sheet. In the current context of electronic spreadsheet environment, where no other tool is really available, instances of such similar recursively structured ranges of cells are frequently created through cut/copy and paste operations. We have already described the limitations of conventional tools for creating STI's. The creation of a RSTI is even more difficult and prone to errors due to the twofold structure of a RSTI. Indeed the additional difficulty appearing when manipulating such recursive objects is to determine the structural level at which should occur a given operation (such as copy-pasting a recursive object, identifying areas containing row data or structure specific data within a recursive object, adjusting the size of a recursive object, emptying some fields within a recursive object, correcting any error resulting from the previous operations applied to a recursive object, and filling default values in some fields within a recursive object). Furthermore, before the copy-paste operation, on the recursively structured range of cells, takes place, the user must prepare the place for the copied recursively structured range of cells, at the destination location, with the risk, if this is not done, of overwriting, and therefore loosing the preexisting information at this location. The chain of operations described above rapidly becomes tedious, lengthy and prone to error, mainly because the size and complexity of recursively structured ranges of cells are quickly reaching the limits of human beings, when using conventional tools. In a preferred embodiment of the present invention, a user-friendly solution to these problems is proposed by allowing the electronic spreadsheet user to:
• Define a superstructure, for a range of cells, including :
• (i) an optional header part made of one or more RME's ;
• (ii) a mandatory body part made of one RE's ;
• (iii) an optional footer part made of one or more RME's. The structure of each RME of the header part is defined as an ordered collection of superstructure fields, each corresponding to a ST. The structure of all RE's of the body part, is defined as an ordered collection of superstructure fields, each corresponding to a ST. The structure of each RME of the footer part is defined as an ordered collection of superstructure fields, each corresponding to a ST. This superstructure is called a RST. In summary, the RST defines a superstructure by specifying the number of fields, by referring to a RE that defines the body part, and, optionally, by referring to one or several RME's that define the header part and/or the footer part. Manage RST's and underneath defined objects, known as RE's and RME's. Create, or update RE's. • Create, or update RME's. Create, or update a RST. Create a RSTI abiding by a defined RST. The above set of functions is supported by a set of tools : the "RST Manager" method, or RSTM method for short; • the "RE Editor" method, or REE method for short; the "RST Editor" method, or RSTE method for short; the "RSTInstanciator" method, or RSTI method for short. This set of functions is defined in much further details, in the following sections. In our example, a RST is developed to define the generic structure of the "NSP Customer Repository" and thus to facilitate the creation of several instances of said "NSP Customer Repository". Now referring to FIG 15B, the RST defining the structure of "NSP Customer Repository" : ° (i) Specifies the number of superstructure fields, 2 (two) in our exemple.
* (ii) Defines the header part of 2052 "NSP Customer Repository", through the following steps :
° Defining the structure of a first ST "ST_cust_daia", and of a second ST "ST_contactεT.
• Defining the structure of a first RME 2058 comprising the two previous ST's. • Defining the structure of a third ST "ST_SLA", and of a fourth ST " S T_support_ team" .
• Defining the structure of a second RME 2057 comprising the two previous ST's.
• (iii) Defines the body part 2053 of "NSP Customer Repository", through the following steps :
G Defining the structure of a fifth ST "ST_res_infd', and of a sixth ST "ST_pb_lod'. ° Defining the structure of a RE 2056 comprising the two previous ST's. ° (iv) Defines the footer part 2054 of "NSP Customer Repository", through the following ° Defining the structure of a first ST "ST_billincf, and of a second ST "ST_siat£'.
• Defining the structure of a RME 2055 comprising the two previous ST's.
From the above RST 2051, one or several RSTI's, such as the one illustrated in FIG 15A, can be created, at very limited cost to the user and thus avoiding the many risks for error. B. Concepts and Vocabulary The purpose of this section is to formalize both some concepts (with associated objects) and some vocabulary defined within the scope of the present invention. In the following descriptions, it is assumed that spreadsheets are in two dimensions (2D), so that tables and structures can be described in a 2D environment. Moreover it is assumed that tables are organized vertically, so that the table headings are on the top of the table instead of being on its left. This allows to significantly clarify the description of the various original concepts, objects, and methods which are part of the present invention, but this does not limit in any way the scope of the invention. In other words, the underneath description can be generalized to environment with either 2D tables organized horizontally or with 3D tables, without departing from the spirit of the present invention. B1. Preliminary Definitions
Structured Range of Cells : a structured range of cells is a range of cells that abides by some kind of structure organizing the data into rows and columns. Columns define fields aimed at containing the same kind of information on each row. Rows define records (or elements). Table : the word table can be used to designate a structured range of cells. Field : a field is a labeled column in a database or table that contains the same kind of information for each record (or element). For example, a customer table may contain fields labeled Name, Address and Tel #.
By extension, in a given record (or element), a given field refers to the cell located at the intersection of the record (or element) and the given field (labeled column). The above definitions are for a 2D environment where columns define fields and rows define records. They can be transposed in a 2D environment where rows define fields and columns define record. They can also be transposed in a 3D environment, where, for example, sheets define records. IN/OUT Cell: a cell is specified as "IN" cell when assumed to be used for recording user provided information. A cell is specified as "OUT" cell when assumed to be used for producing information (generally obtained through formulas whose arguments refer directly or indirectly to "IN" cells). B2. Object Definitions
The following objects are defined to help the understanding of the invention. Element Format : an EF is a spreadsheet object defining the structure of an element within a 2 dimensions or a 3 dimensions range of cells, in terms of format attribute :
• Background attributes (color, pattern, etc.),
• Alignment attributes (horizontal, vertical, text wrapping, alignment across columns, etc..) 0 Font attributes (size, color, etc..) β Line attributes (type, color, etc..) • Protection of the field
° and any other conventional format attribute. Meta-Element Format : a MEF is a spreadsheet object defining the structure of a meta-element within a 2 dimensions or a 3 dimensions range of cells, in terms of format attribute :
• Background attributes (color, pattern, etc.), β Alignment attributes (horizontal, vertical, text wrapping, cell merging, etc.) ° Font attributes (size, color, etc.) ° Line attributes (type, color, etc.) 0 Protection of the field ° and any other conventional format attribute. Element Profile : an EP is a spreadsheet object defining the structure of an element within a 2 dimensions or a 3 dimensions range of cells, in terms of content and destination : s formulas for fields to be computed from data comprised in other fields of the same element, or in other fields of another element or meta-element of the same STI, or even in other fields outside the STI. • field default values to be assigned at element creation time.
• destination of the cells (data entry for "IN" cells or data produced for "OUT" cells). Meta-Element Profile : a MEP is a spreadsheet object defining the structure of a meta-element within a 2 dimensions or a 3 dimensions range, in terms of content and destination : • formulas for cells to be computed from data comprised in other cells of the same element, or in other cells of another element or meta-element of the same STI, or even in other cells outside the STI.
• cell default values to be assigned at meta-element creation time.
• destination of the cells (data entry for "IN" cells or data produced for "OUT" cells) Scalable Template (also referred to as "Template" or "ST") : A ST is a spreadsheet object defining the structure of a 2 dimensions or a 3 dimensions range of cells, in terms of {element + meta-elements} layout. The word "scalable" refers to the capability of the ST of defining a given structure for variable size (e.g. ranging from a minimum value to a maximum value) range of cells. The ST defines a structure by : • specifying the number of fields,
• by referring to a couple of EF and/or EP that defines each body element, and,
• optionally, by referring to one or several couples of MEF's and/or MEP's.
In a 2 dimensions environment, such MEF's / MEP's are either located above the EF / EP, constituting the ST "header" part, or located below the EF / EP, constituting the ST "footer"" part. Either the ST "header" part or the ST "footer" part, or both of them may be empty. When the element and meta-element references are only constituted by EP's and MEP's, then the ST only carries contents information and can thus be named Scalable Profiled Template. When the element and meta-element references are only constituted by EF's and MEF's, then the ST only carries format information and can thus be named Scalable Formatted Template. When the element and meta-element references are constituted by any combination of both EP's and EF', then the ST carries both profile and format information and can thus be named Scalable Profiled & Formatted Template. Scalable Template Instance (also referred to as "Instance" or "scalable instance" or "STI") : A STI is a spreadsheet object abiding by the structure of a defined ST : a scalable formatted template, or a scalable profiled template, or a scalable profiled & formatted template. An STI may be viewed as a heir object of a ST. It contains a variable number of elements (at least one) containing information, in each field, corresponding to the parent structure, and constituting the "body" part, plus optionally one or several meta-elements, as defined by the ST, and constituting the "header" part and the "footer" part of the STI. Element : An element is a spreadsheet object belonging to a STI, and made of elementary fields abiding either by an EF, or by an EP, or by a couple (EF, EP) found in the parent structure (respectively scalable formatted template, or scalable profiled template, or scalable profiled & formatted template). Without loosing any generality, it is assumed that an element always abides by a couple (EF, EP), where either the EF or the EP can be reduced to a void object.
Meta-Element : A meta-element is a spreadsheet object belonging to an STI, and made of elementary cells abiding either by a MEF, or by a MEP, or by a couple (MEF, MEP). Without loosing any generality, it is assumed that a meta-element always abides by a couple (MEF, MEP), where either the MEF or the MEP can be reduced to a void object. Recursive Element : A RE is a spreadsheet object belonging to a RST, constituting the body part of the RST, and made of elementary fields used to record the names of ST's. A RE has a structure similar to the structure of an element, but instead of being instanciated as a range of cells, is instanciated as a range of STI's.
Example : The RE of the RST 2051, as illustrated in FIG 15B, corresponds to the structure
2056, constituting the body part 2053 of this RST, and made of two fields which respectively contain the name of the ST's "ST_res_infd' and "ST_pb_lo '.
Recursive Meta-element : A RME is a spreadsheet object belonging to a RST, belonging to the header and/or footer part of the RST, and made of elementary fields used to record the names of ST's. A RME has a structure similar to the structure of a meta-element, but instead of being instanciated as a range of cells, is instanciated as a range of STI's. Example : A RME of the RST 2051, as illustrated in FIG 15B, corresponds to the structure 2058, belonging to the header part 2052 of this RST, and made of two fields which respectively contain the name of the ST's "ST_cust_data" and "ST_contactέ'.
Recursive Scalable Template (also referred to as "Recursive Template" or "RST"): A RST is a spreadsheet object defining the superstructure of a 2 dimensions or a 3 dimensions range of cells, in terms of {RE + RME's} layout. The word "scalable" refers to the capability of the RST of defining a given superstructure for variable size (e.g. ranging from a minimum value to a maximum value) range of cells. The RST defines a superstructure by :
• specifying the number of fields,
• by referring to a RE that defines the body part of the RST, and,
• optionally, by referring to one or several RME's.
In a 2 dimensions environment, such RME's are either located above the RE, constituting the RST "header" part, or located below the RE, constituting the RST "footer" part. Either the RST "header" part or the RST "footer" part, or both of them may be empty. Example : A RST 2051 is illustrated in FIG 15B. It is constituted by a header part 2052, a body part 2053 and a footer part 2054. The header part comprises two RME's 2058 and
2057, both with two fields, and which respectively contain the name of the ST's "ST_cust_data", "ST_contactsr and "ST_SLA", "ST_support_team". The body part comprises one RE 2056 with two fields which respectively contains the name of the ST's "ST_res_infd', "ST_pb_lod'. The footer part comprises one RME 2055 with two fields which respectively contains the name of the ST's "ST_billind', "ST_statέ Recursive Scalable Template Instance (also referred to as "Recursive Instance" or "Recursive Scalable Instance" or as RSTI): A RSTI is a spreadsheet object abiding by the structure of a defined RST. A RSTI may be viewed as a heir object of a RST. It contains a variable number of container rows (at least one) containing one or a plurality of STI's, corresponding to the parent RE structure, and constituting the "body" part, plus optionally one or several other container rows containing one or a plurality of STI's, corresponding to the parent RME's structure, and constituting the "header" part and the "footer" part of the RSTI.
Example: A RSTI 2001 is illustrated in FIG 15A. This RSTI abides by the RST 2051 as illustrated in FIG 15B. It is constituted by a header part 2002, a body part 2003 and a footer part 2004. The header part comprises two container rows 2012 and 2011. The body part comprises three container rows 2010, 2009 and 2008. The footer part comprises one container row 2007. Each container row contains two container ranges, such as the container range 2014 which can be seen as the intersection of the top container row 2012 and of the right container column 2005. Each container range contains a STI which abides by the structure of the ST defined as part of the RE or RME member of the RST 2051. For instance the STI 2034 comprised within the container range intersection of the container row 2010 and of the container column 2005 abides by the structure of the ST named "ST_pb_lod', as defined in the RME 2056 of the RST 2051, and is itself constituted by a header part 2015, a body part 2016 and a footer part 2017.
Container rows :a container row is a spreadsheet object belonging to a RSTI, and corresponding to the range of cells containing the STI's which are structured according to the definition of a RE or of a RME part of the RST that the RSTI abides by. The number of rows of a container row is equal to the number of rows of the highest STI it contains. A container row can also be referred to as a recursive element instance. A container row can be seen within a RSTI as equivalent to an element within a STI.
Example : The container row 2012 is illustrated in FIG 15A, and corresponds to the range of cells comprising the STI's 2032 and 2013 which are defined within the RSTI 2001. The number of rows of this container row is equal to the number of rows of the STI 2032 which is higher than the STI 2013.
Container columns : a container column is a spreadsheet object belonging to a RSTI, and corresponding to the range of cells containing the STI's which occupy the same superstructure position within the container rows of the RSTI. The number of columns of a container column is equal to the number of columns of the widest STI it contains. Example : The container column 2006 is illustrated in FIG 15A, and corresponds to the range of cells comprising the STI's occupying the leftmost position within the RSTI 2001. The number of columns of this container column is equal to the number of columns of the STI 2030 which is the widest STI on the left side of the RSTI 2001. Container ranges : a container range is a spreadsheet object belonging to a RSTI, and corresponding to the intersection of a container row and of a container column. Each container range contains a single STI which occupies the top and leftmost corner. A container range within a RSTI can be seen as equivalent to a single cell within a STI. Example : The container range 2014 is illustrated in FIG 15A, and corresponds to the intersection of the container row 2012 and of the container column 2005, both belonging to the RSTI 2001. This container range 2014 contains the STI 2013. B3. Notations
The following notation : π^ aι corresponds to the multiplication of the terms a, the index i belonging to the set s. The following notation : LCM({aι})te corresponds to the Least Common Multiplier of the terms aι, the index i belonging to the set s. If S is constituted by a single element a, then LCM({ai})ieΛ is equal to a. The following notation : a Mod b corresponds to the remainder of the division of a by b. C. Tables used for managing RST objects
As introduced in the previous section, the preferred embodiment of the present invention relies on different types of objects for managing RST's. These objects are recorded in different repositories, so that they can be accessed and updated by the different methods which are part of the preferred embodiment of the present invention. Such repositories are referred to as tables:
• the EF Table or EFT for short,
• the EP Table or EPT for short, • the ST Table or STTfor short, a The ST Descriptor Table or STDT for short.
■ The ST Instanciator Table or STIT for short. a The RE Table or fiETfor short.
• The RST Table or RSTTlor short. ° The RST Manager Table or RSTMT for short.
0 The RST Descriptor Table or RSTDT 'for short.
• The RSTI Table or flST/T for short.
• The RSTI Descriptor Table or RSTIDT for short. The EFT, EPT, STT, STDT, STIT, RET, RSTT, RSTDT, RSTIT, and RSTIDT tables are saved as part of the spreadsheet disk file on the mass storage 107, whereas the RSTMT table is temporarily saved on the main memory 102. C1. EF Table Referring now to FIG. 7A, the EFT Table 700 corresponds to a logical simple structure made of several records 701, each of them corresponding to an EF or to a MEF, according to the present invention. Each record includes six fields:
° The "Name" 702 field is used for recording a character string which uniquely identifies the EF or the MEF described by the current record 701. ° The "Last Change Date" 703 field is used for recording the date of the last update of the EF or the MEF described by the current record 701. a The "Description Ptr" 704 field is a reference pointing to the memory location where is recorded an illustrative range of cells depicting the EF or MEF described by the current record 701. This memory location can either be on the Mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
• The "Row #" 705 field is used for recording the number of rows present in the EF or in the MEF described by the current record 701. This field is relevant for 3D ST's where element or MEF's correspond to 2D structures. In the preferred embodiment of the present invention where 2D ST's are assumed, this field is always filled with the value 1.
• The "Column #"706 field is used for recording the number of columns present in the EF or in the MEF described by the current record 701.
• The "Type" 707 field is used for recording different attributes associated to the EF or to the MEF described by the current record 701 : this is the "META" attribute 708 specifying if the current record 701 describes an EF or a MEF (with respective values "NO" and "YES"), and the "REFERENCED" attribute 709 specifying through dedicated subfields (709a, 709b, 709c, 709d and 709e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED" attribute 2240. Conventional techniques can be used for encoding these different attributes in this "Typd' field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention. C2. EP Table
Referring now to FIG. 7B, the EPT Table 710 corresponds to a logical simple structure made of several records 711, each of them corresponding to an EP or to a MEP, according to the present invention. Each record includes six fields:
• The "Name" 712 field is used for recording a character string which uniquely identifies the EP or the MEP described by the current record 711.
• The "Last Change Date" 713 field is used for recording the date of the last update of the EP or the MEP described by the current record 711.
• The "Description Ptr" 714 field is a reference pointing to the memory location where an illustrative range of cells depicting the EP or MEP described by the current record 711 is recorded. This memory location can either be on the Mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
• The "Row #"715 field is used for recording the number of rows present in the EP or in the MEP described by the current record 711. This field is relevant for 3D ST's where element or MEP's correspond to 2D structures. In the preferred embodiment of the present invention where 2D ST's are assumed, this field is always filled with the value 1. ° The "Column #"71 field is used for recording the number of columns present in the EP or in the MEP described by the current record 711.
• The Type" 717 field is used for recording different attributes associated to the EP or to the MEP described by the current record 711: this is the "META" attribute 718 specifying if the current record 701 describes an EP or a MEP (with respective values "NO" and "YES"), and the "REFERENCED" attribute 719 specifying through dedicated subfields (719a, 719b, 719c, 719d and 719e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED" attribute 2240. Conventional techniques can be used for encoding these different attributes in this "Type" field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention.
C3. ST Table Referring now to FIG. 7C, the STT Table 720 corresponds to a logical simple structure made of several records 721 , each of them corresponding to a ST, according to the present invention. Each record includes six fields: o The "Name" 722 field is used for recording a character string which uniquely identifies the ST described by the current record 721. • The "Last Change Date" 723 field is used for recording the date of the last update of the ST described by the current record 721.
• The "Description Ptr" 724 field is a reference pointing to the memory location where a description of the ST described by the current record 721 is recorded. This memory location can either be on the mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention. This description is structured according to the STDT table 760 illustrated in FIG 7D, that is as an ordered list of couples of names, each couple being made by the name of an element or MEF and by the name of an element or MEP.
• The "Min Element #"725 field is used to record the minimum number of elements found in each STI abiding by the ST described by the current record 721.
• The "Max Element #" 726 field is used to record the maximum number of elements found in each STI abiding by the ST described by the current record 721.
• The "Type" 727 field is used for recording different attributes associated to the ST described by the current record 721 : this is the "META" attribute 728 which always take the value "NO", and the "REFERENCED" attribute 729 specifying through dedicated subfields (729a, 729b, 729c, 729d and 729e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED" attribute 2240. Conventional techniques can be used for encoding these different attributes in this "Type" field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention. C4. ST Descriptor Table
Referring now to FIG. 7D, the STDT Table 760 corresponds to a logical simple structure made of several couples of element or MEF 765 and of element or MEP 764. This structure is organized into three sub-sets:
• The optional ST "Headei" part 767, made of a variable number (possibly null) of couples like the top couple 761. Each of these couples is constituted by a MEF (column 765) and by a MEP (column 764).
• The mandatory "Body" part 762 made of a single couple constituted by an EF (column 765) and by an EP (column 764).
6 The optional ST "Foote part 766, made of a variable number (possibly null) of couples like the bottom couple 763. Each of these couples is constituted by a MEF (column 765) and by a MEP (column 764).
C5. ST Instanciator Table Referring now to FIG. 7E, the STIT Table 750 corresponds to a logical simple structure made of several records 751, each of them corresponding to a STI, according to the preferred embodiment of the present invention. Each record includes six fields: • The "Address" 752 field is used for locating the STI described by the current record 751 : its value corresponds to the conventional character string used to record the address of any range of cells.
• The "ST" 753 field is used for recording the name of the ST abided by the STI described by the current record 751.
° The "Element #" 754 field is used for recording the number of elements within the STI described by the current record 751. ° The "Critical" 755 field is used for recording if the STI described by the current record
751 is considered as critical. Its content can take the values "YES" or "NO". ° The "Header Size" 756 field is used for recording the number of meta-elements constituting the Header part of the STI described by the current record 751. ° The "Footer Size" 757 field is used for recording the number of meta-elements constituting the Footer part of the STI described by the current record 751. C6. RE Table Referring now to FIG. 17A, the RET Table 2210 corresponds to a logical simple structure made of several records 2211 , each of them corresponding to a RE or to a RME, according to the present invention. Each record includes six fields:
• The "Name" 2212 field is used for recording a character string which uniquely identifies the RE or the RME described by the current record 2211. • The "Last Change Date" 2213 field is used for recording the date of the last update of the RE or of the RME described by the current record 2211.
• The "Description Ptr" 2214 field is a reference pointing to the memory location where is recorded an illustrative range of cells depicting the RE or the RME described by the current record 2211. This memory location can either be on the Mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
• The "Row #"2215 field is used for recording the number of rows present in the RE or in the RME described by the current record 2211. This field is relevant for 3D RST's where RE's or RME's correspond to 2D structures. In the preferred embodiment of the present invention where 2D RST's are assumed, this field is always filled with the value 1.
• The "Column #" 2216 field is used for recording the number of columns present in the RE or in the RME described by the current record 2211.
• The ype" 2217 field is used for recording different attributes associated to the RE or to the RME described by the current record 2211 : this is the "META" attribute 2218 specifying if the current record 2211 describes a RE or a RME (with respective values "NO" and "YES"), and the "REFERENCED" attribute 2219 specifying through dedicated subfields (2219a, 2219b, 2219c, 2219d and 2219e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED" attribute 2240. Conventional techniques can be used for encoding these different attributes in this 'Type" field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention. C7. RST Table
Referring now to FIG. 17B, the RSTT Table 2220 corresponds to a logical simple structure made of several records 2221 , each of them corresponding to a RST, according to the present invention. Each record includes six fields: e The "Name" 2222 field is used for recording a character string which uniquely identifies the RST described by the current record 2221.
• The "Last Change Date" 2223 field is used for recording the date of the last update of the RST described by the current record 2221. β The "Description Ptr" 2224 field is a reference pointing to the memory location where a description of the RST described by the current record 2221 is recorded. This memory location can either be on the mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention. This description is structured according to the RSTDT table 2250 illustrated in FIG 17D, that is as an ordered list of RME or RE names.
• The "Min Element #"2225 field is used for recording the minimum number of RE's found in every RSTI abiding by the RST described by the current record 2221.
° The "Max Element #" 2226 field is used for recording the maximum number of RE's found in every RSTI abiding by the RST described by the current record 2221.
° The Type" 2227 field is used for recording different attributes associated to the RST described by the current record 2221 : this is the "META" attribute 2228 which always take the value "NO", and the "REFERENCED" attribute 222© specifying through dedicated subfields (2229a, 2229b, 2229c, 2229d and 2229e) the relationships with other objects. These subfields are described as part of the description of the "REFERENCED" attribute 2240. Conventional techniques can be used for encoding these different attributes in this "Type" field, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention.
C8. RST Manager Table .
Referring now to FIG. 17C, the flSTMTTable 2230 corresponds to a logical simple structure made of several records 2231 , each of them corresponding to an object managed by the RST manager, according to the preferred embodiment of the present invention. Each record includes seven fields:
• The "Name" 2232 field is used for recording a character string which uniquely identifies the object described by the current record 2231.
• The "Last Change Date" 2233 field is used for recording the date of the last update of the object described by the current record 2231.
• The "Description Ptr" 2234 field is a reference pointing to the memory location where is recorded a description of the object described by the current record 2231. This memory location can either be on the Mass storage 107, or on the main memory 102, or on other conventional memory repository means, without departing from the spirit of the present invention.
• The "Info Field 1" 2235 field is used for recording a first piece of information associated to the object described by the current record 2231.
• The "Info Field 2" 2236 field is used for recording a second piece of information associated to the object described by the current record 2231. • The Type" 2237 field is used for recording different attributes associated to the object described by the current record 2231 , such as:
• the attribute "META" 2239 previously described for the similar 'Type" fields 707, 717, 727, 777, 2217, and 2227, and also two other attributes:
• the attribute "REFERENCED" 2240 which is constituted by 5 (five) subfields, according to the FIG 17C illustrating an example of RSTMT table 2230:
• The "OWN REFERENCE" (or OR for short) subfield 2240a. This subfield is a unique prime number assigned when the object described by the record 2231 is created. This prime number is released only when the object described by the record 2231 is deleted. • The "FILIATION REFERENCE" (or FR for short) subfield 2240b. This subfield is evaluated according to the following formula, where the set corresponds to the set of objects constituting the object described by the record 2231 :
FR = E yOR, x LCiVi({FR,}),ey The above formula allows to dynamically link the object described by the record 2231 with the objects constituting it, because any change in the value of one of the factors OR, or FR, will be automatically reflected into FR. If the set is empty (for instance when the object described by the record 2231 is an EP, or a MEP, or an EF, or a MEF), then the FR subfield defaults to the value 1 (one). • The "INSTANCE REFERENCE" (or IR for short) subfield 2240c. This subfield is initiated to the value 1 (one) when the object described by the record 2231 is created.
Afterwards this subfield is multiplied by 2 (two) each time a new instance abiding by this object is created, and is divided by 2 (two) each time an existing instance abiding by this object is deleted.
° The "REFERENCED OBJECT" (or RO for short) subfield 2240d. This subfield is a Boolean variable specifying if the object described by the record 2231 participates to the definition of another object. For instance an EF, or a MEF, or an EP, or a MEP can participate to the definition of a ST. Similarly a ST can participate to the definition of a RE which can itself participate to the definition of a RST. This subfield is evaluated according to the following formula, where the Έ set corresponds to the set of objects the type of which follows the type of the object described by the record 2231 , in the hierarchy of RST objects: RO = "YES" if LCM({FRi})teJ, Mod OR = 0; RO = "NO" otherwise.
The above formula allows to dynamically link the object described by the record 2231 with the objects belonging to the -Pset, because any change in the value of one of the factors FRi will be automatically reflected into RO. If the object described by the record 2231 is an EF, or a MEF, or an EP, or a MEP, then the T set corresponds to the set of ST's. If the object described by the record 2231 is a
ST, then the fP set corresponds to the set or RE's. If the object described by the record 2231 is a RE, then the fPset corresponds to the set or RST's. If the object described by the record 2231 is a RST, then the set is empty (the top of the hierarchy being reached), so that the RO subfield defaults to the value "NO". • The "SELECTED CHILDREN" (or SC for short) subfield 2240e. This subfield is a
Boolean variable specifying if the object described by the record 2231 participates to the definition of a selected object. This subfield is evaluated according to the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES"): SC = "YES" if LCM({FRi})te5 Mod OR = 0 #OR# object e$
SC = "NO" otherwise. The above formula allows to dynamically link the object described by the record 2231 with the selected objects (belonging to the s set), because any change in the value of one of the factors FR or in the s set will be automatically reflected into SC.
The other "REFERENCED" attributes 709, 719, 729, 780, 2219, and 2229, as defined within the tables EFT 700, EPT 710, STT 720, RSTEIT 770, RET 2210, and RSTT 2220, are based on the same set of five subfields.
• the "SELECTED" attribute 2242 reflecting whether the associated object has been or not selected by the spreadsheet user within the RST Manager Dialog Box 2300, (with respective values "YES" and "NO"), and also
• the "NATURE" attribute 2241 reflecting whether the object is a (M)EF, or a (M)EP, or a ST, or a R(M)E, or a RST (with respective values "FORMAT", or "PROFILE" or "TEMPLATE" or "RECELEMENT" or "RECTEMPLATE" ). Conventional techniques can be used for encoding these different attributes in this "Type" field 2237, such as executing bit-wise XOR operations with predefined bit patterns, but any other conventional means could be used instead without departing from the spirit of the invention. • The "Index" 2238 field is used for sorting the RSTMT table, as performed by the RST Manager method. C9. RST Descriptor Table Referring now to FIG. 17D, the flSTDTTable 2250 corresponds to a logical simple structure made of several names of RE's or RME's 2254. This structure is organized into three sub-sets:
• The optional RST "Headei" part 2256, made of a variable number (possibly null) of RME names like the top name 2251.
° The mandatory "Body" part 2252 made of a single RE name.
° The optional RST "Footer" part 2255, made of a variable number (possibly null) of RME names like the bottom name 2253. C10. RSTI Table Referring now to FIG. 17E, the RSTIT Table 2260 corresponds to a logical simple structure made of several records 2261 , each of them corresponding to a RSTI, according to the preferred embodiment of the present invention. Each record includes six fields:
• The "Address" 2262 field is used for locating the RSTI described by the current record 2261 : its value corresponds to the conventional character string used to record the address of any range of cells.
• The "ST" 2263 field is used for recording the name of the RST abided by the RSTI described by the current record 2261.
• The "Element #" 2264 field is used for recording the number of RE's within the RSTI described by the current record 2261. • The "Critical" 2265 field is used for recording if the RSTI described by the current record 2261 is considered as critical. Its content can take the values "YES" or "NO".
• The "Header Size" 2266 field is used for recording the number of RME's constituting the Header part of the RSTI described by the current record 2261.
• The "Footer Size" 2267 field is used for recording the number of RME's constituting the Footer part of the RSTI described by the current record 2261.
C11. RSTI Descriptor Table
Referring now to FIG. 17F, the RSTIDT Table 2270 corresponds to a logical simple structure made of several records 2271 , each of them made of several cells 2272, each of them corresponding to a STI member of the RSTI, according to the preferred embodiment of the present invention. The RSTIT table 2270 is mapped to the structure of the associated RSTI with a top header part 2275 (possibly empty) constituted by one or several records 2271, with a middle body part 2274 constituted by one or several records 2271, and with a bottom footer part 2273 (possibly empty) constituted by one or several records 2271. Each record 2271 comprises one or a plurality of individual cells 2272, the number of which corresponding to the number of STI's per RE. Each record 2272 includes seven fields characterizing a STI member of the RSTI:
• The "container_range" 2276 field is used for recording the address of the container range hosting the STI described by the record 2272. By referring to the FIG 15A, this field records the address of the container 2014 (intersection of the container row 2012 and of the container column 2005) if the record 2272 describes the STI 2013.
• The "container_col" 2277 field is used for recording the number of columns of the container range hosting the STI described by the record 2272. By referring to the FIG 15A, this field records the column number 2028 if the record 2272 describes the STI 2013. • The "STI_col" 2278 field is used for recording the number of columns of the STI described by the record 2272. By referring to the FIG 15A, this field records the column number 2026 if the record 2272 describes the STI 2013.
• The "STl_row" 2279 field is used for recording the number of rows of the STI described by the record 2272. By referring to the FIG 15A, this field records the row number 2027 if the record 2272 describes the STI 2013.
The "ST_name" 2280 field is used to record the name of the ST abided by the STI described by the record 2272. • The "container row' '2281 field is used for recording the number of rows of the container range hosting the STI described by the record 2272. By referring to the FIG 15A, this field records the row number 2029 if the record 2272 describes the STI 2013.
• The "STIT_rec_ptr" 2282 field is used for pointing, within the STIT table 750, to the record 751 describing the STI described by the record 2272.
C12. Relationships Between Tables
Referring now to FIG. 7F, some previously introduced tables RSTIT 2260, RSTIDT 2270, RSTT 2220, RSTDT 2250, RET 2210, STIT 750, STT 720, STDT 760, EFT 700 and EPT 710 are presented altogether to illustrate the relationships established between these tables and with either a RSTI RSTI 730 or a STI STI 797. Within this diagram, a solid bold arrow illustrates a pointer based relationship towards a table or a record, a dashed bold arrow illustrates an address based relationship towards a range of cells, a solid unbold arrow illustrates a name based relationship towards an object, and a dashed unbold arrow illustrates a size based relationship towards an object. In the FIG 7F, the pointer based, address based and named relationships are identified by an index represented within a circle, according to the following sequence:
• Starting with a STI STI 797 made of the three parts "STI Header", "STI Bod and "STI Foote , a first address based relationship Φ is established between this STI STI 797 and a record 751 of the STIT table 750. • A second name based relationship © is then established between this record 751 and a record 721 of the STT table 720. This record 721 corresponds to the ST abided by the STI 797.
• A third pointer based relationship ® is established between this record 721 and a STDT table 760 which describes the structure of the ST. Each record of the STDT table 760 corresponds to a pair of an element or MEF name and of an element or MEP name.
• A fourth name based relationship © is established between the element or MEF name and a record 701 of the EFT table 700.
• A fifth name based relationship © is established between the element or MEP name and a record 711 of the EPT table 710. • A sixth pointer based relationship © is established between the record 701 and an illustrative range of cells 798 specifying the format attributes.
• A seventh pointer based relationship © is established between the record 711 and an illustrative range of cells 799 specifying the profile content.
• Starting now with a RSTI 730 made of the three parts "RSTI Header", "RSTI Bodf and "RSTI Footer", an eighth address based relationship © is established between this RSTI
730 and a record 2261 of the RSTIT table 2260.
• A ninth pointer based relationship © is established between this record 2261 and a RSTIDT table 2270 which describes the structure of the RSTI 730. Each cell 2272 of the RSTIDT table 2270 comprise several fields 2276, 2277, 2278, 2279, 2280, 2281 and 2282 related to a given STI (like STI 797) member of the RSTI 730.
• A tenth address based relationship ® is thus established between the 2276 field of the cell 2272 of the RSTIDT table 2270, and the container range comprising the STI STI 797.
• An eleventh pointer based relationship ®® is also established between the 2282 field of the cell 2272 of the RSTIDT table 2270, and the record 751 of the STIT table 750 corresponding to the STI STI 797. β A twelfth name based relationship ®© is then established between the record 2261 and a record 2221 of the RSTT table 2220. This record 2221 corresponds to the RST abided by the RSTI 730. ° A thirteenth pointer based relationship ®® is established between this record 2221 and a RSTDT table 2250 which describes the structure of the RST. Each record of the RSTDT table 2250 corresponds to a RE or RME. • A fourteenth name based relationship ®@ is established between the RE or RME name and a record 2211 of the RET table 2210.
• A fifteenth pointer based relationship Φ® is established between the record 2211 and a RE descriptor range of cells 731 containing the names of ST's. • A sixteenth name based relationship Φ® is established between the RE descriptor range of cells 731 and a record 721 of the STT table 720. ° A similar seventeenth name based relationship ®® is established between the cell 2272 of the RSTIDT table 2270 and a record 721 of the STT table 720. D. Scenarios In contrast to just-described conventional tools, the preferred embodiment of the present invention provides a more powerful, user-friendly and interactive approach for defining and managing ST's, in a form of a collection of methods.
In a preferred embodiment, the present invention is used within a scenario which articulates as a sequence of operations : * 1. First Operation : Creation of a STI or of a RSTI
The first operation occurs when the spreadsheet user decides, based on some criteria not detailed here, to either create a STI abiding by the structure of a ST or to create a
RSTI abiding by the structure of a RST. In a preferred embodiment of the present invention, this operation comprises the following steps: • a. RST Manager : The spreadsheet user invokes first an original specific command called "RST Manager" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to visualize through a dedicated user interface any existing EF or MEF or EP or MEP or RE or RME or ST or RST. This RST manager offers different alternatives for further managing these entities. This can be illustrated with the user interface described with the FIG 2, showing the RST Manager Dialog Box 200, as displayed on the display device 106. Within this RST Manager Dialog Box 200, the user can visualize already defined objects (EF's, MEF's, EP's, MEP's, RE's, RME's, ST's and
RST's) in the "list boxes" 213, 214 and 202 where are respectively specified the names of the objects, the types of the objects and their last date of update. If a large number of objects have been defined, then the user can navigate among them by clicking with the pointing device 105 either upwards on downwards on the scroll bar
203, so that the objects shown within the list boxes 213, 214 and 202 move back and forth between the top object and the bottom object. In a preferred embodiment of the present invention, the objects have been sorted by date of last update, but any other sorting scheme could be also used without departing from the spirit of the invention.
Several actions may then be taken by the user. The user can use the pointing device
105 to click on a check box on the left side of the RST Manager Dialog Box 200 like the check box 212, in order to either select or deselect the object whose name is displayed within the list box 213 just on the right of the clicked check box. One or multiple objects can be selected or deselected. List scrolling is of course reflected on the check boxes. Once a selection is performed, the user can use the pointing device 105 to click on the "Delete" push-button 207, if he/she intends to remove all the selected objects from the list boxes 213, 214 and 202. If there is no other object (either ST or STI or RE or RME or RST or RSTI) referring to at least one of these objects, then they are immediately deleted, so that they do no longer appear on the list boxes 213, 214 and 202. If there is at least one other ST or STI or RE or RME or
RST or RSTI referring to at least one of the selected objects, then a conventional dialog box is displayed on the display device 106 to first alert the user about this situation and second to invite him to either cancel the deletion operation or to confirm it. If the user decision is to cancel the operation, then no action is taken, otherwise the selected objects are immediately deleted, so that they do no longer appear on the list boxes 213, 214 and 202. Alternatively the user can use the pointing device 105 to click on the "Edit' push-button 211 if he/she wants to edit the selected object which is assumed to be unique.
If no object or multiple objects have been previously selected, as shown within the RST Manager Dialog Box 200 by the presence of no or multiple check marks (visible or not) within the check boxes located on the left side, like the check box 212, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention.
If a single object was previously selected, as shown by the presence of a single check mark (visible or not) within a check box located on the left side, like the check box 212, then the RST Manager Dialog Box 200 is first closed and afterwards the nature of this single selected object is taken into account to determine the new dialog box to be opened. β If the selected object was an EF or a MEF, then the EF Editor command is issued, so that the EF Editor method takes control by first displaying on the display device 106 the EF Editor Dialog Box 301, as illustrated in FIG 3. The following steps of this scenario case are detailed in a subsequent section. • If the selected object was an EP or a MEP, then the EP Editor command is issued, so that the EP Editor method takes control by first displaying on the display device 106 the EP Editor Dialog Box 401, as illustrated in FIG 4. The following steps of this scenario case are detailed in a subsequent section.
• If the selected object was a RE or a RME, then the RE Editor command is issued, so that the RE Editor method takes control by first displaying on the display device 106 the RE Editor Dialog Box 2321, as shown in FIG 18B. The following steps of this scenario case are detailed in a subsequent section.
• If the selected object was a ST, then the ST Editor command is issued, so that the ST Editor method takes control by first displaying on the display device 106 the ST Editor Dialog Box 501, as illustrated in FIG 5. The following steps of this scenario case are detailed in a subsequent section.
• If the selected object was a RST, then the RST Editor command is issued, so that the RST Editor method takes control by first displaying on the display device 106 the RST Editor Dialog Box 601, as illustrated in FIG 6. The following steps of this scenario case are detailed in a subsequent section.
Alternatively the user can use the pointing device 105 to click on the "Instanciate" push-button 204 if he/she wants to generate either a STI or a RSTI which abides by the selected object which is assumed to be unique and to be respectively a ST or a RST. If no object or multiple objects have been previously selected, as shown within the
RST Manager Dialog Box 200 by the presence of no or multiple check marks (visible or not) within the check boxes located on the left side, like the check box 212, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention.
If a single object was previously selected, as shown by the presence of a single check mark (visible or not) within a check box located on the left side, like the check box 212, then the method checks if this object is a ST or a RST. If it is not the case, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. If a single ST (respectively RST) object was previously selected, then the RST Manager Dialog Box 200 is first closed and afterwards the ST Instanciator (resp. RST Instanciatoή command is issued, so that the ST Instanciator (resp. RST Instanciatoή method takes control by first displaying on the display device 106 the ST Instanciator Dialog Box 1300 (resp. RST Instanciator Dialog Box 2300), as shown in FIG 13A (resp. 18A). The following steps of this scenario case are detailed in subsequent sections.
Alternatively the user can use the pointing device 105 to click on the "Export' push-button 206 if he/she wants to export a non-empty set of objects from the current spreadsheet file to another spreadsheet file. If the check box "Including child objects (for Export)" 220 is filled with a check mark, then all the child objects of the selected objects will also benefit from the export operation, even if these child objects are not selected through the check boxes located on the left side, like the check box 212. If no object has been previously selected, as shown within the RST Manager Dialog
Box 200 by the absence of any check mark (visible or not) within the check boxes located on the left side, like the check box 212, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention.
If one or multiple objects were previously selected, as shown by the presence of at least one check mark (visible or not) within a check box located on the left side, like the check box 212, then the RST Manager Dialog Box 200 is first closed and afterwards a specific RST Export Manager command is issued, so that a dedicated method, not described in the present invention, takes control to handle the export operation.
Alternatively the user can use the pointing device 105 to click on the "Import' push-button 205 if he/she wants to import one or several objects from another spreadsheet file to the current spreadsheet file. The RST Manager Dialog Box 200 is first closed and afterwards a specific RST Import Manager command is issued, so that a dedicated method, not described in the present invention, takes control to handle the import operation.
Alternatively the user can use the pointing device 105 to click on one of the five option-buttons 217 "Format', 209 "Profile", 216 "Template", 218 "RE', 219 "Recursive Template", on the bottom left side of the RST Manager Dialog Box 200, if he/she wants to specify which type of new object may be created afterwards. As five option-buttons are available on the RST Manager Dialog Box 200, the user has the choice to specify either a EF, or a EP or a RE or a ST or a RST as the type of the new object to be created afterwards. Alternatively the user can use the pointing device 105 to click on the check-box 208 entitled "From current selection", if he/she wants to specify if the next object to be created afterwards will be derived or not from the range of cells currently selected in the spreadsheet file. Alternatively the user can use the pointing device 105 to click on the "Create New" push-button 210 if he/she wants to create a new object whose type has been previously specified thanks to the three option-buttons like
• the "Profile" option-button 209, or ° the "Format' option-button 217, or
• the "Template" option-button 216, or • The "RE' option-button 218, or
° The "Recursive Template" option-button 219.
If none of these five option-buttons shows a previous user choice, as shown within the RST Manager Dialog Box 200 by the absence of a point within one of these five option-buttons 209, 216, 217, 218 and 219, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. If one of these five option-buttons 209, 216, 217, 218 and 219 shows a previous user choice, then the RST Manager Dialog Box 200 is first closed and afterwards the single selected option-button is taken into account to determine the new dialog box to be opened. a If the "Format option-button 217 shows a selection, then the EF Editor command is issued, so that the EF Editor method takes control by first displaying on the display device 106 the EF Editor Dialog Box 301, as shown in
FIG 3. The following steps of this scenario case are detailed in a subsequent section.
° If the "Profile" option-button 209 shows a selection, then the EP Editor command is issued, so that the EP Editor method takes control by first displaying on the display device 106 the EP Editor Dialog Box 401, as shown in FIG 4. The following steps of this scenario case are detailed in a subsequent section.
• If the "Templatd' option-button 216 shows a selection, then the ST Editor command is issued, so that the ST Editor method takes control by first displaying on the display device 106 the ST Editor Dialog Box 501, as illustrated in FIG 5. The following steps of this scenario case are detailed in a subsequent section.
• If the "RE' option-button 218 shows a selection, then the RE Editor command is issued, so that the RE Editor method takes control by first displaying on the display device 106 the RE Editor Dialog Box 2321, as illustrated in FIG 18B. The following steps of this scenario case are detailed in a subsequent section.
• If the "Recursive Templatd' option-button 219 shows a selection, then the RST Editor command is issued, so that the RST Editor method takes control by first displaying on the display device 106 the RST Editor Dialog Box 601, as illustrated in FIG 6. The following steps of this scenario case are detailed in a subsequent section.
Finally the user can use the pointing device 105 to click on the "Done" push-button
201 or on the closing-window push-button 215 if he/she wants to quit the RST
Manager method. The resulting effect is to close the RST Manager Dialog Box 200 on the display device 106.
• b. EF Editor : According to the previous scenario illustrating the RST Manager method, the spreadsheet user may then invoke an original specific command called "EF Editor" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new EF; or to create a new MEF; or to update an existing EF; or to update an existing MEF. The corresponding scenario is described in international patent application PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al. • c. EP Editor : According to the previous scenario illustrating the RST Manager method, the spreadsheet user may then invoke an original specific command called "EP Editor" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new EP or to create a new MEP or to update an existing EP or to update an existing MEP. The corresponding scenario is described in international patent application PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al. d. RE Editor : According to the previous scenario illustrating the RST Manager method, the spreadsheet user may then invoke an original specific command called "RE Editor" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new RE or to create a new RME or to update an existing RE or to update an existing RME. This can be illustrated with the user interface described with the FIG 18B, showing the RE Editor Dialog Box 2321, as displayed on the display device 106 within the GUI window of the electronic spreadsheet office application. When the RE Editor Dialog Box 2321 is displayed on the display device 106, it contains some pieces of information.
First the nature of the edited object is shown by a pair of option-buttons 2330 and 2331 which specifies if it is either a RE or a RME. The spreadsheet user can click with the pointing device 105 on one of these two option-buttons 2330 and 2331 to swap between a RE definition and a RME definition.
Second the number of fields within the edited object is specified in the text-box 2326. When a new RE or RME is created (the spreadsheet user having previously clicked with the pointing device 105 on the option-button 218 to put a point on it and on the push-button 210, all contained within the RST Manager Dialog Box 200, as illustrated by FIG 2), the value shown by the text box 2326 corresponds to a default value set to 3 in a preferred embodiment of the present invention. When an existing RE or RME is edited, the value shown by the text box 2326 corresponds to the number of fields previously defined for this object. In all cases, the spreadsheet user can change the value shown in the text box 2326 by clicking with the pointing device 105 on the spin-button 2327, either on the ascending or on the descending side, so that the value can get increased or decreased (within predefined boundaries). Third the name of the edited RE or RME is displayed on the label box 2324. When an existing RE or RME is edited, the name shown by the label box 2324 corresponds to the name previously assigned to this object. When a new RE or RME is created, then the name displayed on the label box 2324 corresponds to a default value which, in a preferred embodiment of the present invention, takes the form "New XX" where XX is a counter ensuring the uniqueness of the assigned name. Fourth the ST's constituting the edited RE or RME are jointly specified by the text boxes 2335 and 2334. The text box 2335 specifies a field rank, which by convention takes the value 1 for the leftmost field of the edited RE or RME, and takes the same value as the one displayed in the text box 2326 for the rightmost field of the edited RE or RME. The text box 2334 specifies the name of the ST for the field whose rank is specified by the text box 2335. The RE Editor Dialog Box 2321 contains several graphical objects which allow the spreadsheet user to take some actions.
First the spreadsheet user can assign a new name to the currently edited RE or RME. For this purpose he/she will first use conventional means such as the keyboard 104 to specify within the text box 2325 the new name to be given to the edited RE or RME. Then he/she will use the pointing device 105 to click on the "Save As" push-button 2332. If the specified name entered within the text box 2325 was already assigned to an existing object or was not a valid name, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. This warning message informs the spreadsheet user about this situation and then prompts him for acknowledgment. Then the text box 2325 is cleared without further action. If the specified name entered within the text box 2325 was not yet assigned to an existing object and was a valid name, then the text box 2325 is cleared and the edited object is saved on the spreadsheet file under the new name which is in turn displayed within the label box 2324.
Second the spreadsheet user can save on the spreadsheet file the current definition of the edited object by clicking with the pointing device 105 on the "Save" push-button 2333. This event results in checking if the updated RE or RME is already referenced by an existing RST. If it is not the case, then the updated definition of the RE or RME is saved on the spreadsheet file. If it is the case, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. This warning message informs the spreadsheet user about this situation and then prompts him for either canceling the operation or for pursuing it. In the first case the updated RE or RME definition is not saved while it is saved on the spreadsheet file in the second case. Third the spreadsheet user can change the definition of the ST's constituting the edited RE or RME. For this purpose he/she will first navigate within the fields of the edited object by clicking with the pointing device 105 on the spin-button 2329 to either decrement or increment the rank of the field, as displayed in the text box 2335, and whose ST name is displayed in the text box 2334. The value taken by the field rank is kept within an interval lower bounded by the value 1 (one) and upper bounded by the value of the text box 2326. Then the spreadsheet user can update the name of the ST for the field whose rank is displayed in the text box 2335 by clicking with the pointing device 105 on the spin-button 2328 to select an available ST name. Finally the user can use the pointing device 105 to click on the "Dond' push-button
2323 or on the closing-window push-button 2322 if he/she wants to quit the RE Editor method. The resulting effect is to close the RE Editor Dialog Box 2321 on the display device 106.
• e. ST Editor : According to the previous scenario illustrating the RST Manager method, the spreadsheet user may then invoke an original specific command called
"ST Editor" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new ST or to update an existing ST. The corresponding scenario is described in international patent application PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al.
• f. RST Editor : According to the previous scenario illustrating the RST Manager method, the spreadsheet user may then invoke an original specific command called "RST Editor" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to either create a new RST or to update an existing RST. This can be illustrated with the user interface described with the FIG 6, showing the RST Editor Dialog Box 601, as displayed on the display device 106 within the GUI window 611 of the electronic spreadsheet office application. When the RST Editor Dialog Box 601 is displayed on the display device 106, the current sheet becomes a dedicated sheet entitled "Editor Spaed' 615 in a preferred embodiment of the present invention. Within the "Editor Spaed' 615 sheet, the RST to be edited appears as a range of cells 614 in the top left angle, with the top left cell at address B2. Although the edited RST corresponds to a regular range of cells 614 within a sheet, conventional tools available in electronic spreadsheet environments cannot be used to update this range of cells 614. The spreadsheet user will only be able to navigate within the range of cells 614 illustrating the RST, and to either insert or delete rows within the range of cells 614 illustrating the RST, by using dedicated means which are part of the RST Editor Dialog Box 601. Row insertion or deletion in the "Editor Spaed' sheet 615 will be disabled. Moreover the "Editor Spaed' sheet 615 is write-protected to prevent the user to inadvertently modify the settings of the RE's or RME's defined as part of the RST illustrated by the range of cells 614.
When the RST Editor Dialog Box 601 is displayed on the display device 106, it contains some pieces of information which either relate to the whole RST, as illustrated by the range of cells 61 , or which relate to the RE or RME pointed by the cell currently selected within this same range of cells 61 . First the RE or RME pointed by the cell currently selected is shown by the "RE' combo box 610. By clicking with the pointing device 105 on the arrow located on the right side of this "RE' combo box 610, the spreadsheet user can display and navigate within the list of defined RE's and RME's, then select a RE or RME of his/her choice and his/her choice appearing on the row where is located the currently selected cell within the range of cells 614. If the spreadsheet user changes the selected row within the range of cells 614, by clicking with the pointing device 105 on the "Up" push-button 619, or on the "Dowrt' push-button 616, then the name displayed within the combo box 610 is updated to specify the name of the RE or RME corresponding to the new selected row. If the spreadsheet user wishes to insert a new RME either in the header or in the footer part of the RST, he/she has just to click with the pointing device 105 on the "Add' push-button 617 to insert a new row within the range of cells 614, at the desired place above the last position of the currently selected cell. Then the range of cells 614 is updated with a new row being displayed on the window 611. Then the RST Editor Dialog Box 601 is updated by showing within the combo boxes 610 the name assigned by default to the introduced
RME. If the spreadsheet user wishes to remove a RME either from the header part or from the footer part of the RST, he/she has just to click with the pointing device 105 on the "Delete" push-button 618 to remove the corresponding row within the range of cells 614, at the desired place. Then the currently selected cell within the range of cells 614 becomes the one belonging to the row representing the unique
RE defined within the RST, and the RST Editor Dialog Box 601 is updated by showing within the combo box 610 the name of the unique RE defined within the RST. Second the minimum number of RE's allowed within a RSTI abiding by the edited RST is specified in the "MIN' text-box 606. Similarly the maximum number of RE's allowed within a RSTI abiding by the edited RST is specified in the "MAX' text-box 609. When a new RST is created (the spreadsheet user having previously clicked with the pointing device 105 on the option-button 219 to put a point on it and on the push-button 210, all contained within the RST Manager Dialog Box 200, as illustrated by FIG 2), the value shown by the "MIN' text box 606 corresponds to a default value set to 1 in a preferred embodiment of the present invention, and the value shown by the "MAX' text box 609 corresponds to a default value set to 16 in a preferred embodiment of the present invention. When an existing RST is edited, the values shown by the text boxes 606 and 609 correspond respectively to the minimum and maximum number of RE's allowed in any RSTI abiding by the currently edited RST, as previously defined by the spreadsheet user. In all cases, the spreadsheet user can change the values shown in the text box "MIN' 606 or in the text box "MAX' 609 by clicking with the pointing device 105 respectively on the spin-button 607 or on the spin-button 608, either on the ascending or on the descending side, so that the values can get increased or decreased (within predefined boundaries), while ensuring that the value specified in the "MIN' text box 606 remains less than or equal to the value specified in the "MAX' text box 609. Should any existing RSTI abiding by the updated RST have a number of elements falling outside the new "MIN'-'MAX' interval, then this RSTI will not be impacted by the RST update, but any future addition or removal of RE's will be done according to the new definition of the "MIN'-'MAX' interval.
Third the name of the edited RST is displayed on the label box 604. When an existing RST is edited, the name shown by the label box 604 corresponds to the name previously assigned to this object. When a new RST is created, then the name displayed on the label box 604 corresponds to a default value which, in a preferred embodiment of the present invention, takes the form "New XX" where XX is a counter ensuring the uniqueness of the assigned name. The RST Editor Dialog Box 601 comprises several graphical objects which allow the spreadsheet user to take some actions.
First the spreadsheet user can assign a new name to the currently edited RST, if this RST is currently constituted by RE's and RME's having all the same number of fields. Indeed in this case the "Save As" push-button 612 is enabled, so that any click on it with the pointing device 105 is recognized as a valid event. The spreadsheet user will first use conventional means such as the keyboard 104 to specify within the text box 605 the new name to be given to the edited RST. Then he/she will use the pointing device 105 to click on the "Save Ad' push-button 612. If the specified name entered within the text box 605 was already assigned to an existing object or is not a valid name, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. This warning message informs the spreadsheet user about this situation and then prompts her/him for acknowledgment. Then the text box 605 is cleared without further action. If the specified name entered within the text box 605 was not yet assigned to an existing object and is a valid name, then the text box 605 is cleared and the edited RST is saved on the spreadsheet file under the new name which is in turn displayed within the label box 604. Second the spreadsheet user can save on the spreadsheet file the current definition of the edited RST, if this RST is currently constituted by RE's and RME's having all the same number of fields. Indeed in this case the "Savd' push-button 613 is enabled, so that any click on it with the pointing device 105 is recognized as a valid event. This event results in checking if the updated RST is already referenced by an existing RSTI. If it is not the case, then the updated definition of the RST is saved on the spreadsheet file. If it is the case, then a warning message is displayed on the display device 106 to the user through conventional means such as pop-up windows, status bar messages, or any other similar conventional means which can be used instead without departing from the spirit of the invention. This warning message informs the spreadsheet user about this situation and then prompts him for either canceling the operation or for pursuing it. In the first case the updated RST definition is not saved while it is saved on the spreadsheet file in the second case. Finally the user can use the pointing device 105 to click on the "Done" push-button 603 or on the closing-window push-button 602 if he/she wants to quit the RST Editor method. The resulting effect is to close the RST Editor Dialog Box 601 on the display device 106 and to revert to the sheet which was active when the RST Editor command was first invoked. g. ST Instanciator : According to the previous scenario illustrating the RST
Manager method, the spreadsheet user may then invoke an original specific command called "ST Instanciator" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to create a STI abiding by a selected ST and located according to the currently selected cell. The corresponding scenario is described in international patent application PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al. h. RST Instanciator : According to the previous scenario illustrating the RST Manager method, the spreadsheet user may then invoke an original specific command called "RST instanciator" thanks to conventional means available in spreadsheet environment, such as but not limited to the pointing device 105 or the keyboard 104, in order to create a RSTI abiding by a selected RST and located according to the currently selected cell. This can be illustrated with the user interface described with the FIG 18A, showing the RST Instanciator Dialog Box 2300, as displayed on the display device 106. When the RST Instanciator Dialog Box 2300 is displayed on the display device 106, the current sheet remains still active, so that the spreadsheet user can visualise the data present on it. The RST Instanciator Dialog Box 2300 contains some pieces of information which relate to the instanciation operation.
First the name of the RST that abides by the RSTI to be created, is displayed in a label box 2302.
Second the number of RE's to be present at RSTI creation time is shown in a text box 2311. This number takes a default value equal to the minimum number of RE's, as specified in the definition of the RST that abides by the RSTI to be created. If the spreadsheet user wished to create a RSTI with another number of RE's, then he/she will have to click with the pointing device 105 on the upper or lower side of the spin-button 2303 to either increase or decrease the number of RE's. This number of RE's will vary within a range delimited by the minimum and maximum number of RE's, as specified within the definition of the RST (fields "Min Element #" 2225 and
"Max Element #' 2226 within a record 2221 of the RSTT table 2220 whose "Name" field 2222 matches the name displayed in the label box 2302) and is displayed, after possible update, in the text box 2311. Third the push-button "Cancel' 2308 or the closing-window push-button 2301 allow to close the RST Instanciation Dialog Box 2300 without further action. By clicking with the pointing device 105 on one of these two push-buttons 2301 and 2308, the RST Instanciation Dialog Box 2300 is closed and the RST instanciation operation is aborted. Fourth the push-button "Create Instancd' 2310, when first enabled and second clicked with the pointing device 105 by the spreadsheet user, is the trigger launching the operation of RST instanciation. This push-button "Create Instancd' 2310 is enabled (meaning that the method recognises the click event with the pointing device 105 on this push-button "Create Instancd' 2310) when the instanciation operation is possible. The fact that this RST instanciation is possible or not depends on different factors: the position of the currently selected cell within the current sheet of the electronic spreadsheet, the size of the RSTI to be created, the presence of any existing STI belonging to the same sheet as the currently selected cell. The possibility to create or not a new RSTI with the size specified in the text box 2303, abiding by a RST whose name is specified by the label box 2302, with the top left corner located on the currently selected cell, is reflected by several label boxes, taking the values "YES" or "NO", which are part of the RST Instanciation Dialog Box 2300: the label box 2304 which reflects if the new RSTI is or not too wide, the label box 2305 which reflects if the new RSTI is or not too high, the label box 2306 which reflects if any existing STI is already defined on the sheet comprising the currently selected cell, and the label box 2307 which reflects if the creation of the new RSTI may lead to loose any existing data present in one or several spreadsheet cells. As soon as the value "YES" is taken by the label box 2304, or by the label box 2305, or by the label box 2306, then the RSTI creation is considered as impossible, so that the "Create Instancd' push-button 2310 get disabled. If the value "NO" is displayed in these three label boxes, then the instanciation operation is possible, so that the "Create Instance" push-button 2310 get enabled. When clicked with the pointing device 105 by the spreadsheet user, the instanciation operation is performed, and then the RST Instanciation Dialog Box 2300 is closed.
Fifth the push-button "Create instance in a new sheet' 2309, when first enabled and second clicked with the pointing device 105 by the spreadsheet user, is an alternative trigger launching the operation of RST instanciation, but in a sheet which is created as part of this instanciation operation. In a preferred embodiment of the present invention, the new sheet is created after the sheet comprising the currently selected cell. Any other sheet position could be used instead, without departing from the spirit of the current invention. This push-button "Create instance in a new sheet' 2309 is enabled (meaning that the method recognises the click event with the pointing device 105 on this push-button "Create instance in a new sheet' 2309) when the instanciation operation is possible in a new sheet. The fact that this RST instanciation is possible or not in a new sheet depends on the size of the RSTI to be created. The possibility to create or not a new RSTI in a new sheet with the size specified in the text box 2303, abiding by a RST whose name is specified by the label box 2302, is reflected by several label boxes, taking the values "YES" or "NO", which are part of the RST Instanciation Dialog Box 2300: the label box 2304 which reflects if the new RSTI is or not too wide, and the label box 2305 which reflects if the new RSTI is or not too high. As soon as the value "YES" is taken by the label box 2304, or by the label box 2305, then the RSTI creation is considered as impossible in a new sheet, so that the "Create instance in a new sheet' push-button 2309 get disabled. If the value "NO" is displayed in these two label boxes, then the instanciation operation is possible in a new sheet, so that the "Create instance in a new sheet' push-button 2309 get enabled. When clicked with the pointing device 105 by the spreadsheet user, the instanciation operation is performed in a new sheet, and then the RST Instanciation Dialog Box 2300 is closed. • 2. Second Operation : Introduction of New Elements Within a Defined STI
The second operation occurs when the spreadsheet user decides, based on his or her own criteria not detailed here, to introduce new elements within a defined STI. The corresponding scenario is described in international patent application PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al. • 3. Third Operation : Removal of Elements from a Defined STI
The fourth operation occurs when the spreadsheet user decides, based on his or her own criteria not detailed here, either to remove some elements from a defined STI, or to clear the content of some elements within a defined STI, or to delete a whole defined
STI, or even to delete some spreadsheet cells or columns or rows from the current sheet. The corresponding scenario is described in international patent application
PCT/EP 02/09483 (IBM's reference FR9 2001 0029) entitled "System and method in an electronic spreadsheet for exporting-importing the content of input cells from a scalable template instance to another" by Aureglia et al.
E.METHODS
E1. RST Manager method
The method for managing EF's, MEF's, EP's, MEP's, ST's, RE's and RST's used in the preferred embodiment of the present invention is summarized in flowchart 800 of FIG 8. This method can be seen as the processing of the RST Manager command.
° At step 801 , the method is in its default state, waiting for an event to initiate the process. • At step 802, the RST Manager command is detected, as a result of a user action. This action can be for instance:
• a specific combination of key on the keyboard 104, or
• the click of the pointing device 105 on a specific button, or • any other similar means not further specified here.
° At step 803, some local variables are initialized:
° the local variable RSTM_seleci is set to the value 0 (zero), ° the local variable RSTM_new is set to the value "NONE", ° the local variable RSTM_range is set to the value "NO", and ° the local variable RSTMJndex is set to the value 1 (one), and 9 The local variable RSTM_child is set to the value "NO".
• At step 804, the five tables EFT 700, EPT 710, STT 720, RET 2210 and RSTT 2220 are parsed to derive the table RSTMT 2230. For each respective record 701 , or 711, or 721, or 2211 , or 2221 found in one of these five tables, is created a new record 2231 within the RSTMT table 2230.
Referring now to FIG 7A, 7B, 70, 17A, 17B and 17C, this construction is done by copying in sequence all the fields defined in the record 701 ("Name" field 702, "Last Change Date" field 703, "Description Ptf field 704, "Row #" field 705, "Column #" field 706 and "Type" field 707), or in the record 711 ("Namd' field 712, "Last Change Date9 field 713, "Description Ptf field 714, "Row #" field 715, "Column #" field 716 and 'Type" field 717), or in the record 721 ("Namd' field 722, "Last Change Date" field 723, "Description Ptf' field 724, "Min Element #" field 725, "Max Element #" field 726 and "Type" field 727), or in the record 2211 ("Namd' field 2212, "Last Change Date" field 2213, "Description Ptf' field 2214, "Row #" field 2215, "Column #" field 2216 and "Typd' field 2217), or in the record 2221 ("Namd' field 2222, "Lasr Change Date" field 2223, "Description Ptf field 2224, "Min Element #" field 2225, "Max Element #" field 2226 and "Type" field 2227) onto the corresponding fields of the record 2231 ("Name" field 2232, "Last Change Datd' field 2233, "Description Ptf field 2234, "Info Field 1" field 2235, "Info Field 2' field 2236 and "Type" field 2237), then by initialising in the 'Type" field 2237 the "SELECTED" attribute 2242 to "NO" and the "NATURE" attribute 2241 to the values "FORMAT", or "PROFILE" or "TEMPLATE" or "RECELEMENT" or "RECTEMPLATE" if the record 2231 has been respectively copied from a record 701 , or 711 , or 721 , or 2211 , or 2221 and then by initializing the last field "Index"' 2238 with the value of a counter which increments for each new record and which starts with the value 1 (one). • At step 805, the RST Manager Dialog Box 200 is displayed on the display device 106.
• The "Name" information appearing on the top of the list box 213 corresponds to the "Name" field 2232 of the record 2231 in the RSTMT table 2230 whose "Index" field 2238 is equal to the local variable RSTMJndex. Underneath "Name" information's within this list box 213 correspond to the "Namd' field 2232 of the following records 2231 of the RSTMT table 2230.
• The "Type" information appearing on the top of the list box 214 is derived from the "Type" field 2237 (attributes "NATURE" 2241 and "META" 2239) of the record 2231 in the RSTMT table 2230 whose "Index" field 2238 is equal to the local variable RSTMJndex. Underneath "Type" information's within this list box 213 are derived from the "Type" field 2237 (attributes "NATURE" 2241 and "META" 2239) of the following records 2231 of the RSTMT table 2230. G The "Modified" information appearing on the top of the list box 202 corresponds to the "Last Change Date" field 2233 of the record 2231 in the RSTMT table 2230 whose "Index"' field 2238 is equal to the local variable RSTMJndex. Underneath "Modified" information's within this list box 213 correspond to the "Last Change Datd' field 2233 of the following records 2231 of the RSTMT table 2230.
• The check box 212 is filled with a check mark if the 'Type" field 2237 of the record 2231 in the RSTMT table 2230 whose "Index"' field 2238 is equal to the local variable RSTMJndex has the "SELECTED" attribute 2242 equal to "YES". Underneath check boxes on the left of the list box 213 are also derived from the 'Type" field 2237
("SELECTED" attribute 2242) of the following records 2231 of the RSTMT table 2230.
• The option button "Format" 217 displays a black point if and only if the local variable RSTM_new is equal to "FORMAT". The option button "Profile" 209 displays a black point if and only if the local variable RSTM_new is equal to "PROFILE". The option button "Template" 216 displays a black point if and only if the local variable
RSTM_new \s equal to "TEMPLATE". The option button "RE" 218 displays a black point if and only if the local variable RSTM_new is equal to "RECELEMENT". The option button "Recursive Template" 219 displays a black point if and only if the local variable
RSTM_new is equal to "RECTEMPLATE".
° The check box "From current selection" 208 displays a check mark if and only if the local variable RSTM_range is equal to "YES". ° The check box "Including child objects (for Export)" 220 displays a check mark if and only if the local variable RSTM_child is equal to "YES".
8 At step 806, the method is waiting for any user action on the RST Manager Dialog Box 200. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here. • At step 807, a user action on the RST Manager Dialog Box 200 is detected.
If the user action is a click on the push-button "Delete" 207, then control is given to step 808; if the user action is a click on the push-button "Import" 205, then control is given to step 810; • if the user action is a click on the push-button "Done" 201 or on the closing-window push-button 215, then control is given to step 834; if the user action is a click on the push-button "Export" 206, then control is given to step 811 ; if the user action is a click on the scrolling bar 203, either on the up direction or on the down direction, then control is given to step 814; if the user action is a click on the option buttons "Format" 217, or "Profile" 209, or "Template" 216, or "RE" 218, or "Recursive Template" 219, then control is given to step 815; if the user action is a click on the check box "From current selectiorf' 208, then control is given to step 816; if the user action is a click on the check box "Including child objects (for Export]' 220, then control is given to step 841 ; if the user action is a click on a top check box like the check box 212, then control is given to step 817; • if the user action is a click on the push-button "Instanciate" 204, then control is given to step 830; if the user action is a click on the push-button "Edit" 211 , then control is given to step 824 and; if the user action is a click on the push-button "Create New" 210, then control is given to step 818.
8 At step 808, a test is performed on each of the records 2231 of the RSTMT table 2230 whose "Type" field 2237 has the "SELECTED" attribute 2242 with the subfield "REFERENCED OBJECT" (RO) 2240d equal to "YES" or with the subfield "INSTANCE REFERENCE" (IR) 2240C larger than 1 (one) (this test determines if there exist some objects referring to one of the selected objects, or if there exist some instance abiding by one of the selected objects). • If it is the case, then control is given to step 835 (meaning that at least one record 2231 of the RSTMT table 2230 previously selected was referenced by a ST, or by a STI, or by a RE, or by a RST, or by a RSTI);
• otherwise control is given to step 809. β At step 809, each respective record 701 , 711 , 721 , 2211 and 2221 is removed from the EFT table 700, EPT table 710, STT table 720, RET table 2210, and RSTT table 2220, if the corresponding respective "Namd' field 702, 712, 722, 2212, and 2222 matches the "Namd' field 2232 of a record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", as resulting from the step 817. Then the local variable RSTM_select is reset to the value 0 (zero). Then control is given to the step 804 for rebuilding the RSTMT table 2230. a At step 810, the RST Import Manager command is issued and then control is given to step 834. ° At step 311 , a test is performed to determine if the local variable RSTM_select is equal to 0 (zero).
• If it is the case, then control is given to step 813;
• otherwise control is given to step 812.
• At step 812, the RST Export Manager command is issued and then control is given to step 834. • At step 813, a warning message notification is issued for informing the user that at least one object must be selected prior clicking on the "Export" push-button 206. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 805.
• At step 814, the local variable RSTMJndex is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the scrolling bar 203, and as long as it value remains positive and less than or equal to the number of records 2231 defined within the RSTMT table 2230. Then control is given to step 805.
• At step 815, the local variable RSTM_new is updated to reflect the option button hit by the user with the pointing device 105.
If the user has clicked on the "Format" option button 217, then the local variable RSTM_new takes the value "FORMAT".
If the user has clicked on the "Profile" option button 209, then the local variable RSTM_new takes the value "PROFILE". • If the user has clicked on the "Template" option button 216, then the local variable RSTM_new takes the value "TEMPLATE".
If the user has clicked on the "RE" option button 218, then the local variable RSTM_new takes the value "RECELEMENT".
If the user has clicked on the "Recursive Template" option button 219, then the local variable RSTM_new takes the value "RECTEMPLATE".
Then control is given to step 805. β At step 816, the local variable RSTM_range is updated, so that its value swaps between "YES" and "NO". In addition, a check mark is respectively added within or removed from the check box 206 if it was previously absent or present in this same check box 206. Then control is given to step 805. e At step 817, the method updates the value of the 'Type" field 2237 of the record 2231 within the RSTMT table 2230, whose "Name" field 2232 is found equal to the character string located within the list box 213 immediately on the right of the check box on which the user has just clicked.
If the previous value of this "Type" field 2237 had the "SELECTED" attribute 2242 equal to
"YES", then the value update consists in turning this "SELECTED" attribute 2242 to "NO" ; reversibly if the previous value of the "SELECTED" attribute 2242 was equal to "NO", then the value update consists in turning this "SELECTED" attribute 2242 to "YES".
In the first case the local variable RSTM_select is decremented by 1 , and in the second case the local variable RSTM_seleci is incremented by 1.
Furthermore in the first case the check mark previously present in the check box on which the user has just clicked is removed from this check box and in the second case a check mark is displayed in the check box on which the user has just clicked. Then control is given to step 805. e At step 818, a test is performed to determine if the local variable RSTM_new is equal to
"NONE". If it is the case, then control is given to step 819; otherwise control is given to step 820.
• At step 819, a warning message notification is issued for informing the user that at least one option ("Format" option button 217, or "Profile" option button 209, or "Template" option button 216, or "RE" option button 218, or "Recursive Template" option button 219) must be selected prior clicking on the "Create New" push-button 210. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 805.
• At step 820, a test is performed to determine the value taken by the local variable RSTM_new.
• If found equal to "FORMAT", then control is given to step 821 ; • If found equal to "PROFILE", then control is given to step 822;
• If found equal to "TEMPLATE", then control is given to step 823.
• If found equal to "RECELEMENT", then control is given to step 836.
• If found equal to "RECTEMPLATE", then control is given to step 837.
• At step 821 , the EF Editor command is issued with passing two parameters ("NEW" ; RSTM_range) and then control is given to step 834.
• At step 822, the EP Editor command is issued with passing two parameters ("NEW" ; RSTM_range) and then control is given to step 834.
• At step 823, the ST Editor command is issued with passing one parameter ("NEW") and then control is given to step 834. • At step 824, a test is performed to determine if the local variable RSTM_select is equal to 1 (one). If it is the case, then control is given to step 825; otherwise control is given to step 829.
• At step 825, a test is performed to determine the nature of the selected object, as specified by the "Type" field 2237 "NATURE" attribute 2241 of the corresponding record 2231 of the RSTMT table 2230. β If found equal to "FORMAT", then control is given to step 826; ° if found equal to "PROFILE", then control is given to step 827;
• if found equal to "TEMPLATE", then control is given to step 828.
• if found equal to "RECELEMENT", then control is given to step 838. ° if found equal to "RECTEMPLATE", then control is given to step 839.
• At step 826, the EP Editor command is issued with passing one parameter equal to the "Namd' field 2232 of the unique record 2231 of the RSTMT table 2230 whose "Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", and then control is given to step 834.
• At step 827, the EF Editor command is issued with passing one parameter equal to the "Name" field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", and then control is given to step 834.
° At step 828, the ST Editor command is issued with passing one parameter equal to the
"Name" field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", and then control is given to step 834.
• At step 829, a warning message notification is issued for informing the user that a single object must be selected within the ST Manager Dialog Box (thanks to check boxes like 212) prior clicking on the "Edit" push-button 211 or on the "Instanciate" push-button 204. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 805.
• At step 830, a test is performed to determine if the local variable RSTM_select is equal to 1 (one). If it is the case, then control is given to step 831; otherwise control is given to step 829.
• At step 831 , a test is performed to determine the nature of the selected object, as specified by the "Type" field 2237 "NATURE" attribute 2241 of the corresponding record
2231 of the RSTMT table 2230.
• If found equal to "TEMPLATE", then control is given to step 832;
• If found equal to "RECTEMPLATE", then control is given to step 840;
• otherwise control is given to step 833. • At step 832, the ST Instanciator command is issued with passing one parameter equal to the "Namd' field 2232 of the unique record 2231 of the RSTMT table 2230 whose "Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", and then control is given to step 834.
• At step 833, a warning message notification is issued for informing the user that a single ST object or a single RST object must be selected within the RST Manager Dialog Box
(thanks to check boxes like 212) prior clicking on the "Instanciate" push-button 204. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 805.
• At step 834, the RST Manager Dialog Box 200 is closed so that it disappears from the display device 106 and then control is given back to the initial step 801 for processing any future RST Manager command. ° At step 835, a warning message notification is issued for informing the user that at least one selected object to be deleted is referenced by another object. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Then the user is prompted to either cancel the current "Delete" operation, or to pursue it. This can typically be done by displaying on the display device 106 a prompting message in a pop-up window, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has made his choice through conventional means such as clicking with the pointing device 105 on an "Cancel" or "Continue" push-button present within a prompting message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 805 if the spreadsheet user decision is to cancel the "Delete" operation, or to step 809 if the spreadsheet user decision is to continue the "Delete" operation. ° At step 836, the RE Editor command is issued with passing one parameter ("NEW") and then control is given to step 834. ° At step 837, the RST Editor command is issued with passing one parameter ("NEW") and then control is given to step 834.
• At step 838, the RE Editor command is issued with passing one parameter equal to the "Name" field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", and then control is given to step 834. e At step 839, the RST Editor command is issued with passing one parameter equal to the "Namd' field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", and then control is given to step 834. • At step 840, the RST Instanciator command is issued with passing one parameter equal to the "Name" field 2232 of the unique record 2231 of the RSTMT table 2230 whose 'Type" field 2237 has the "SELECTED" attribute 2242 equal to "YES", and then control is given to step 834.
• At step 841 , the value of the local variable RSTM_child is updated by swapping the values "YES" and "NO". Then control is given to step 805.
E2. EF Editor method
The method for creating or updating EF's or MEF's used in the preferred embodiment of the present invention is summarised in flowchart 900 of FIG 9. This method can be seen as the processing of the EF Editor command. • At step 901 , the method is in its default state, waiting for an event to initiate the process.
• At step 902, the EF Editor command is detected, as a result of an user action. This action can be for instance:
• a specific combination of key on the keyboard 104, or • the click of the pointing device 105 on a specific button, or
• any other similar means not further specified here.
• At step 903, the parameters of the command are retrieved. They correspond to:
• a first mandatory parameter EFEjname which can either take a reserved value "NEW" or another value corresponding to a character string name, as found in the "Name" field 2232 of a record 2231 within the RSTMT table 2230; and
• a second optional parameter EFE_range which can take only two predefined values "YES" and "NO". This second optional parameter must be present when the first mandatory parameter value differs from the "NEW".
These two parameters are recorded as local variables. • At step 904, some local variables are initialized: the local variable EFE_meta is set to the value "NO", the local variable EFEjsize is set to the value 8 (eight). " At step 905, a test is performed to determine the value taken by the local variable
EFEjname. If found equal to "NEW", then control is given to step 909; otherwise control is given to step 906. • At step 906, the EFT table 700 is looked up to locate a record 701 whose "Name" field
702 is found equal to the value taken by the local variable EFEjname. If such a record is found, then control is given to step 908; otherwise control is given to step 907. • At step 907, an exception handler is invoked to treat this "should not occur" condition. Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to step 925. • At step 908,
° the local variable EFE_meta is set to the value "YES" or "NO" according to the value of the "META" attribute 708 within the "Type" field 707 of the record 701 found at step 906, ° the local variable EFEjsize is set to the value found in the "Column #" field 706 of the record 701 found at step 906, and
• the memory location pointed by the "Description Ptf field 704 of the record 701 found at step 906 is copied onto the clipboard.
Then control is given to step 912. ° At step 909, a new name for the newly created EF or MEF is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Namd' fields 702, 712, 722, 2212 and 2222 found in the respective records 701 , 711 , 721, 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured. Then the new name is recorded in the local variable EFEjname. Then memory space is allocated within the main memory 102 to later record the illustrative range of cells for the EF or MEF. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 701 is created in the EFT table 700, and this new record 701 is initialized as follows:
• the "Namd' field 702 is set to the value of the local variable EFEjname ;
• the "Last Change Date" field 703 is set to the system time reference, as known by the central processor 101 ; • the "Description Ptf field 704 is set to the memory location which has just been allocated ;
• the "Row #' field 705 is set to the value 1 (as in the preferred embodiment of the present invention the ST's are managed in a 2D environment; this field would carry the number of defined rows for the created EF or MEF in a 3D environment) ; « the "Column #" field 706 is set to the value of the local variable EFEjsize ; and
• the "Typd' field 707 is set as follows: the attribute "META" 708 is set equal to the value of the local variable EFEjmeta, and the attribute "REFERENCED" 709 is initialized as follows:
• The "OWN REFERENCE" (OR) subfield 709a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or
2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
• The "FILIATION REFERENCE" (FR) subfield 709b is initialized with the value 1 (one).
• The "INSTANCE REFERENCE" (IR) subfield 709c is initialized with the value 1 (one). • The "REFERENCED OBJECT" (RO) subfield 709d is initialized with the following formula, where the fPset corresponds to the set of ST's:
RO = "YES" if LCM({FRi})ieP Mod OR = 0; RO = "NO" otherwise.
• The "SELECTED CHILDREN" (SC) subfield 709e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230):
SC = "YES" if LCM({FRi})te Mod OR = 0 #OR# EFEjname ≡S, SC = "NO" otherwise. Then control is given to step 910.
• At step 910, a test is performed to determine the value taken by the local variable EFEjange. If found equal to "YES", then control is given to step 911 ; otherwise control is given to step 912. β At step 911 , the currently selected range of cells is copied onto the clipboard and the local variable EFEjsize is set equal to the number of columns of the selected range.
° At step 912, the "Editor Space" sheet 315 is made the current sheet and the content of the clipboard is pasted on this blank sheet at a fixed cell address 314 (address B2 in a preferred embodiment of the present invention, as shown on FIG 3), so that the user can visualize on the display device 106 an illustration of the EF or MEF.
• At step 913, the EF Editor Dialog Box 301 is displayed on the display device 106. s The label box 304 is initialized with the value of the local variable EFEjname.
° The top (respectively bottom) option button 310 is filled with a black point if the local variable EFEj eta is found equal to "NO" (respectively "YES"). • The text box 306 is filled with the value of the local variable EFEjsize.
• The push-buttons "Savd' 312 and "Save & Refresh' 308 are enabled if the local variable EFEjsize is found equal to the "Column #" field 706 of the current record 701, or if the attribute "REFERENCED" 709 within the 'Type" field 707 of this same record 701 is found with the subfield "REFERENCED OBJECT" 709d (RO) equal to "NO", SO that any future click with the pointing device 105 on one of these two push-buttons
"Savd' 312 and "Save & Refresh' 308 will be recognized as a valid event.
• The push-buttons "Savd' 312 and "Save & Refresh' 308 are disabled otherwise (local variable EFEjsize is not found equal to the "Column #" field 706 of the current record 701 , and the attribute "REFERENCED" 709 within the "Type" field 707 of this same record 701 is found with the subfield "REFERENCED OBJECT" 709d (RO) equal to
"YES"), SO that any future click with the pointing device 105 on one of these two push-buttons "Savd' 312 and "Save & Refresh' 308 will not be recognized as an event.
• At step 914, the method is waiting for any user action on the EF Editor Dialog Box 301. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
• At step 915, a user action on the EF Editor Dialog Box 301 is detected. If the user action is a click on the push-button "Save & Refresh" 308, then control is given to step 916; if the user action is a click on the push-button "Save" 312, then control is given to step 917; if the user action is a click on the push-button "Save As" 311 , then control is given to step 918; « if the user action is a click on the push-button "Clear" 309, then control is given to step 919; if the user action is a click on the spin button 307, then control is given to step 920; if the user action is a click on one of the two option buttons 310, then control is given to step 921 ; • if the user action is a click on the push-button "Done" 303, or on the closing-window push-button 302, then control is given to step 925. ° At step 916, the EFT table 700 is updated and saved as part of the electronic spreadsheet file by refreshing the record 701 whose "Name" field 702 is equal to the local variable EFEjname. For this purpose, ° the "Last Change Date" field 703 is set to the system time reference, as known by the central processor 101 ;
• the "Column #' field 706 is set to the value of the local variable EFEjsize ; and • the "Type" field 707 is set as follows: the attribute "META" 708 is set equal to the value of the local variable EFEj eta.
In addition the range of cells 314 illustrating on the "Editor Space" sheet 315 the current definition of the EF or MEF is copied onto the memory location pointed by the "Description Ptf field 704. Then control is given to step 922.
° At step 917, the EFT table 700 is updated and saved as part of the electronic spreadsheet file by refreshing the record 701 whose "Namd' field 702 is equal to the local variable EFEjname. For this purpose,
° the "Last Change Datd' field 703 is set to the system time reference, as known by the central processor 101 ;
• the "Column #" field 706 is set to the value of the local variable EFEjsize ; and
° the 'Type" field 707 is set as follows: the attribute "META" 708 is set equal to the value of the local variable EFEjmeta. In addition the range of cells 314 illustrating on the "Editor Space" sheet 315 the current definition of the EF or MEF is copied onto the memory location pointed by the "Description Ptf field 704. Then control is given to step 913.
• At step 918, a test is performed on the value found in the text box 305 to determine if it corresponds to a valid new name. The corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Name" fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 923; otherwise control is given to step 924.
• At step 919, the default attributes currently defined in the spreadsheet environment are applied to the "Editor Space" sheet 315, so that the displayed illustration of the EF or
MEF receives these same default attributes. Then control is given to the step 913.
• At step 920, the local variable EFEjsize is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 307, and as long as it value remains positive and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 913.
• At step 921 , the local variable EFEjmeta is updated, so that its value becomes "YES" (respectively "NO") if the bottom (respectively top) option button 310 has been clicked on. Then control is given to step 913. • At step 922, the ST Refresh Manager command is issued with the following parameters: EFEjname, "FORMAT" and then control is given to step 913.
• At step 923, memory space is allocated within the main memory 102 to later record the illustrative range of cells for the EF or MEF. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 701 is created in the EFT table 700 which is saved as part of the electronic spreadsheet file, and this new record 701 is initialized as follows:
• the "Namd' field 702 is set to the value found in the text box 305 and validated at step 918; this field 702 becoming then the new value of the EFEjname local variable; • the "Last Change Datd' field 703 is set to the system time reference, as known by the central processor 101 ; ° the "Description Ptf field 704 is set to the memory location which has just been allocated ;
• the "Row #' field 705 is set to the value 1 (as in the preferred embodiment of the present invention the ST's are managed in a 2D environment; this field would carry the number of defined rows for the created EF or MEF in a 3D environment) ;
• the "Column #' field 706 is set to the value of the local variable EFEjsize ; and • the 'Type" field 707 is set as follows: the attribute "META" 708 is set equal to the value of the local variable EFEjmeta, and the attribute "REFERENCED" 709 is initialized as follows:
• The "OWN REFERENCE" (OR) subfield 709a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or
2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here. ° The "FILIATION REFERENCE" (FR) subfield 709b is initialized with the value 1 (one). ° The "INSTANCE REFERENCE" (IR) subfield 709c is initialized with the value 1 (one). ° The "REFERENCED OBJECT" (RO) subfield 709d is initialized with the following formula, where the !Pset corresponds to the set of ST's:
RO = "YES" if LCM({FRi})teϊ , Mod OR = 0; RO = "NO" otherwise. ° The "SELECTED CHILDREN" (SC) subfield 709e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230):
SC = "YES" if LCM({FRi})ie5 Mod OR = 0 #OR# EFEjname S, SC = "NO" otherwise. Then control is given to step 913. • At step 924, a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 305 prior to clicking on the "Save As" push-button 311. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 913.
• At step 925, the EF Editor Dialog Box 501 is closed so that it disappears from the display device 106, then the "Editor Space" sheet 515 is removed from the displayed window so that it is replaced by the original sheet present at EF Editor invocation time.
Finally control is given back to the initial step 901 for processing any future EF Editor command. E3. EP Editor method The method for creating or updating EP's or MEP's used in the preferred embodiment of the present invention is summarized in flowchart 1000 of FIG 10. This method can be seen as the processing of the EP Editor command.
• At step 1001 , the method is in its default state, waiting for an event to initiate the process. • At step 1002, the EP Editor command is detected, as a result of an user action. This action can be for instance:
• a specific combination of key on the keyboard 104, or
• the click of the pointing device 105 on a specific button, or
• any other similar means not further specified here. • At step 1003, the parameters of the command are retrieved. They correspond to:
• a first mandatory parameter EFEjname which can either take a reserved value "NEW" or another value corresponding to a character string name, as found in the "Name" field 2232 of a record 2231 within the RSTMT table 2230; and
• a second optional parameter EPEjange which can take only two predefined values "YES" and "NO". This second optional parameter must be present when the first mandatory parameter value differs from the "NEW". These two parameters are recorded as local variables. • At step 1004, some local variables are initialized: the local variable EFEjmeta is set to the value "NO", the local variable EPEjsize is set to the value 8 (eight).
• At step 1005, a test is performed to determine the value taken by the local variable EPEjname. If found equal to "NEW", then control is given to step 1009; otherwise control is given to step 1006.
° At step 1006, the EPT table 710 is looked up to locate a record 711 whose "Namd' field 712 is found equal to the value taken by the local variable EPEjname. If such a record is found, then control is given to step 1008; otherwise control is given to step 1007. ° At step 1007, an exception handler is invoked to treat this "should not occur" condition. Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to step 1025. a At step 1008,
° the local variable EPEj eta is set to the value "YES" or "NO" according to the value of the "META" attribute 718 within the 'Type" field 717 of the record 711 found at step
1006,
• the local variable EPEjsize is set to the value found in the "Column #" field 716 of the record 711 found at step 1006, and
• the memory location pointed by the "Description Ptf field 714 of the record 711 found at step 1006 is copied onto the clipboard and within the local variable
EPEjDesc. Then control is given to step 1012.
• At step 1009, a new name for the newly created EP or MEP is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Namd' fields 702, 712, 722, 2212 and 2222 found in the respective records 701 , 711 , 721 , 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured.
Then the new name is recorded in the local variable EPEjname. Then memory space is allocated within the main memory 102 to later record the illustrative range of cells for the EP or MEP. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 711 is created in the EPT table 710, and this new record 711 is initialized as follows:
• the "Name" field 712 is set to the value of the local variable EPEjname ;
• the "Last Change Datd' field 713 is set to the system time reference, as known by the central processor 101 ;
• the "Description Ptf field 714 is set to the memory location which has just been allocated ;
• the "Row #' field 715 is set to the value 1 (as in the preferred embodiment of the present invention the ST's are managed in a 2D environment; this field would carry the number of defined rows for the created EP or MEP in a 3D environment) ;
• the "Column #" field 716 is set to the value of the local variable EPEjsize ; and • the "Type" field 717 is set as follows: the attribute "META" 718 is set equal to the value of the local variable EPEjmeta, and the attribute "REFERENCED" 719 is initialized as follows:
° The "OWN REFERENCE" (OR) subfield 719a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
• The "FILIATION REFERENCE" (FR) subfield 719b is initialized with the value 1 (one).
• The "INSTANCE REFERENCE" (IR) subfield 719c is initialized with the value 1 (one). • The "REFERENCED OBJECT" (RO) subfield 719d is initialized with the following formula, where the Pset corresponds to the set of ST's:
RO = "YES" if LCM({FRι})(E* Mod OR = 0; RO = "NO" otherwise. ° The "SELECTED CHILDREN" (SC) subfield 719e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230):
SC = "YES" if LCM({FRi})ie Mod OR = 0 #ΌR# EPEjname ≡S, SC = "NO" otherwise. Then control is given to step 1010.
• At step 1010, a test is performed to determine the value taken by the local variable EPEjrange. If found equal to "YES", then control is given to step 1011; otherwise control is given to step 1012.
° At step 1011 , the currently selected range of cells is copied onto the clipboard and the local variable EPEjsize is set equal to the number of columns of the selected range.
• At step 1012, the "Editor Space" sheet 315 is made the current sheet and the content of the clipboard is pasted on this blank sheet at a fixed cell address 314 (address B2 in a preferred embodiment of the present invention, as shown on FIG 3), so that the user can visualize on the display device 106 an illustration of the EP or MEP. • At step 1013, the EP Editor Dialog Box 401 is displayed on the display device 106.
• The label box 404 is initialized with the value of the local variable EPEjname. The top (respectively bottom) option button 410 is filled with a black point if the local variable EPEjmeta is found equal to "NO" (respectively "YES").
• The text box 406 is filled with the value of the local variable EPEjsize. • The push-buttons "Savd' 412 and "Save & Refresh' 408 are enabled if the local variable EPEjsize is found equal to the "Column #" field 716 of the current record 711, or if the attribute "REFERENCED" 719 within the "Type" field 717 of this same record 711 is found with the subfield "REFERENCED OBJECT" 719d (RO) equal to "NO", SO that any future click with the pointing device 105 on one of these two push-buttons "Save" 412 and "Save & Refresh' 408 will be recognized as a valid event.
• The push-buttons "Savd' 412 and "Save & Refresh' 408 are disabled otherwise (local variable EPEjsize is not found equal to the "Column #" field 716 of the current record 711, and the attribute "REFERENCED" 719 within the "Type" field 717 of this same record 711 is found with the subfield "REFERENCED OBJECT" 719d (RO) equal to "YES"), SO that any future click with the pointing device 105 on one of these two push-buttons "Savd' 412 and "Save & Refresh' 408 will not be recognized as an event.
• At step 1014, the method is waiting for any user action on the EP Editor Dialog Box 401. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
• At step 1015, a user action on the EP Editor Dialog Box 401 is detected.
• If the user action is a click on the push-button "Save & Refresh" 408, then control is given to step 1016; • if the user action is a click on the push-button "Save" 412, then control is given to step 1017; ° if the user action is a click on the push-button "Save As" 411 , then control is given to step 1018;
• if the user action is a click on the push-button "Clear" 409, then control is given to step 1019;
• if the user action is a click on the spin button 407, then control is given to step 1020; • if the user action is a click on one of the two option buttons 410, then control is given to step 1021;
• if the user action is a click on the push-button "Done" 403, or on the closing-window push-button 402, then control is given to step 1025. ° At step 1016, the EPT table 710 is updated and saved as part of the electronic spreadsheet file by refreshing the record 711 whose "Name" field 712 is equal to the local variable EPEjname. For this purpose,
° the "Last Change Datd' field 713 is set to the system time reference, as known by the central processor 101 ; ° the "Column #' field 716 is set to the value of the local variable EPEjsize ; and
° the "Type" field 717 is set as follows: the attribute "META" 718 is set equal to the value of the local variable EPEjmeta. In addition the range of cells 414 illustrating on the "Editor Space" sheet 415 the current definition of the EP or MEP is copied onto the memory location pointed by the "Description Ptf field 714. Then control is given to step 1022. β At step 1017, the EPT table 710 is updated and saved as part of the electronic spreadsheet file by refreshing the record 711 whose "Namd' field 712 is equal to the local variable EPEjname. For this purpose,
• the "Last Change Datd' field 713 is set to the system time reference, as known by the central processor 101 ;
• the "Column #" field 716 is set to the value of the local variable EPEjsize ; and
• the "Type" field 717 is set as follows: the attribute "META" 718 is set equal to the value of the local variable EPEjmeta.
In addition the range of cells 414 illustrating on the "Editor Space" sheet 415 the current definition of the EP or MEP is copied onto the memory location pointed by the "Description Ptf field 714.
Then the local variable EPEjdesc is updated with the current EP or MEP description, as recorded in the memory location pointed by the "Description Ptf field 714, and control is given to step 1013. • At step 1018, a test is performed on the value found in the text box 405 to determine if this value corresponds to a valid new name. The corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Name" fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 1023; otherwise control is given to step 1024.
• At step 1019, the default attributes currently defined in the spreadsheet environment are applied to the "Editor Space" sheet 415, so that the displayed illustration of the EP or MEP receives these same default attributes. Then control is given to the step 1013. • At step 1020, the local variable EPEjsize is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 407, and as long as it value remains positive and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 1013. • At step 1021, the local variable EPEjmeta is updated, so that its value becomes "YES"
(respectively "NO") if the bottom (respectively top) option button 410 has been clicked on.
Then control is given to step 1013. s At step 1022, the ST Refresh Manager command is issued with the following parameters'. EPEjname, "PROFILE", and EPEjdesc. Then the local variable EPEjdesc is updated with the current EP or MEP description, as recorded in the memory location pointed by the "Description Ptf field 714 and then control is given to step 1013.
• At step 1023, memory space is allocated within the main memory 102 to later record the illustrative range of cells for the EP or MEP. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 711 is created in the EPT table 710 which is saved as part of the electronic spreadsheet file, and this new record 711 is initialized as follows:
• the "Namd' field 712 is set to the value found in the text box 405 and validated at step 1018; this field 712 becoming then the new value of the EPEjname local variable;
° the "Last Change Date" field 713 is set to the system time reference, as known by the central processor 101 ; ° the "Description Ptf field 714 is set to the memory location which has just been allocated; ° the "Row #' field 715 is set to the value 1 (as in the preferred embodiment of the present invention the ST's are managed in a 2D environment; this field would carry the number of defined rows for the created EP or MEP in a 3D environment); β the "Column #" field 71 is set to the value of the local variable EPEjsize; ° the "Type" field 717 is set as follows: the attribute "META" 718 is set equal to the value of the local variable EPEjmeta, and the attribute "REFERENCED" 719 is initialized as follows:
• The "OWN REFERENCE" (OR) subfield 719a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
• The "FILIATION REFERENCE" (FR) subfield 719b is initialized with the value 1 (one).
• The "INSTANCE REFERENCE" (IR) subfield 719c is initialized with the value 1 (one).
• The "REFERENCED OBJECT" (RO) subfield 719d is initialized with the following formula, where the ϊ'set corresponds to the set of ST's: RO = "YEs" if LCM({FRi})isP Mod OR = 0;
RO = "NO" otherwise.
• The "SELECTED CHILDREN" (SC) subfield 719e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230): SC = "YES" if LCM({FRi})is5 Mod OR = 0 #OR# EPEjname ≡S,
SC = "NO" otherwise. Then control is given to step 1013.
• At step 1024, a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 405 prior to clicking on the "Save As" push-button 411. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 1013.
• At step 1025, the EP Editor Dialog Box 401 is closed so that it disappears from the display device 106, then the "Editor Space" sheet 415 is removed from the display window so that it is replaced by the original sheet present at EP Editor invocation time. Finally control is given back to the initial step 1001 for processing any future EP Editor command. E4. ST Editor method
The method for creating or updating ST's used in the preferred embodiment of the present invention is summarized in flowchart 1100 of FIG 11. This method can be seen as the processing of the ST Editor command.
• At step 1101, the method is in its default state, waiting for an event to initiate the process. • At step 1102, the ST Editor command is detected, as a result of an user action. This action can be for instance:
• a specific combination of key on the keyboard 104, or
• the click of the pointing device 105 on a specific button, or o any other similar means not further specified here.
° At step 1103, the parameter of the command is retrieved. It corresponds to a mandatory parameter STEjname which can either take a reserved value "NEW" or another value corresponding to a character string name, as found in the "Name" field 2232 of a record 2231 within the RSTMT table 2230. This parameter is recorded as a local variable. ° At step 1104, some local variables are initialized: the local variable STEjmin is set to the default value 1 (one), the local variable STEjmax is set to the default value 255. ° At step 1105, a test is performed to determine the value taken by the local variable STEjname. If found equal to "NEW", then control is given to step 1109; otherwise control is given to step 1106. • At step 1106, the STT table 720 is looked up to locate a record 721 whose "Namd' field 722 is found equal to the value taken by the local variable STEjname. If such a record is found, then control is given to step 1108; otherwise control is given to step 1107.
• At step 1107, an exception handler is invoked to treat this "should not occur" condition. Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then. control is given to step 1128.
• At step 1108,
• the local variable STEjmin is set to the value found in the "Min Element #" field 725 of the record 721 found at step 1106, • the local variable STEjmax is set to the value found in the "Max Element #" field 726 of the record 721 found at step 1106.
Then the memory location pointed by the "Description Ptf field 724 of the record 721 found at step 1106 (where is recorded the description of the ST according to the STDT table 760 illustrated in FIG 7D) is copied in a working buffer which in turns follows the same STDT table 760. This structure is then used to build on the clipboard within the main memory 102 a spreadsheet range of cells illustrating the ST definition copied in the working buffer. This construction is achieved by loading in the clipboard within the main memory 102 an ordered sequence of ranges of cells, each of them successively abiding by the EF (column 765) and the EP (column 764) definition corresponding to each pair of EF and EP names, starting with the first pair 761 up to the last one 763. Then control is given to step 1110.
• At step 1109, a new name for the newly created ST is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Name" fields 702, 712, 722, 2212 and 2222 found in the respective records 701, 711, 721, 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured. Then the new name is recorded in the local variable STEjname. Then memory space is allocated within the main memory 102 to later record the illustrative range of cells for the new ST. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file and follows the STDT table 760 illustrated in FIG 7D. Then a new record 721 is created in the STT table 720, and this new record 721 is initialized as follows:
• the "Namd' field 722 is set to the value of the local variable STEjname ;
• the "Last Change Datd' field 723 is set to the system time reference, as known by the central processor 101 ; • the "Description Ptf field 724 is set to the memory location which has just been allocated ;
• the "Min Element #" field 725 is set to the value of the local variable STEjmin;
• the "Max Element #' field 726 is set to the value of the local variable STEjmax ; and β the "Typd' field 727 is set as follows: the attribute "META" 728 is set equal to "NO", and the attribute "REFERENCED" 729 is initialized as follows:
° The "OWN REFERENCE" (OR) subfield 729a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here. β The "FILIATION REFERENCE" (FR) subfield 729b is initialized according to the following formula, where the ψ set corresponds to the set of EF's, MEF's, EP's and MEP's constituting the new ST, according to the structure recorded in the "Description Ptf field 724: FR = π ^ OR, x LGM({FR,}),^ β The "INSTANCE REFERENCE" (IR) subfield 729c is initialized with the value 1 (one).
• The "REFERENCED OBJECT" (RO) subfield 729d is initialized with the following formula, where the fPset corresponds to the set of RE's and RME's:
RO = "YES" if LCM({FR,}),. Mod OR = 0; RO = "NO" otherwise.
• The "SELECTED CHILDREN" (SC) subfield 729e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230):
SC = "YES" if LCM({FR,}),e5 Mod OR = 0 #OR# STEjname e $, SC = "NO" otherwise.
Then a working buffer is allocated in main memory 102 and initialized with a default ST description which corresponds to a single pair 762 of default EF and default EP. This default ST description is then used to build on the clipboard within the main memory 102 a spreadsheet range of cells illustrating the new ST. This construction is achieved as explained at the end of the step 1108. Then control is given to step 1110.
• At step 1110, the "Editor Space" sheet 515 is made the current sheet and this sheet is turned to write-protect mode while regular row insertion and deletion are disabled. Then the top left cell of the range of cells 514 is selected. Then the local variable STEJormat is filled with the name of the EF or of the MEF corresponding to the row where is located the currently selected cell within the range of cells 514. Finally the local variable STEjprofile is filled with the name of the EP or of the MEP corresponding to the row where is located the currently selected cell within the range of cells 514.
• At step 1111, the ST Editor Dialog Box 501 is displayed on the display device 106. The label box 504 is initialized with the value of the local variable STEjname. • The text box 506 is filled with the value of the local variable STEjmin. The text box 509 is filled with the value of the local variable STEjmax. The combo box 511 is filled with the value of the local variable STEJormat. The combo box 510 is filled with the value of the local variable STEjprofile. Then the range of cells 514 is updated according to the description recorded in the memory clipboard: the content of the clipboard is pasted on this blank sheet at a fixed cell address 514 (address B2 in a preferred embodiment of the present invention, as shown on FIG 5), so that the user can visualize on the display device 106, within the window 500 an illustration of the ST. Then a test is performed to check if all the EF's, EP's, MEF's and MEP's contributing to the ST definition illustrated by the range of cells 514, have the same number of fields. If it is the case, then the two push-buttons "Savd' 513 and "Save Ad' 512 are enabled, so that the click with the pointing device 105 on one of these two push-buttons is recognized as a valid event. Otherwise the two push-buttons "Savd' 513 and "Save Ad' 512 are disabled, so that the click with the pointing device 105 on one of these two push-buttons is not recognized as a valid event.
• At step 1112, the method is waiting for any user action on the ST Editor Dialog Box 501. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here. 0 At step 1113, a user action on the ST Editor Dialog Box 501 is detected.
° If the user action is a click on the push-button "Save" 513, then control is given to step 1116; ° if the user action is a click on the push-button "Save As" 512, then control is given to step 1119; ° if the user action is a click on the push-button "Add" 517, then control is given to step
1124; ° if the user action is a click on the push-button "Delete" 518, then control is given to step 1125;
• if the user action is a click on the push-button "Up" 519 or on the push-button "Down" 520, then control is given to step 1126;
• if the user action is an update of the combo box 511 , then control is given to step 1114; • if the user action is an update of the combo box 510, then control is given to step 1115;
• if the user action is a click on the spin button 507, then control is given to step 1122;
• if the user action is a click on the spin button 508, then control is given to step 1123;
• if the user action is a click on the push-button "Done" 503, or on the closing-window push-button 502, then control is given to step 1128.
• At step 1114, the ST description is updated in the working buffer by replacing by the EF or MEF name found in the text box 511 the previous EF or MEF specification corresponding to the element or meta-element illustrated by the currently selected cell within the range of cells 514. Then the local variable STEJormat is also set equal to the name found in the text box 511. Then control is given to step 1111.
• At step 1115, the ST description is updated in the working buffer by replacing by the EP or MEP name found in the text box 510 the previous EP or MEP specification corresponding to the element or meta-element illustrated by the currently selected cell within the range of cells 514. Then the local variable STE_profile is also set equal to the name found in the text box 510. Then control is given to step 1111.
• At step 1116, a test is performed to check if the currently edited ST is already referenced by an existing RE or RME or is already instanciated as a STI. For this purpose is considered the "REFERENCED" attribute 729 within the "Type" field 727 of the record 721 within the STT table 720 whose "Name" field 722 is equal to the local variable STE_name. If the value of the "REFERENCED OBJECT" (RO) subfield 729d is equal to "NO" and if the value of the "INSTANCE REFERENCE" (IR) subfield 729c is equal to 1 (one), then control is given to step 1117; otherwise control is given to step 1118.
• At step 1117, the STT table 720 is updated by refreshing the record 721 whose "Name" field 722 is equal to the local variable STE_name. For this purpose, • the "Last Change Datd' field 723 is set to the system time reference, as known by the central processor 101 ; ° the "Min Element #" field 725 is set to the value of the local variable STE_min;
• the "Max Element #" field 726 is set to the value of the local variable STE_max.
• The current description of the ST, as illustrated by the range of cells 514, as recorded in the working buffer, and following the STDT table 760 is copied onto the memory location pointed by the "Description Ptf field 724.
• The 'Type" field 727 is updated as the "FILIATION REFERENCE" (FR) subfield 729b of the "REFERENCED" attribute 729 is automatically updated thanks to its definition formula depending on the set of EF's, MEF's, EP's and MEP's belonging to the STDT table 760 pointed by the "Description Ptf field 724.
• For each EF name or MEF name found in the column 765 of this STDT table 760, the EFT table 700 is automatically updated within the corresponding records 701 whose "Namd' field 702 matches this element or MEF name, as the subfield
"REFERENCED OBJECT" (RO) 709d (within the "REFERENCED" attribute 709) is recalculated according to its definition formula. ° For each EP name or MEP name found in the column 764 of this STDT table 760, the EPT table 710 is automatically updated within the corresponding records 711 whose "Namd' field 712 matches this element or MEP name, as the subfield
"REFERENCED OBJECT" (RO) 71 d (within the "REFERENCED" attribute 719) is recalculated according to its definition formula. Then control is given to step 1111. ° At step 1118, a warning message notification is issued for informing the user that the edited ST is already referenced by a RE or RME or is already instanciated as an existing STI. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Then the user is prompted to either cancel the current "Save" operation, or to pursue it. This can typically be done by displaying on the display device 106 a prompting message in a pop-up window, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has made his choice through conventional means such as clicking with the pointing device 105 on an "Cancel" or "Continue" push-button present within a prompting message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 1111 if the spreadsheet user decision is to cancel the operation, or to step 1117 if the spreadsheet user decision is to continue the operation. • At step 1119, a test is performed on the value found in the text box 505 to determine if it corresponds to a valid new name. The corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Name" fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 1120; otherwise control is given to step 1121. • At step 1120, memory space is allocated within the main memory 102 to later record the descriptor of the ST. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 721 is created in the STT table 720, and this new record 721 is initialized as follows:
• the "Name" field 722 is set to the value found in the text box 505 and validated at step 1119; this field 722 becoming then the new value of the STE_name local variable;
• the "Last Change Datd' field 723 is set to the system time reference, as known by the central processor 101 ;
• the "Description Ptf field 724 is set to the memory location which has just been allocated ;
• the "Min Element #' field 725 is set to the value of the local variable STE_min;
° the "Max Element #' field 726 is set to the value of the local variable STE_max ;
• the current description of the ST, as illustrated by the range of cells 514, as recorded in the working buffer, and following the STDT table 760 is copied onto the memory location pointed by the "Description Ptf field 724.
• the "Typd' field 727 is set as follows: the attribute "META" 728 is set equal to "NO", and the attribute "REFERENCED" 729 is initialized as follows: • The "OWN REFERENCE" (OR) subfield 729a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here. ° The "FILIATION REFERENCE" (FR) subfield 729b is initialized according to the following formula, where the set corresponds to the set of EF's, MEF's, EP's and MEP's constituting the new ST, according to the structure recorded in the "Description Ptf field 724:
FR = πtey ORi x LCM({FRi} ° The "INSTANCE REFERENCE" (IR) subfield 729c is initialized with the value 1 (one).
• The "REFERENCED OBJECT" (RO) subfield 729d is initialized with the following formula, where the fPset corresponds to the set of RE's and RME's:
RO = "YES" if LCM({FRi})ie* Mod OR = 0; RO = "NO" otherwise. β The "SELECTED CHILDREN" (SC) subfield 729e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230):
SC = "YES" if LCM({FRi})te5 Mod OR = 0 #OR# STE_name S, SC = "NO" otherwise. • For each EF name or MEF name found in the column 765 of this STDT table 760, the EFT table 700 is automatically updated within the corresponding records 701 whose "Name" field 702 matches this element or MEF name, as the subfield "REFERENCED OBJECT" (RO) 709d (within the "REFERENCED" attribute 709) is recalculated according to its definition formula. • For each EP name or MEP name found in the column 764 of this STDT table 760, the EPT table 710 is automatically updated within the corresponding records 711 whose "Namd' field 712 matches this element or MEP name, as the subfield "REFERENCED OBJECT" (RO) 719d (within the "REFERENCED" attribute 719) is recalculated according to its definition formula. Then control is given to step 1111.
• At step 1121, a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 505 prior to clicking on the "Save As" push-button 512. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 1111. • At step 1122, the local variable STE_min is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 507, and as long as its value remains positive and less than or equal to both an upper limit set equal to 254 in a preferred embodiment of the present invention and to the value shown in the text box 509. Then control is given to step 1111. • At step 1123, the local variable STE_max is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 508, and as long as its value remains positive, greater than the value shown in the text box 506 and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 1111. ° At step 1124, a new row is inserted in the range of cells 514 illustrating the edited ST, above the row where the last selected cell was previously located. Then the left most cell located on the new row within the range of cells 514 is selected. Then the ST definition is updated in the working buffer by introducing a new meta-element which is described, like the other ones, by a couple (MEF 765, MEP 764) which defaults to a couple of default MEF and default MEP, which are also respectively assigned to the local variable STEJormat and STEjprofile. In addition the current description of the ST, as illustrated by the range of cells 514, as recorded in the working buffer, and following the STDT table 760 is copied onto the memory location pointed by the "Description Ptf field 724. Then control is given to step 1111. o At step 1125, the row containing the selected cell is removed from the range of cells 514. Then the left most cell located within the range of cells 514 on the row representing the element defined within the edited ST is selected. Then the ST definition is updated by removing the deleted meta-element which was described by a couple (MEF, MEP). In addition the current description of the ST, as illustrated by the range of cells 514, as recorded in the working buffer, and following the STDT table 760 is copied onto the memory location pointed by the "Description Ptf field 724. Then control is given to step 1127. s At step 1126, the current cell within the "Editor Space" sheet 515 is respectively moved up or down if the spreadsheet user has clicked with the pointing device 105 on the "Up" push-button 519, or on the "Down" push-button 520, and also if this movement does not move the current cell away from the range of cells 514 illustrating the ST.
• At step 1127, the local variables STEJormat and STEjprofile are respectively set equal to the name of the EF or MEF and to the name of the EP or MEP corresponding to the element or the meta-element illustrated by the currently selected cell within the range of cells 514. Then control is given to step 1111.
• At step 1128, the ST Editor Dialog Box 501 is closed so that it disappears from the display device 106, then the "Editor Space" sheet 515 is removed from the display window so that it is replaced by the original sheet present at EP Editor invocation time. All the means which were temporarily disabled while the "Editor Space" sheet 515 was displayed are now enabled again. Finally control is given back to the initial step 1101 for processing any future ST Editor command. E5. RST Editor method The method for creating or updating RST's used in the preferred embodiment of the present invention is summarized in flowchart 1230 of FIG 12. This method can be seen as the processing of the RST Editor command.
• At step 1231, the method is in its default state, waiting for an event to initiate the process. • At step 1232, the RST Editor command is detected, as a result of an user action. This action can be for instance:
• a specific combination of key on the keyboard 104, or
• the click of the pointing device 105 on a specific button, or
• any other similar means not further specified here. • At step 1233, the parameter of the command is retrieved. It corresponds to a mandatory parameter RSTEjname which can either take a reserved value "NEW" or another value corresponding to a character string name, as found in the "Namd' field 2232 of a record 2231 within the RSTMT table 2230. This parameter is recorded as a local variable.
• At step 1234, some local variables are initialized: the local variable RSTEjmin is set to the default value 1 (one), the local variable RSTEj ax is set to the default value 16. β At step 1235, a test is performed to determine the value taken by the local variable RSTEjname. If found equal to "NEW", then control is given to step 1239; otherwise control is given to step 1236.
• At step 1236, the RSTT table 2220 is looked up to locate a record 2221 whose "Name" field 2222 is found equal to the value taken by the local variable RSTEjname. If such a record is found, then control is given to step 1238; otherwise control is given to step 1237. • At step 1237, an exception handler is invoked to treat this "should not occur" condition. Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to the initial step 1231 for processing any future RST Editor command. ° At step 1238,
° the local variable RSTEj in is set to the value found in the "Min Element #" field
2225 of the record 2221 found at step 1236,
° the local variable RSTEj ax is set to the value found in the "Max Element #" field
2226 of the record 2221 found at step 1236. Then the memory location pointed by the "Description Ptf field 2224 of the record 2221 found at step 1236 (where is recorded the description of the RST according to the RSTDT table 2250 illustrated in FIG 17D) is copied in a working buffer which in turns follows the same RSTDT table 2250. This structure is then used to build on the clipboard within the main memory 102 a spreadsheet range of cells illustrating the RST definition copied in the working buffer, each cell successively corresponding to RE or RME names, starting with the first name 2251 up to the last one 2253. Then control is given to step 1240.
• At step 1239, a new name for the newly created RST is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Name" fields 702, 712, 722, 2212 and 2222 found in the respective records 701, 711, 721, 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured. Then the new name is recorded in the local variable RSTEjname. Then memory space is allocated within the main memory 102 to later record the illustrative range of cells for the new RST. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file and follows the RSTDT table 2250 illustrated in FIG 17D. Then a new record 2221 is created in the RSTT table 2220, and this new record 2221 is initialized as follows:
• the "Namd' field 2222 is set to the value of the local variable RSTEjname ;
• the "Last Change Datd' field 2223 is set to the system time reference, as known by the central processor 101 ; • the "Description Ptf field 2224 is set to the memory location which has just been allocated ;
• the "Min Element #" field 2225 is set to the value of the local variable RSTEjmin;
• the "Max Element #' field 2226 is set to the value of the local variable RSTEjmax ;
• the "Type" field 2227 is set as follows: the attribute "META" 2228 is set equal to "NO", and the attribute "REFERENCED" 2229 is initialized as follows:
• The "OWN REFERENCE" (OR) subfield 2229a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here. • The "FILIATION REFERENCE" (FR) subfield 2229b is initialized according to the following formula, where the f set corresponds to the set of RE's and RME constituting the new RST, according to the structure recorded in the "Description Ptf field 2224:
FR = I OR, x LCM({FR,})iey ° The "INSTANCE REFERENCE" (IR) subfield 2229c is initialized with the value 1 (one).
• The "REFERENCED OBJECT" (RO) subfield 2229d is initialized with the value "NO". • The "SELECTED CHILDREN" (SC) subfield 2229e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230): SC = "YES" if LCM({FR,}),e5 Mod OR = 0 #OR# RSTEjname e s, SC = "NO" otherwise.
Then a working buffer is allocated in main memory 102 and initialized with a default RST description which corresponds to a RE 2252. This default RST description is then used to build on the clipboard within the main memory 102 a spreadsheet range of cells illustrating the new RST. This construction is achieved as explained at the end of the step 1238. Then control is given to step 1240. e At step 1240, the "Editor Space" sheet 615 is made the current sheet and this sheet is turned to write-protect mode while regular row insertion and deletion are disabled. Then the top left cell of the range of cells 614 is selected. Then the local variable REjname is filled with the name of the RE corresponding to the row where is located the currently selected cell within the range of cells 614.
• At step 1241, the RST Editor Dialog Box 601 is displayed on the display device 106.
• The label box 604 is initialized with the value of the local variable RSTEjname.
• The text box 606 is filled with the value of the local variable RSTEjmin.
• The text box 609 is filled with the value of the local variable RSTEjmax. • The combo box 610 is filled with the value of the local variable REjname.
Then the range of cells 614 is updated according to the description recorded in the memory clipboard: the content of the clipboard is pasted on this blank sheet at a fixed cell address 614 (address B2 in a preferred embodiment of the present invention, as shown on FIG 6), so that the user can visualize on the display device 106, within the window 611 an illustration of the ST. Then a test is performed to check if all the RE's and RME's contributing to the RST definition illustrated by the range of cells 614, have the same number of fields. If it is the case, then the two push-buttons "Savd' 613 and "Save Ad' 612 are enabled, so that the click with the pointing device 105 on one of these two push-buttons is recognized as a valid event. Otherwise the two push-buttons "Save" 613 and "Save Ad' 612 are disabled, so that the click with the pointing device 105 on one of these two push-buttons is not recognized as a valid event.
• At step 1242, the method is waiting for any user action on the RST Editor Dialog Box 601. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
• At step 1243, a user action on the RST Editor Dialog Box 601 is detected. If the user action is a click on the push-button "Save" 613, then control is given to step 1246; if the user action is a click on the push-button "Save As" 612, then control is given to step 1249; if the user action is a click on the push-button "Add" 617, then control is given to step
1254; if the user action is a click on the push-button "Delete" 618, then control is given to step 1255; • if the user action is a click on the push-button "Up" 619 or on the push-button "Down"
616, then control is given to step 1256; ° if the user action is an update of the combo box 610, then control is given to step
1244;
* if the user action is a click on the spin button 607, then control is given to step 1252; ° if the user action is a click on the spin button 608, then control is given to step 1253;
• if the user action is a click on the push-button "Done" 603, or on the closing-window push-button 602, then control is given to step 1258. • At step 1244, the ST description is updated in the working buffer by replacing by the RE or RME name found in the combo box 610 the previous RE or RME name corresponding to the RE or RME illustrated by the currently selected cell within the range of cells 614. Then the local variable REjname is also set equal to the name found in the combo box 610. Then control is given to step 1241.
° At step 1246, a test is performed to check if the currently edited RST is already referenced by an existing RSTI. For this purpose is considered the value of the "REFERENCED" attribute 2229 within the "Type" field 2227 of the record 2221 within the RSTT table 2220 whose "Namd' field 2222 is equal to the local variable RSTEjname. If the value of the "INSTANCE REFERENCE" (IR) subfield 2229c is equal to 1 (one), then control is given to step 1247; otherwise control is given to step 1248. ° At step 1247, the RSTT table 2220 is updated by refreshing the record 2221 whose "Namd' field 2222 is equal to the local variable RSTEjname. For this purpose, ° the "Last Change Date" field 2223 is set to the system time reference, as known by the central processor 101 ;
• the "Min Element #' field 2225 is set to the value of the local variable RSTEjmin;
• the "Max Element #' field 2226 is set to the value of the local variable RSTEjmax.
• The current description of the RST, as illustrated by the range of cells 614, as recorded in the working buffer, and following the RSTDT table 2250 is copied onto the memory location pointed by the "Description Ptf field 2224.
• The "Type" field 2227 is updated as the "FILIATION REFERENCE" (FR) subfield 2229b of the "REFERENCED" attribute 2229 is automatically updated thanks to its definition formula depending on the set of RE's, and RME's belonging to the RSTDT table 2250 pointed by the "Description Ptf field 2224. • For each RE name or RME name found in the column 2254 of this RSTDT table
2250, the RET table 2210 is automatically updated within the corresponding record
2211 whose "Namd' field 2212 matches this RE or RME name, as the subfield
"REFERENCED OBJECT" (RO) 2219d (within the "REFERENCED" attribute 2219) is recalculated according to its definition formula. • At step 1248, a warning message notification is issued for informing the user that the edited RST is already instanciated as a RSTI. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Then the user is prompted to either cancel the current "Save" operation, or to pursue it. This can typically be done by displaying on the display device
106 a prompting message in a pop-up window, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has made his choice through conventional means such as clicking with the pointing device 105 on an "Cancel" or "Continue" push-button present within a prompting message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 1241 if the spreadsheet user decision is to cancel the operation, or to step 1247 if the spreadsheet user decision is to continue the operation.
• At step 1249, a test is performed on the value found in the text box 605 to determine if it corresponds to a valid new name. The corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Namd' fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 1250; otherwise control is given to step 1251. ° At step 1250, memory space is allocated within the main memory 102 to later record the descriptor of the RST. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 2221 is created in the RSTT table 2220, and this new record 2221 is initialized as follows:
• the "Namd' field 2222 is set to the value found in the text box 605 and validated at step 1249; this field 2222 becoming then the new value of the RSTEjname local variable;
° the "Last Change Date" field 2223 is set to the system time reference, as known by the central processor 101 ; ° the "Description Ptf field 2224 is set to the memory location which has just been allocated ; o the "Min Element #" field 2225 is set to the value of the local variable RSTEjmin;
• the "Max Element #' field 2226 is set to the value of the local variable RSTEjmax ; and
• the "Type" field 2227 is set as follows: the attribute "META" 2228 is set equal to "NO", and the attribute "REFERENCED" 2229 is initialized as follows: β The "OWN REFERENCE" (OR) subfield 2229a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
• The "FILIATION REFERENCE" (FR) subfield 2229b is initialized according to the following formula, where the T set corresponds to the set of RE's and RME constituting the new RST, according to the structure recorded in the "Description Ptf field 2224:
FR = ϋieyORi x LCM({FRi})fer
• The "INSTANCE REFERENCE" (IR) subfield 2229c is initialized with the value 1 (one). • The "REFERENCED OBJECT" (RO) subfield 2229d is initialized with the value "NO".
• The "SELECTED CHILDREN" (SC) subfield 2229e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230):
SC = "YES" if
Figure imgf000054_0001
Mod OR = 0 #OR# RSTEjname ≡ S, SC = "NO" otherwise.
• The current description of the RST, as illustrated by the range of cells 614, as recorded in the working buffer, and following the RSTDT table 2250 is copied onto the memory location pointed by the "Description Ptf field 2224.
• For each RE name or RME name found in the column 2254 of this RSTDT table 2250, the RET table 2210 is automatically updated within the corresponding record
2211 whose "Name" field 2212 matches this RE or RME name, as the subfield "REFERENCED OBJECT" (RO) 2229d (within the "REFERENCED" attribute 2219) is recalculated according to its definition formula.
• At step 1251 , a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 605 prior to clicking on the "Save As" push-button 612. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 1241.
• At step 1252, the local variable RSTEjmin is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 607, and as long as its value remains positive and less than or equal to both an upper limit set equal to 254 in a preferred embodiment of the present invention and to the value shown in the text box 609. Then control is given to step 1241. • At step 1253, the local variable RSTEjmax is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 608, and as long as its value remains positive, greater than the value shown in the text box 606 and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 1241. ° At step 1254, a new row is inserted in the range of cells 614 illustrating the edited RST, above the row where the last selected cell was previously located.
Then the left most cell located on the new row within the range of cells 61 is selected.
Then the RST definition is updated in the working buffer by introducing a new RME which is identified, like the other ones, by a name, which is also assigned to the local variable REjname.
In addition the current description of the RST, as illustrated by the range of cells 614, as recorded in the working buffer, and following the RSTDT table 2250 is copied onto the memory location pointed by the "Description Ptf field 2224. Then control is given to step 1241.
• At step 1255, the row containing the selected cell is removed from the range of cells 614, so that the next RE or meta-element gets selected.
Then the RST definition is updated by removing the deleted RME which was identified by its name. In addition the current description of the RST, as illustrated by the range of cells 614, as recorded in the working buffer, and following the RSTDT table 2250 is copied onto the memory location pointed by the "Description Ptf field 2224. Then control is given to step 1257.
• At step 1256, the current cell within the "Editor Space" sheet 615 is respectively moved up or down if the spreadsheet user has clicked with the pointing device 105 on the "Up" push-button 619, or on the "Down" push-button 616, and also if this movement does not move the current cell away from the range of cells 614 illustrating the RST.
• At step 1257, the local variable REjname is set equal to the name of the RE or RME corresponding to either the RE or the RME identified by the currently selected cell within the range of cells 614. Then control is given to step 1241.
• At step 1258, the RST Editor Dialog Box 601 is closed so that it disappears from the display device 106, then the "Editor Space" sheet 615 is removed from the display window so that it is replaced by the original sheet present at RST Editor invocation time. All the means which were temporarily disabled while the "Editor Space" sheet 615 was displayed are now enabled again. Finally control is given back to the initial step 1231 for processing any future RST Editor command.
E6. ST Instanciator method
The method for creating a STI abiding by a defined ST used in the preferred embodiment of the present invention is summarized in flowchart 1400 of FIG 14A and FIG 14B, where the later corresponds to the CreateSTI routine. This method can be seen as the processing of the ST Instanciator command.
• At step 1401, the method is in its default state, waiting for an event to initiate the process.
• At step 1402, the ST Instanciator command is detected, as a result of a user action. This action can be for instance a specific combination of key on the keyboard 104, or the click of the pointing device 105 on a specific button, or any other similar means not further specified here. β At step 1403, a test is performed to check if the currently selected cell is contained within a sheet where a RSTI is present. This test can be done by parsing the RSTIT table 2260 to identify any record 2261 whose Address field 2262 corresponds to the same sheet as the currently selected cell. If it is the case, then control is given to step 1404 ; otherwise control is given to step 1405. • At step 1404, a warning message notification is issued for informing the user that a STI cannot be individually created on a sheet where a RSTI already exists. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 1401. ° At step 1405, the command parameter STjname is first retrieved: it corresponds to the name of the ST that the STI to be created will abide by. This parameter STjname is used to parse the STT table 720 in order to find the record 721 whose "Namd' field 722 matches the parameter STjname. Once this record 721 is found, its fields "Min Element #"725 and "Max Element #" 726 are respectively memorized as local variables STIjmin and STIjmax. Then its field "Description Ptf 724 is used to determine, according to the referenced STDT table 760, the number of meta-elements defined within the ST, and the number of cells defined within each element or meta-element member of the ST. The first number is memorized in a local variable STIj eta, and the second number is memorized in a local variable STLwidth 1325 (representing the number of columns of the future STI).
Then another local variable STIjalement is initialized with the value taken by STIjmin. Then another local variable STI_critical s initialized with the default value "YES". Then another local variable STI_sheet_width 1321 is initialized with the total number of columns in the current sheet 1320. Then another local variable STIjsheetjheight 1322 is initialized with the total number of rows in the current sheet 1320. Then another local variable STIjmode is initialized with the value OVERLAY.
• At step 1406, some other local variables are first built or updated. The position of the currently selected cell 1327 is first represented by the local variables STI_offset_width 1323 and STIjoffsetjheight 1324 corresponding respectively to the number of columns and of rows between the top left cell of the current sheet 1320 and the currently selected cell 1327. Then the number of rows of the future STI is represented by the local variable STljheight 1326, computed as the sum of the local variables STI_meta and STIjelement. Second some working ranges of cells are determined through the evaluation of their addresses. The range of cells STIjange 1328 corresponding to the future STI is first determined as the range of cells with the currently selected cell 1327 as the top left cell, and with a number of rows and columns respectively equal to STljheight 1326 and STLwidth 1325. Then the range of cells STIjhorizontalJlushedjange 1330 is determined as the range of cells sharing the same rows as STIjange 1328, and occupying the STLwidth 1325 rightmost columns of the current sheet 1320.
Then the range of cells STIjhorizontaljkeptjange 1329 is determined as the range of cells sharing the same rows as STIjange 1328, and occupying the columns located between those of STIjange 1328 and STIJiorizontalJlushed ange 1330. Then the range of cells STI /erticalJlushed ange 1332 is determined as the range of cells sharing the same columns as STIjange 1328, and occupying the STI_heighf\Z26 bottom columns of the current sheet 1320.
Then the range of cells STIj eriicalJ<epl ange 1331 is determined as the range of cells sharing the same columns as STIjange 1328, and occupying the rows located between those of STIjange 1328 and STIj/erticalJlushedjange 1332.
• At step 1407, two sums are performed to check if the future STI will fit within the boundaries of the current sheet 1320. • If the sum of the local variables STI_offset_width 1323 and STLwidth 1325 is found greater than the local variable STIjsheetjwidth 1321, then a local variable STIJoojA/ide is set to "YES"; otherwise it is set to "NO".
• If the sum of the local variables STI_offset_heighf\324 and STljheight 1326 is found greater than the local variable STIjsheetjheight 1322, then a local variable
STIJooj igh is set to "YES"; otherwise it is set to "NO". At step 1408, several tests are performed to evaluate the potential impact of the creation of the future STI, according to the five possible instanciation modes, on any already existing STI or data. These tests require to parse the STIT table 750, and to visit each record 751 to learn the address ("Addresd' field 752) and the importance ("Critical' field 755) of every already defined STI. These tests evaluate either if two given ranges of cells partially overlap (meaning that there exist in the first range of cells at least one cell belonging to the second range of cells and at least one cell not belonging to the second range of cells) or if a first given range of cells is included within a second given range of cells (meaning that every cell belonging to the first range of cells belongs too to the second range of cells). Different conventional range comparison techniques can be used for evaluating either range partial overlapping or range inclusion, without departing from the spirit of the present invention; they will not be described in the preferred embodiment of the present invention. First the OVERLAY mode of instanciation is investigated.
• If there exists at least one existing STI whose "Critical' field 755 takes the value "YES" and which partially overlaps the range of cells STIjange 1328, then the local test variable STIjoverlayjcritical takes the value "YES"; otherwise the local test variable STljoverlayjoritical lakes the value "NO". • If there exists at least one existing STI whose "Critical' field 755 takes the value "NO" and which partially overlaps the range of cells STIjange 1328, then the local test variable STLoverlayjother takes the value "YES"; otherwise the local test variable STIjoverlayjjther takes the value "NO".
• If all the cells within the range of cells STIjange 1328 are empty (containing none data), then the local test variable STLoverlayjdata takes the value "NO"; otherwise the local test variable STLoverlayjdata takes the value "YES". Second the HORIZONTAL NSERT mode of instanciation is investigated.
• If there exists at least one existing STI whose "Critical' field 755 takes the value "YES" and which partially overlaps the range of cells made of the entire row where is located the currently selected cell 1327, or which partially overlaps the range of cells constituted by the last bottom STI_heighf\326 rows, or which is included in the range of cells constituted by the last bottom STljheight 1326 rows, then the local test variable STIjhorizontaLcritical takes the value "YES"; otherwise the local test variable STljhorizontaLcriticalXaV.es the value "NO". • If there exists at least one existing STI whose "Critical' field 755 takes the value "NO" and which partially overlaps the range of cells made of the entire row where is located the currently selected cell 1327, or which partially overlaps the range of cells constituted by the last bottom STlj eight 1326 rows, or which is included in the range of cells constituted by the last bottom STljheight 1326 rows, then the local test variable STIj orizontaLother takes the value "YES"; otherwise the local test variable
STIjhorizontaljother lakes the value "NO". s If all the cells within the range of cells constituted by the last bottom STlj eight 1326 rows are empty (containing none data), then the local test variable
STIjhorizontaljdata takes the value "NO"; otherwise the local test variable STIjhorizontaLdata takes the value "YES".
Third the HORIZONTAL_INSERT_BY_RANGE mode of instanciation is investigated.
• If there exists at least one existing STI whose "Critical' field 755 takes the value "YES" and which partially overlaps the range of cells constituted by the concatenation of the two ranges of cells STLrange 1328 and STLverticaljkept ange 1331, or which partially overlaps the range of cells STIj/erticalJlushedjange 1332, or which is included in the range of cells STLverticalJlushed ange 1332, then the local test variable STIjhorizontal angejcritical takes the value "YES"; otherwise the local test variable STIjhorizontaljange_critical takes the value "NO".
° If there exists at least one existing STI whose "Critical' field 755 takes the value "NO" and which partially overlaps the range of cells constituted by the concatenation of the two ranges of cells STIjange 1328 and STI /erticalJiepi ange 1331 , or which partially overlaps the range of cells STLverticalJlushedjange 1332, or which is included in the range of cells STLverticalJlushedjange 1332, then the local test variable STIjhorizontal angejJther takes the value "YES"; otherwise the local test variable STIjhorizontaljangejJther takes the value "NO".
° If all the cells within the range of cells STLverticalJlushedjange 1332 are empty (containing none data), then the local test variable STIjhorizontal angejdata takes the value "NO"; otherwise the local test variable STIjhorizontaljangejdata takes the value "YES".
Fourth the VERTICALJNSERT mode of instanciation is investigated.
• If there exists at least one existing STI whose "Critical' field 755 takes the value "YES" and which partially overlaps the range of cells made of the entire column where is located the currently selected cell 1327, or which partially overlaps the range of cells constituted by the last right STLwidth 1325 columns, or which is included in the range of cells constituted by the last right STLwidth 1325 columns, then the local test variable STI_vertical_critical takes the value "YES"; otherwise the local test variable STI erticaLcritical takes the value "NO". • If there exists at least one existing STI whose "Critical' field 755 takes the value "NO" and which partially overlaps the range of cells made of the entire column where is located the currently selected cell 1327, or which partially overlaps the range of cells constituted by the last right STLwidth 1325 columns, or which is included in the range of cells constituted by the last right STLwidth 1325 columns, then the local test variable STI /erticaljother takes the value "YES"; otherwise the local test variable
STI erticaLother takes the value "NO".
• If all the cells within the range of cells constituted by the last right STLwidth 1325 columns are empty (containing no data), then the local test variable STI erticaljdata takes the value "NO"; otherwise the local test variable STIj/erticaljdata takes the value "YES".
Fifth the VERTICAL_INSERT_BY_RANGE mode of instanciation is investigated.
• If there exists at least one existing STI whose "Critical' field 755 takes the value "YES" and which partially overlaps the range of cells constituted by the concatenation of the two ranges of cells STIjange 1328 and STIjhorizontaljkeptjange 1329, or which partially overlaps the range of cells STIjhorizontalJlushed ange 1330, or which is included in the range of cells STI_horizontalJlushed ange 1330, then the local test variable STLvertical angejcritical takes the value "YES"; otherwise the local test variable STLvertical angejcritical takes the value "NO".
• If there exists at least one existing STI whose "Critical' field 755 takes the value "NO" and which partially overlaps the range of cells constituted by the concatenation of the two ranges of cells STIjange 1328 and STIjhorizontaljkeptjange 1329, or which partially overlaps the range of cells STIjhorizontalJlushedjange 1330, or which is included in the range of cells STIjhorizontalJlushedjange 1330, then the local test variable STI_vertical ange_other takes the value "YES"; otherwise the local test variable STI_verticaljange_other takes the value "NO".
° If all the cells within the range of cells STIjhorizontalJlushedjange 1330 are empty (containing none data), then the local test variable STLvertical angejdata takes the value "NO"; otherwise the local test variable STLvertical angejdata takes the value "YES".
• At step 1409, the ST Instanciator Dialog Box 1300 is displayed on the display device 106. The "Critical' check box 1314 displays a check mark if the local variable STLcritical takes the value "YES"; otherwise (value "NO"), the "Critical' check box 1314 is kept with a blank empty display. The label box 1315 is initialized with the value of the local variable STjname. The text box 1 12 is filled with the value of the local variable STIjelement The label box 1311 is filled with the value of the local variable STIJoo_wide and the label box 1310 is filled with the value of the local variable STIJoo_high. The 15 label boxes 1304 are filled row after row, starting with the top row, from the left to the right, with the values of the following local variables in the following order: STI_overlay_critical, STIjjverlayjother, STLoverlayjdata, STIjhorizontaLcritical, STIjhorizontaljother, STIjhorizontaljdata, STIjhorizontal ange_critical, STIjhorizontaljangejJther, STIjhorizontaljangejdata, STLverticaljohtical, STI /erticaljoiher, STIj/erticaljdata, STl_vertical ange_critical, STI_verticaljange_other, STLverticaljangejdata.
Then if the local variable STIj ode takes the respective value OVERLAY, or
HORIZONTALJNSERT, Or HORIZONTAL_lNSERT_BY_RANGE, Or VERTICALJNSERT, Or
VERTICAL_INSERT_BY_RANGE, then the option button "Overlay' 1309, or "Horizontal Insert'
1308, or "Horizontal Insert by Rangd' 1307, or "Vertical Insert' 1306, or "Vertical Insert by Range" 1305 displays alone a black point. Finally the "Creatd' push-button 1303 is disabled as soon as one of the following local variables takes the value "YES":
STIJoo_wide, STIJooJiigh, STIjJverlayjcritical (only taken into account if the local variable STIjmode is equal to OVERLAY) , STIjhorizontaLcritical (only taken into account if the local variable STIjmode is equal to HORIZONTALJNSERT), STLverticaLcritical (only taken into account if the local variable STIjmode is equal to VERTICALJNSERT),
STI_horizontal ange_critical (only taken into account if the local variable STIjmode is equal to HORIZONTAL JNSERT_BY_RANGE), STLvertical angej ritical (only taken into account if the local variable STIjmode is equal to VERTICALJNSERT_BY_RANGE); otherwise the "Creatd' push-button 1303 is enabled. • At step 1410, the method is waiting for any user action on the ST Instanciator Dialog
Box 1300, or on any change of the currently selected cell. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here. • At step 1411, a user action on the ST Instanciator Dialog Box 1300, or a change of the currently selected cell is detected.
If the user action is a click on the "Creatd' push-button 1303, then control is given to step 1416; if the user action is a click on the upper part of the spin button 1313, then control is given to step 1415; if the user action is a click on the lower part of the spin button 1313, then control is given to step 1414; if the user action is a click on the "Critical' check box 1314, then control is given to step 1413; • if the user action is a click on one of the option buttons 1309, or 1308, or 1307, or 1306, or 1305, then control is given to step 1412; ° if the user action is a click on the "Cancel' push-button 1302, or on the closing-window push-button 1301, then control is given to step 1418; • finally if the user action is a change in the position of the currently selected cell, then control is given to step 1406.
• At step 1412, the local variable STIjmode takes the value OVERLAY, or HORIZONTALJNSERT, or HORIZONTAL INSERT BY RANGE, or VERTICALJNSERT, or VERTICAL INSERT BY_RANGE if the spreadsheet user has respectively clicked with the pointing device 105 on the option button 1309, or 1308, or 1307, or 1306, or 1305. Then control is given to step 1406.
• At step 1413, the local variable STLcritical is updated in order to swap between the values "YES" and "NO". Then control is given to step 1406. ° At step 1414, the local variable STIjelement is decremented by 1 (one), as long as its value remains greater than or equal to the value of the local variable STIjmin. Then control is given to step 1406.
° At step 1415, the local variable STIjelement is incremented by 1 (one), as long as its value remains less than or equal to the value of the local variable STIjmax. Then control is given to step 1406.
• At step 1416, the STIT table 750 is visited to remove from it every record 751 corresponding to a STI corrupted by the introduction of the new instance, as identified during the step 1408 for the insertion mode represented by the local variable STIjmode. Then the STT table 720 is updated to reflect the removal of each STI. For each removed STI, the INSTANCE REFERENCE (IR) field 729c of the "REFERENCED" attribute 729 of the record 721 whose "Namd' field 722 is equal to the "ST field 753 of the record 751 of the STIT table 750 corresponding to the removed STI, is divided by 2 (two).
• At step 1417, the routine CreateSTI is called. • At step 1418, the ST Instanciator Dialog Box 1300 is closed so that it disappears from the display device 106. Finally control is given back to the initial step 1401 for processing any future ST Instanciator command. The following steps, all part of FIG 14B, correspond to the execution of the CreateSTI routine, as used in the preferred embodiment of the present invention • At step 1419, a new record 751 is introduced in the STIT table 750. Within this record 751 , the "Addresd' field 752 is initialized with the address of the range of cells STIjange 1328, the "ST field 753 is initialized with the value of the local variable STjname, the "Element #' field 754 is initialized with the value of the local variable STIjelement, the "Critical' field 755 is initialized with the value of the local variable STLcritical, the "Header Sizd' field 756 is initialized with the number of meta-elements constituting the header part of the new STI (this number being equal to the number of pairs in the header part 767 of the STDT table 760 associated to the ST that the new STI will abide by), and the "Footer Sizd' field 757 is initialized with the number of meta-elements constituting the footer part of the new STI (this number being equal to the number of pairs in the footer part 766 of the STDT table 760 associated to the ST abided by the new STI). Then the STT table 720 is scanned to identify the record 721 whose "Namd' field is found equal to the local variable STjname. Once found, the "REFERENCED" attribute 729 within the "Typd' field 727 of this record 721 is updated by multiplying the "INSTANCE REFERENCE" subfield 729c by 2 (two). • At step 1420 a test is performed to check the value of the local variable STIjmode.
• If this value is found equal to OVERLAY then control is given to step 1425,
• If this value is found equal to HORIZONTALJNSERT then control is given to step 1424,
• If this value is found equal to HORIZONTALJNSERT_BY_RANGE then control is given to step 1422, • If this value is found equal to VERTICALJNSERT then control is given to step 1423, β If this value is found equal to VERTICALJNSERT_BY_RANGE then control is given to step
1421. s At step 1421 , the range of cells STIjange 1328 is selected to become the currently selected range of cells, with the currently selected cell being kept in its former position 1327 and then a regular operation of "column insertion within selected range" is performed. Then control is given to step 1425.
• At step 1422, the range of cells STIjange 1328 is selected to become the currently selected range of cells, with the currently selected cell being kept in its former position 1327 and then a regular operation of "row insertion within selected range" is performed. Then control is given to step 1425.
• At step 1423, the range of cells STIjange 1328 is selected to become the currently selected range of cells, with the currently selected cell being kept in its former position 1327 and then a regular operation of "column insertion" is performed. Then control is given to step 1425.
° At step 1424, the range of cells STIjange 1328 is selected to become the currently selected range of cells, with the currently selected cell being kept in its former position
1327 and then a regular operation of "row insertion" is performed. Then control is given to step 1425.
• At step 1425, a local variable STIJndex is initialized to the value taken by the local variable STIjelement. Then the STT table 720 is parsed to identify the record 721 whose "Name" field 722 matches the value of the local variable STjname. Within this record 721 is retrieved the "Description Ptf field 724 allowing to locate in memory the STDT table 760 associated to the ST that the new STI to be created will abide by. Then the first pair 761 of element or MEF name and element or MEP name found within this STDT table 760 is set as the current pair of names: (EF or MEF name, EP or MEP name).
• At step 1426, the EPT table 710 is parsed to find the record 711 whose "Name" field 712 is found equal to the EP or MEP name within the current pair. Once this record 711 is found, its "Description Ptf field 714 is retrieved to locate in memory the range of cells illustrating the EP or MEP. This description of the EP or MEP is copy-pasted by value only onto the currently selected cell, so that the corresponding row within the STIjange receives the EP or MEP initial values. Then the EFT table 700 is parsed to find the record 701 whose "Namd' field 702 is found equal to the EF or MEF name within the current pair. Once this record 701 is found, its "Description Ptf field 704 is retrieved to locate in memory the range of cells illustrating the EF or MEF. This description of the EF or MEF is copy-pasted by attribute only onto the currently selected cell, so that the corresponding row within the STIjange receives the EF or MEF attributes. • At step 1427 a test is performed to check if the current pair (EF or MEF name, EP or MEP name) corresponds to an element or to a meta-element. In the first case, control is given to step 1428, and in the second case control is given to step 1429.
• At step 1428, the local variable STIJndex is decremented by 1 (one). Then control is given to step 1430. • At step 1429, a test is performed to check if the current pair (EF or MEF name, EP or MEP name) is the last one 763 within the STDT table 760. If it is the case, the execution of the CreateSTI routine completes by returning control to the routine caller, otherwise control is given to step 1431.
• At step 1430, a test is performed to check if the local variable STIJndex is equal to 0 (zero). If it is the case, then control is given to step 1429, otherwise control is given to step 1432.
• At step 1431, the pair of names (EF or MEF name, EP or MEP name) following the current one in the STDT table 760 becomes the current pair of names.
• At step 1432, the currently selected cell is moved downwards by one row. Then control is given to step 1426.
E7. RST Instanciator method
The method for instanciating a RST used in the preferred embodiment of the present invention is summarized in flowchart 2100 of FIG 16A and 16B. This method can be seen as the processing of the ST Instanciator command. ° At step 2101, the method is in its default state, waiting for an event to initiate the process.
• At step 2102, the RST Instanciator command is detected, as a result of a user action. This action can be for instance a specific combination of keys on the keyboard 104, or the click of the pointing device 105 on a specific button, or any other similar means no further specified here. • At step 2103, the command parameter is retrieved and some local variables are initialized: ° The command parameter is recorded in the RSTJMame variable. ° The local variable Element# is initialized with the value 0 (zero). 0 The local variable toojMide is initialized with the default value FALSE. 0 The local variable toojhigh is initialized with the default value FALSE. 0 The local variable Maxjool is initialized with the maximum number of available columns on a sheet.
• If the local variable Maxjow is initialized with the maximum number of available rows on a sheet.
• The local var iiable STIjpresent is initialized with the default value FALSE. 0 The local vari iable RSTLbusy is initialized with the default value FALSE.
• The local var iiable RSTIJopJeft_ceH\s initialized as being the currently selected cell. β At step 2104, the RSTT table 2220 is parsed to identify the record 2221 (identified by the local variable CurrjRSTTjec) whose "Namd' field 2222 is equal to the command parameter RSTjName. Then the local variable RSTIjΞ# is set equal to the value of the "Min Elements field 2225 of this record CurrjRSTTjec 2221. • At step 2105, the local variable CurrjRSTDT is set equal to the RSTDT table 2250 pointed by the "Description Ptf field 2224 of the record CurrjRSTT ec 2221. Then the local variable CurrjRSTDT ec is set equal to the first single-cell record 2251 of the CurrjRSTDT table 2250. Then the local variable CurrJRET ec is set equal to the record 2211 of the RET table 2210, with a "Namd' field 2212 equal to the local variable CurrjRSTDTjec. Then the local variable CurrjREDjRoC is set equal to the range of cells pointed by the "Description Ptf field 2214 of the record CurrjRET ec 2211.
• At step 2106, a RSTIDT table 2270 is loaded in memory and named through the local variable CurrjRSTlDT. This table has a number of rows equal to the numbers of rows of the CurrjRSTDT table 2250, incremented by the value of the local varaibel RSTI_E# and decremented by 1 (one). This table has a number of columns equal to the number of columns of the Curr_RED_RoC range of cells. Then the local variable CurrjRSTIDT ec is initialized as the first record 2271 of the Ct//τ_ftS77D7" table 2270.
• At step 2107, the local variable CurrjRSTIDTjoell is initialized as the first cell 2280 of the CurrjRSTIDT ec 2271. Then the local variable CurrjRECjRocjoell is initialized as the first cell of the CurrjRECjRoC range of cells.
• At step 2108, the "STIjoof field 2278 of the CurrjRSTIDTjoell 2280 is set equal to the value returned by the function STI_col when called with the unique parameter equal to the value of the local variable Curr_RET_RoC_cell. Then the "STI ow" field 2279 of the CurrjRSTIDTjoell 2230 is set equal to the value returned by the function STIJΌW when called with the two parameters respectively equal to the value of the local variable CurrjRETjRoCjoell and to 0 (zero). Then the "STjname" field 2280 of the CurrjRSTIDTjoell 2280 is set equal to the value of the local variable Curr_RET_RoC_cell.
• At step 2109, a test is performed to check if the cell represented by the local variable CurrjRSTIDTjoell 2280 is the last cell of the record represented by the local variable
CurrjRSTIDTjec 2271. If it is the case, then control is given to step 2111 ; otherwise control is given to step 2110.
• At step 2110, the cell located on the right of the cell represented by the local variable CurrjRSTIDTjoell 2280 becomes the new CurrjRSTIDTjoell 2280. Then the cell located on the right of the cell represented by the local variable CurrjRETjRoCjoell becomes the new CurrjRETjRoCjoell. Then control is given to step 2108.
• At step 2111, a test is performed to check if the record represented by the local variable Curr RET rec 2211 describes a RE. This can be determined if the "META" attribute 2218 of the "Type" field 2217 of the CurrjRETjec record 2211 is equal to the value "NO". If it is the case, then control is given to step 2112; otherwise control is given to step 2114.
• At step 2112, the local variable Element# is incremented by 1 (one).
• At step 2113, a test is performed to determine if the local variable ElemenW is equal to the local variable RSTIjE#. If it is the case, then control is given to step 2114; otherwise control is given to step 2115. 0 At step 2114, a test is performed to check if the cell represented by the local variable CurrjRSTIDTjoell 2280 is the last cell of the record represented by the local variable CurrjRSTIDT ec 2271. If it is the case, then control is given to step 2116; otherwise control is given to step 2117.
• At step 2115, the record following the CurrjRSTIDTjec record 2271 in the CurrjRSTlDT table 2270 becomes the new CurrjRSTIDTjec record 2271. Then control is given to step 2107.
0 At step 2116, the record following the CurrjRSTDTjec record in the CurrjRSTDT table 2250 becomes the new CurrjRSTDTjec. Then control is given to step 2115. β At step 2117, for each cell CurrjRSTIDTjoell 2280 belonging to the CurrjRSTlDT table 2270, the " container ow" attribute 2281 is set equal to the maximum value of the "STIjow" attribute 2279 of the cells Samejowjoell located within the CurrjRSTlDT table 2270 on the same row as CurrjRSTIDTjoell. Then for each cell CurrjRSTIDTjoell 2280 belonging to the CurrjRSTlDT table 2270, the " container joot' attribute 2277 is set equal to the maximum value of the "STIjoof attribute 2278 of the cells Samejooljoell located within the CurrjRSTlDT able 2270 on the same column as CurrjRSTIDTjoell.
• At step 2118, the local variable RSTljool is set equal to the sum of the " container jool' attributes 2277 of the cells belonging to the first row of the CurrjRSTlDT table 2270. Then the local variable RSTIjow is set equal to the sum of the " container ow" attributes 2281 of the cells belonging to the first column of the CurrjRSTlDT tab\e 2270.
• At step 2119, a test is performed to determine if the sum of the local variable RSTljool and of the column index of the individual cell RSTI_ topjeftjoell decremented by 1 (one) is strictly greater than the local variable Maxjool. If it is the case, then control is given to step 2120; otherwise control is given to step 2121.
• At step 2120, the local variable too_wide is set equal to the value TRUE.
• At step 2121, a test is performed to determine if the sum of the local variable RSTIjow and of the row index of the individual cell RSTIJopJeftjoell decremented by 1 (one) is strictly greater than the local variable Max ow. If it is the case, then control is given to step 2122; otherwise control is given to step 2123.
• At step 2122, the local variable toojhigh is set equal to the value TRUE.
• At step 2123, a test is performed to determine if there is any existing STI present on the same sheet as the individual cell RSTIJopJeftjoell. This test can simply be done by parsing the STIT table 750 for identifying any record 751 with an "Addresd' field 752 pointing to the same sheet as the individual cell RSTIJopJeftjoell. If it is the case, then control is given to step 2124; otherwise control is given to step 2125.
• At step 2124, the local variable STIjpresent is set equal to the value TRUE.
• At step 2125, the local variable RSTI ange is initialized as being the range of cells with RSTIJopJeftjoell as the top left cell, with a number of rows equal to the value of the local variable RSTIjow, and with a number of columns equal to the value of the local variable RSTljool. 0 At step 2126, a test is performed to check if there is any data present within the range of cells RSTIjange. If it is the case, then control is given to step 2127; otherwise control is given to step 2128. ° At step 2127,the local variable RSTLbusy is set equal to the value TRUE.
At step 2128, the RST Instanciator dialog box 2300 is displayed on the display device 106. Within this dialog box 2300, the text field 2302 is filled with the value of the local variable RST name, the text field 2311 is filled with the value of the local variable RSTIjΞ#, the text field 2304 is filled with the value of the local variable toojwide, the text field 2305 is filled with the value of the local variable toojhigh, the text field 2306 is filled with the value of the local variable STLpresent, the text field 2307 is filled with the value of the local variable RSTLbusy. The "Create Instancd' push-button 2310 is enabled if and only if the three local variables too_wide, toojhigh and STLpresent take the same value FALSE. The "Create instance in a new sheet' push-button 2309 is enabled if and only if the two local variables too_wide and toojiigh take the same value FALSE. 0 At step 2129, the method is waiting for any user action on the RST Instanciator dialog box 2300. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of keys on the keyboard 104, or any other similar means not further specified here. ° At step 2130, a user action on the RST Instanciator dialog box 2300 is detected.
® If the user action is a click with the pointing device 105 on one "Up" arrow of the spin-button 2303, then control is given to step 2133. β If the user action is a click with the pointing device 105 on one "Down" arrow of the spin-button 2303, then control is given to step 2134.
• If the user action is a click with the pointing device 105 on the "Create instancd' push-button 2310, then control is given to step 2138.
• If the user action is a click with the pointing device 105 on the "Create instance in a new sheet' push-button 2309, then control is given to step 2136.
• If the user action is a click with the pointing device 105 on the "Cancel' push button 2308, or on the closing-window push-button 2301, then control is given to step 2131.
• At step 2131 , the range of cells CurrjRSTlDT Is released from memory.
• At step 2132, the RST Instanciator dialog box 2300 is closed on the display device 106 and then control is given back to the initial step 2101 for processing any future RST
Instanciator command.
• At step 2133, the local variable RSTIJΞtf is incremented by 1 (one).
• At step 2134, the local variable RSTIJΞ# is decremented by 1 (one).
• At step 2135, the range of cells CurrjRSTlDT is released from memory, and then control is given to the step 2105.
• At step 2136, a new sheet is created and named currjsheet.
• At step 2137, the top left cell of the sheet currjsheet becomes the new individual cell RSTIJopJeftjoell.
• At step 2138, the local variable STIjmode is initialized with the value OVERLAY. Then the local variable STLcritical is initialized with the value YES. Then the local variable
CurrjRSTIDTjec is initialized as being the first record 2271 of the CurrjRSTlDT table 2270. Then the local variable CurrjRSTIDTjoell is initialized as being the first cell 2280 of the record CurrjRSTIDTjec 2271. Then the local variable Currjoell is initialized as being equal to RSTIJopJeftjoell. • At step 2139, the " container jange" attribute 2276 of the CurrjRSTIDTjoell 2280 is initialized as the range of cell having as the top left cell the individual cell Currjoell, having' a number of rows equal to the value of the "container ow" attribute 2281 , and having a number of columns equal to the value of the " container jcot' attribute 2277.
• At step 2140, the local variable STIjange is set equal to the " container jangd' attribute 2276 of the CurrjRSTIDTjoell 2280. Then the local variable STjname is set equal to the "STjnamd' attribute 2280 of the CurrjRSTIDTjoell 2280. Then the local variable STIjelement is set equal to the "Min Element!?' field 2225 of the record 721 of the STT table 720 with a "Namd' field 722 equal to STj ame. 9 At step 2141 , the CreateSTI command is invoked (as a sub-routine). When this command completes and returns control to the current process, the control is given to the next step 2142. • At step 2142, the "STIT ecjptf attribute 2282 of the CurrjRSTIDTjoell 2280 is set as pointing to the STIT record 751 that has just been created during the previous step 2141.
• At step 2143, a test is performed to check if the cell represented by the local variable CurrjRSTIDTjoell 2280 is the last cell of the record represented by the local variable
CurrjRSTIDTjec 2271. If it is the case, then control is given to step 2143; otherwise control is given to step 2144. ° At step 2144, the individual cell currjoell is moved to the right by a number of columns equal to the value of the " container joof attribute 2277 of CurrjRSTIDTjoell 2280. Then the cell located on the right of the individual cell CurrjRSTIDTjoell 2280 becomes the new CurrjRSTIDTjoell 2280. ° At step 2145, a test is performed to check if the record represented by the local variable
CurrjRSTIDTjrec 2271 is the last record of the RSTIDT table represented by the local variable CurrjRSTlDT 2270. If it is the case, then control is given to step 2147; otherwise control is given to step 2146.
• At step 2146, the individual cell RSTIJopJeftjoell is moved down by a number of rows equal to the value of the "container ow" attribute 2281 of the CurrjRSTIDTjoell 2280. Then the individual cell currjoell is set equal to the individual cell RSTIJopJeftjoell. Then the record 2271 following CurrjRSTIDTjec in CurrjRSTlDT 2270 becomes the new record CurrjRSTIDTjec 2271. Then the first cell of CurrjRSTIDTjec 2271 becomes the new individual cell CurrjRSTIDTjoell 2280.
• At step 2147, a new record 2261 is created in the RSTIT table 2260 for describing the RSTI that has just been created. The "Addresd' field 2262 is filled with the address of the rir range of cell 2001. The "RST field 2263 is filled with the local variable RSTjName. The "Element #" field 2264 is filled with the local variable Elements The "RSTIDT Ptf field 2265 is filled with the local variable CurrjRSTlDT. The "Header Size" field 2266 is filled with the number of rows of the container rows constituting the RSTI header 2002. The "Footer Sizd' field 2267 is filled with the number of rows of the container rows constituting the RSTI footer 2004. Then the RSTT table 2220 is scanned to identify the record 2221 whose "Namd' field 2222 is found equal to the local variable RSTjname. Once found, the "REFERENCED" attribute 2229 within the "Type" field 2227 of this record 2221 is updated by multiplying the "INSTANCE REFERENCE" subfield 2229c by 2 (two). Then control is given to step 2132. E8. RE Editor method The method for creating or updating RE's or meta-elements used in the preferred embodiment of the present invention is summarized in flowchart 2340 of FIG 18C. This method can be seen as the processing of the RE Editor command.
• At step 2341, the method is in its default state, waiting for an event to initiate the process. • At step 2342, the RE Editor command is detected, as a result of an user action. This action can be for instance:
• a specific combination of key on the keyboard 104, or
• the click of the pointing device 105 on a specific button, or
• any other similar means not further specified here. • At step 2343, the parameter of the command is retrieved. It corresponds to a mandatory parameter REjname which can either take a reserved value "NEW" or another value corresponding to a character string name, as found in the "Namd' field 2232 of a record
2231 within the RSTMT table 2230. This parameter is recorded as a local variable.
9 At step 2344, some local variables are initialized: the local variable REjmeta is set to the value "NO", the local variable REjsize is set to the value 3 (three), and the local variable RE ank is set to the value 1 (one). • At step 2345, a test is performed to determine the value taken by the local variable REjname. If found equal to "NEW", then control is given to step 2349; otherwise control is given to step 2346.
• At step 2346, the RET table 2210 is looked up to locate a record 2211 whose "Name" field 2212 is found equal to the value taken by the local variable REjname. If such a record is found, then control is given to step 2348; otherwise control is given to step
2347. ° At step 2347, an exception handler is invoked to treat this "should not occur" condition.
Such operation is implementation dependent and can take different forms such as the display on the display device 106 of an error message pop-up window. Then control is given to step 2341. » At step 2348,
• the local variable REjmeta is set to the value "YES" or "NO" according to the value of the "META" attribute 2218 within the 'Type" field 2217 of the record 2211 found at step 2346,
• the local variable REjsize is set to the value found in the "Column #" field 2216 of the record 2211 found at step 2346, and
• the memory location pointed by the "Description Ptf field 2214 of the record 2211 found at step 2346 is copied onto a temporary buffer recorded as the local variable REjouffer.
Then control is given to step 2350.
• At step 2349, a new name for the newly created RE is determined, according to a name string taking in a preferred embodiment of the present invention the form "New XX" where XX corresponds to a counter value ensuring the name uniqueness with respect to all the names previously defined and recorded in the "Name" fields 702, 712, 722, 2212 and 2222 found in the respective records 701 , 711 , 721 , 2211 and 2221 of the respective tables EFT 700, EPT 710, STT 720, RET 2210 and RSST 2220. Any other similar conventional means could be used instead without departing from the spirit of the invention, as long as the uniqueness of the newly created name is ensured. Then the new name is recorded in the local variable REjname. Then memory space is allocated within the main memory 102 to later record the illustrative range of cells for the RE or RME. This allocated memory, recorded as the local variable REjouffer is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 2211 is created in the RET table 2210, and this new record 2211 is initialized as follows:
• the "Namd' field 2212 is set to the value of the local variable RE_name ;
• the "Last Change Datd' field 2213 is set to the system time reference, as known by the central processor 101 ;
• the "Description Ptf field 2214 is set to the memory location REjouffer which has just been allocated ;
• the "Row #" field 2215 is set to the value 1 (as in the preferred embodiment of the present invention the RST's are managed in a 2D environment; this field would carry the number of defined rows for the created RE in a 3D environment) ;
• the "Column #' field 2216 is set to the value of the local variable REjsize ; • the "Type" field 2217 is set as follows: the attribute "META" 2218 is set equal to the value of the local variable REjmeta, and the attribute "REFERENCED" 2219 is initialized as follows: s The "OWN REFERENCE" (OR) subfield 2219a is initialized with a prime number not yet assigned to any other OR subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here.
• The "FILIATION REFERENCE" (FR) subfield 2219b is initialized according to the following formula, where the jset corresponds to the set of ST's constituting the new RE or meta-element, according to the structure recorded in the "Description Ptf field 2214:
FR = π,ef OR, x LCM({FR,}),e;F • The "INSTANCE REFERENCE" (IR) subfield 2219c is initialized with the value 1 (one). ° The "REFERENCED OBJECT" (RO) subfield 2219d is initialized with the following formula, where the fPset corresponds to the set of RST's: RO = "YES" if LCM({FR,}),SS> Mod OR = 0; RO = "NO" otherwise. ° The "SELECTED CHILDREN" (SC) subfield 221 e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the
"SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230): SC = "YES" if LCM({FR,}),e.s Mod OR = 0 #OR# RSTEjname e s, SC = "NO" otherwise. Then control is given to step 2350. * At step 2350, the RE Editor Dialog Box 2321 is displayed on the display device 106.
• The label box 2324 is initialized with the value of the local variable REjname.
• The top option button 2331 (respectively bottom option button 2330) is filled with a black point if the local variable REjmeta is found equal to "NO" (respectively "YES").
• The text box 2326 is filled with the value of the local variable REjsize. • The push-button "Savd' 2333 is enabled if the local variable REjsize is found equal to the "Column #" field 2216 of the current record 2211 , or if the attribute "REFERENCED" 2219 within the "Typd' field 2217 of this same record 2211 is found with the subfield "REFERENCED OBJECT" 2219d (RO) equal to "NO", SO that any future click with the pointing device 105 on this push-button "Savd' 2333 will be recognized as a valid event.
• The push-button "Savd' 2333 is disabled otherwise (local variable REjsize is not found equal to the "Column #" field 2216 of the current record 2211 , and the attribute "REFERENCED" 2219 within the 'Type" field 2217 of this same record 2211 is found with the subfield "REFERENCED OBJECT" 2219d (RO) equal to "YES"), SO that any future click with the pointing device 105 on this push-button "Savd' 2333 will not be recognized as an event.
• The text box 2335 is initialized with the value of the local variable RE ank.
• The list box 2334 is initialized with the content of the cell belonging to REjouffer and whose offset is equal to RE ank. The list of names available within this list box 2334 (by clicking on the spin button 2328) is constituted by the names of the ST's recorded in the STT table 720.
• At step 2351, the method is waiting for any user action on the RE Editor Dialog Box 2321. Such user action is typically resulting from a click with the pointing device 105, but take other similar forms such as, but not limited to a specific combination of key on the keyboard 104, or any other similar means not further specified here.
• At step 2352, a user action on the RE Editor Dialog Box 2321 is detected.
• If the user action is a click on the spin button 2328, to select a ST name, then control is given to step 2353;
• if the user action is a click on the push-button "Save" 2333, then control is given to step 2354;
• if the user action is a click on the push-button "Save As" 2332, then control is given to step 2355; f the user action s a click on the spin button 2329, then control is given to step 2358; f the user action s a click on the spin button 2327, then control is given to step 2359; f the user action s a click on one of the two option buttons 2330 or 2331 , then control s given to step 2360; • if the user action is a click on the push-button "Done" 2323, or on the closing-window push-button 2322, then control is given to step 2361.
• At step 2353, the local variable REjouffer is updated by setting equal to the content of the list box 2334 the content of the cell with offset equal to the value of the local variable REjrank. Then control is given to step 2350.
° At step 2354, the RET table 2210 is updated and saved as part of the electronic spreadsheet file by refreshing the record 2211 whose "Name" field 2212 is equal to the local variable REjname. For this purpose,
° the "Last Change Date" field 2213 is set to the system time reference, as known by the central processor 101 ;
@ the "Column #" field 2216 is set to the value of the local variable REjsize ;
° the "Typd' field 2217 is set as follows: the attribute "META" 2218 is set equal to the value of the local variable REjmeta. In addition the range of cells REjouffer illustrating the current definition of the RE or meta-element is copied onto the memory location pointed by the "Description Ptf field 2214. Then control is given to step 2350.
• At step 2355, a test is performed on the value found in the text box 2325 to determine if it corresponds to a valid new name. The corresponding criteria are implementation dependent and may take different forms without departing from the spirit of the invention, as long as the new proposed name is a unique character string against all the already defined names recorded in the "Name" fields 702, 712, 722, 2212 and 2222. If validity and uniqueness are proven, then control is given to step 2356; otherwise control is given to step 2357.
• At step 2356, memory space is allocated within the main memory 102 to later record the illustrative range of cells for the EF or MEF. This allocated memory is part of the memory space corresponding to the currently opened electronic spreadsheet file. Then a new record 2211 is created in the RET table 2210 which is saved as part of the electronic spreadsheet file, and this new record 2211 is initialized as follows:
• the "Name" field 2212 is set to the value found in the text box 2325 and validated at step 2355;
• the "Last Change Datd' field 2213 is set to the system time reference, as known by the central processor 101 ;
• the "Description Ptf field 2214 is set to the memory location REjouffer which has just been allocated ; - the "Row #' field 2215 is set to the value 1 (as in the preferred embodiment of the present invention the RST's are managed in a 2D environment; this field would carry the number of defined rows for the created RE in a 3D environment) ;
• the "Column #' field 2216 is set to the value of the local variable REjsize ;
• the "Typd' field 2217 is set as follows: the attribute "META" 2218 is set equal to the value of the local variable REjmeta, and the attribute "REFERENCED" 2219 is initialized as follows:
• The "OWN REFERENCE" (OR) subfield 2219a is initialized with a prime number not yet assigned to any other subfield 709a, or 719a, or 729a, or 780a, or 2219a, or 2229a, or 2240a. Various conventional techniques can be used for identifying a prime number, and are not further detailed here. a The "FILIATION REFERENCE" (FR) subfield 2219b is initialized according to the following formula, where the set corresponds to the set of ST's constituting the new RE or meta-element, according to the structure recorded in the "Description Ptf field 2214: FR = π ,ey OR, x LCM({FR,}),S;F
• The "INSTANCE REFERENCE" (IR) subfield 2219c is initialized with the value 1 (one).
• The "REFERENCED OBJECT" (RO) subfield 2219d is initialized with the following formula, where the -Pset corresponds to the set of RST's:
Figure imgf000069_0001
RO = "NO" otherwise. • The "SELECTED CHILDREN" (SC) subfield 2219e is initialized with the following formula, where the s set corresponds to the set of selected objects (having the "SELECTED" attribute 2242 equal to the value "YES" in the RSTMT table 2230):
SC = "YES" if
Figure imgf000069_0002
Mod OR = 0 #OR# RSTEjname e $, SC = "NO" otherwise. Then control is given to step 2350. ° At step 2357, a warning message notification is issued for informing the user that a valid and unique name must be specified in the text box 2325 prior to clicking on the "Save Ad' push-button 2332. This can typically be done by displaying on the display device 106 a warning message in a pop-up window, or in a status bar area, but any other similar means could be used instead, without departing from the spirit of the invention. Once the user has acknowledged this notification message through conventional means such as clicking with the pointing device 105 on an "OK" push-button present within a warning message pop-up window, or any other similar means without departing from the spirit of the invention, control is given to step 2350.
• At step 2358, the local variable REjank is decremented by 1 (one) as long as it remains strictly positive if the user has clicked with the pointing device 106 on the down side of the spin button 2329, and the local variable REjank is incremented by 1 (one) as long as it remains lower than or equal to the value of the local variable REjsize, if the user has clicked with the pointing device 106 on the up side of the spin button 2329. Then control is given to step 2350.
• At step 2359, the local variable REjsize is either incremented or decremented by 1 (one) according to the direction (up or down) specified by the pointing device 105 on the spin button 2327, and as long as it value remains positive and less than or equal to an upper limit set equal to 254 in a preferred embodiment of the present invention. Then control is given to step 2350.
• At step 2360, the local variable REjmeta is updated, so that its value becomes "YES" (respectively "NO") if the bottom option button 2330 (respectively the top option button
2331) has been clicked on. Then control is given to step 2350.
• At step 2361 , the RE Editor Dialog Box 2321 is closed so that it disappears from the display device 106. Finally control is given back to the initial step 2341 for processing any future RE Editor command. E9. STI Column/Row counter method
The method for counting the number of columns or rows within a STI used in the preferred embodiment of the present invention is summarized in flowcharts 2400 and 2420 of FIG 19A and 19B. These methods can be seen as the processing of the STIjRow and STI_col functions. • At step 2401 , the first method is in its default state, waiting for a call to the STIjRow function.
• At step 2402, the STIjRow function call is detected, as a result of a user action. The function is called with two parameters named STjName and STIjΞlement.
• At step 2403, the first record 721 of the STT table 720 is set as CurrjRecord. • At step 2404, the fields Name 722, Min Elements 725, and Max Element* 726 of the record CurrjRecord 721 are respectively set as the local variables CurrJName,
Curr Λin and Curr_Max. a At step 2405, a test is performed to check if the local variable Curr_Name is equal to the function parameter ST Name. If it is the case, then control is given to step 2409; otherwise control is given to step 2406.
• At step 2406, a test is performed to check if the record 721 CurrjRecord is the last record of the STT table 720. If it is the case, then control is given to step 2408; otherwise control is given to step 2407. • At step 2407, the record following CurrjRecord in the STT table 720 becomes the new record 721 CurrjRecord. Then control is given to step 2404.
• At step 2408, the local variable STIjRow is set equal to the value 0 (zero). Then control is given to step 2412. ° At step 2409, the range of cells pointed by the description Ptr field 724 of the record 721 CurrjRecord is set as STDTjaddress. ° At step 2410, the local variable ElementJNbr is set equal to the input parameter STIJΞIement, upper bounded by the local variable CurrJMax, and minored by the local variable CurrjMin. ° At step 2411 , the local variable STI jow is set equal to the number of rows of the range of cells STDTjadress, incremented by the value of the local variable STIjElement, and decremented by 1 (one). β At step 2412, the execution of the STljrow function completes as control is returned to the function caller. e At step 2421, the second method is in its default state, waiting for a call to the STIjCol function.
• At step 2422, the STIjCol function call is detected, as a result of a user action. The function is called with one parameter named STjName .
• At step 2423, the first record 721 of the STT table 720 is set as CurrjRecord. • At step 2424, the field Name 722 of the record CurrjRecord 721 is set as the local variables CurrjName.
• At step 2425, a test is performed to check if the local variable CurrJMame is equal to the function parameter STjName. If it is the case, then control is given to step 2429; otherwise control is given to step 2426. • At step 2426, a test is performed to check if the record 721 CurrjRecord is the last record of the STT table 720. If it is the case, then control is given to step 2428; otherwise control is given to step 2427. At step 2427, the record following CurrjRecord in the STT table 720 becomes the new record 721 CurrjRecord. Then control is given to step 2424. • At step 2428, the local variable STIjRow is set equal to the value 0 (zero). Then control is given to step 2431.
• At step 2429, the range of cells pointed by the description Ptr field 724 of the record 721 CurrjRecord is set as STDTjaddress.
• At step 2430, the local variable STIjool is set equal to the number of columns of the range of cells STDTjadress.
• At step 2431 , the execution of the STIj ol function completes as control is returned to the function caller.
ALTERNATE EMBODIMENTS
The methods and systems according to the present invention may be used advantageously in those environments where elements of information are organized as vertically structured two dimensions tables. The methods and systems according to the present invention may be used advantageously in those environments where elements of information are organized as multidimensional tables having more than two dimensions. While the invention has been particularly shown and described with reference to a preferred embodiment, it will be understood that various changes in form and detail may be made therein without departing from the spirit, and scope of the invention.

Claims

ClaimsWhat is claimed is:
1. A method, in a multi-dimensional electronic data table comprising a plurality of data, for creating one or plurality of recursive scalable template instances; a recursive scalable template instance comprising a variable number of contiguous recursive element instances ordered and aligned along a first data table dimension and structured according to a recursive scalable template; a recursive element instance being defined as comprising one or a plurality of scalable template instances; a scalable template instance comprising a variable number of elements structured according to a scalable template; an element being defined as a range of data; a range of data comprising one or a plurality of data; a recursive scalable template comprising a recursive element comprising one or a plurality of scalable templates; said method comprising for each recursive scalable template instance to create, the steps of:
° Selecting a recursive scalable template; β Defining a location for creating a recursive scalable template instance; β Creating at the defined location one or a plurality of contiguous recursive element instances ordered and aligned along a first data table dimension; each recursive element instance having a variable size along said first data table dimension and a same size along a second data table dimension; • Structuring each recursive element instance according to the recursive element defined for the recursive scalable template;
• Aligning each scalable template instance of each recursive element instance along said first data table dimension;
• ' Aligning within each recursive element instance, each scalable template instance along said second data table dimension.
21. The method according to the preceding claim, said method comprising the preliminary steps of:
• ' Creating or updating one or a plurality of recursive elements; the step of creating or updating one or a plurality of recursive elements, comprising for , each recursive element the further step of:
• Specifying one or a plurality of scalable templates;
• ' Creating or updating one or a plurality of recursive scalable templates, said step comprising for each recursive scalable template, the further step of:
• Specifying a recursive element.
3. The method according to any one of the preceding claims wherein the step of creating a variable number of contiguous and ordered recursive element instances aligned along the first data table dimension, comprises for each recursive element instance the step of:
• Instancing the one or plurality of scalable templates specified in the recursive element specified in the recursive scalable template.
4. The method according to any one of the preceding claims wherein said recursive scalable template instance further comprises a header part and/or a footer part; the header part of the recursive scalable template comprising a predefined number of recursive meta-elements; the footer part of the scalable template comprising a predefined number of recursive meta-elements; a recursive meta-element comprising one or a plurality of scalable templates;said method comprising the further steps of:
• Creating or updating one or a plurality of recursive meta-elements, said step comprising for each recursive meta-elements the further steps of:
, ° Specifying one or a plurality of scalable templates.
5. The method according to any one of the preceding claims wherein the step of creating or updating a recursive scalable template, comprises the further step of:
° Defining a recursive scalable template header part and/or a recursive scalable template footer part,
• the step of defining a recursive scalable template header part comprising the step of: • Specifying with a given order, a predefined number of recursive meta-elements; • the step of defining a recursive scalable template footer part comprising the step of: • Specifying with a given order, a predefined number of recursive meta-elements.
6. The method according to any one of the preceding claims wherein the step of creating a recursive scalable template instance, said recursive scalable template instance comprising a variable number of recursive element instances structured according to a body part of a recursive scalable template, comprises the preliminary step of:
° Creating a predefined number of contiguous and ordered recursive meta-element instances aligned along the first data table dimension, and structured according to the one or plurality of recursive meta-elements specified in the header part of the recursive scalable template.
7. The method according to any one of the preceding claims wherein the step of creating a recursive scalable template instance, said recursive scalable template instance comprising a variable number of recursive element instances structured according to a body part of a recursive scalable template, comprises the subsequent step of: • Creating a predefined number of contiguous and ordered recursive meta-element instances aligned along the first data table dimension, and structured according to the one or plurality of recursive meta-elements specified in the footer part of the recursive scalable template.
8. The method according to the preceding claim comprising, for each recursive element instance and recursive meta-element instance, the step of :
• Adjusting the size of the recursive element instance and recursive meta-element instance along said first data table dimension according to the size of the largest scalable template instance of said recursive element instance and recursive meta-element instance.
9. The method according to any one of the preceding claims wherein the step of creating or updating one or a plurality of recursive elements and optionally one or a plurality of recursive meta-elements, comprises for each recursive element or recursive meta-element the further step of:
• Assigning to the recursive element or recursive meta-element : • An identifier, preferably a name;
• Optionally, a last change date corresponding to the date of the last update; and
• Optionally, a type for determining whether it is a recursive element or a recursive meta-element.
10. The method according to any one of the preceding claims comprising the further step of: • Assigning to each recursive element and recursive meta-element :
• Means for determining whether at least one recursive scalable template refers to the recursive element or recursive meta-element or not;
• Means for determining whether at least one recursive scalable template instance refers to the recursive element or recursive meta-element or not.
11. The method according to any one of the preceding claims wherein the step of creating or updating one or a plurality of recursive scalable templates, comprises for each recursive scalable template, the further step of:
• Assigning to the recursive scalable template:
• An identifier, preferably a name; • Optionally, a last change date corresponding to the date of the last update of the recursive scalable template; and
• Optionally, an indicator specifying if at least one recursive scalable template instance refers to said recursive scalable template.
12. The method according to any one of the preceding claims comprising the further steps of:
° Displaying through a dedicated user interface, identifier, optionally type and optionally date of last update of any existing recursive element, or recursive meta-element, or recursive scalable template; • Detecting a selection by a user of a recursive element, a recursive meta-element, or a recursive scalable template for edition:
• If a recursive element has been selected, editing the selected recursive element;
• If a recursive meta-element has been selected, editing the selected recursive meta-element;
° If a recursive scalable template has been selected, editing the selected recursive scalable template.
13. The method according to any one of the preceding claims comprising the further steps of: ° Displaying through a dedicated user interface, identifier, optionally type and optionally date of last update of any existing recursive element or recursive meta-element or recursive scalable template; ° Detecting a selection by a user of a recursive element, a recursive meta-element, or a recursive scalable template for deletion: • If a recursive element has been selected and if no recursive scalable template refers to said selected recursive element, deleting the selected recursive element;
• If a recursive meta-element has been selected and if no recursive scalable template refers to said selected recursive meta-element, deleting the selected recursive meta-element; • If a recursive scalable template has been selected and if no recursive scalable template instance refers to said selected recursive scalable template, deleting the selected recursive scalable template.
14. The method according to any one of the preceding claims wherein the step of creating or updating one or a plurality of recursive meta-elements comprises the further step of : • Specifying for said recursive meta-elements, a number of scalable templates equal to the number of scalable templates comprised in the recursive element specified for the recursive scalable template.
15. The method according to any one of the preceding claims comprising the further step of
• Creating in a same recursive scalable template instance, contiguous recursive element instances and one or plurality of recursive meta-element instances, said recursive element instances and one or plurality of recursive meta-element instances having a same size along said second dimension.
16. The method according to any one of the preceding claims wherein the step of creating in a same recursive scalable template instance, recursive element instances and one or plurality of recursive meta-element instances, comprises the further step of :
• Aligning each scalable template instance of each recursive element instance and each recursive meta-element instance along said first data table dimension.
17. The method according to any one of the preceding claims wherein the step of creating a recursive scalable template instance, comprises the preliminary step of: • Checking that said recursive scalable template instance does not corrupt any existing recursive scalable template instance or existing scalable template instance on the data table.
18. The method according to any one of the preceding claims wherein said multidimensional electronic data table is an electronic spreadsheet comprising a plurality of cells identified by a cell address along each dimension.
19. The method according to the preceding claim wherein a scalable template instance comprises a variable number of contiguous elements of same size ordered and aligned along a given spreadsheet dimension and structured according to a scalable template; an element being defined as a range of cells; said scalable template comprising an element format and/or an element profile; an element format defining for each cell within each element, one or a plurality of format attributes; an element profile defining a cell content for each cell within each element; said method comprising the further steps of:
• Creating or updating one or a plurality of element formats and/or one or a plurality of elements profiles, the step of creating or updating one or a plurality of element formats, comprising for each element format the further steps of:
• Specifying a format illustrative range of cells;
• Defining for each cell belonging to said format illustrative range of cells, one or a plurality of format attributes; the step of creating or updating one or a plurality of element profiles, comprising for each element profile the further steps of: ° Specifying a profile illustrative range of cells; β Defining for each cell belonging to said profile illustrative range of cells a cell content;
• Creating or updating one or a plurality of scalable templates, said step comprising for each scalable template, the further step of:
0 Specifying an element format and/or an element profile; 0 Creating one or a plurality of scalable template instances, said step comprising for each scalable template instance the further steps of: β Selecting a scalable template;
• Defining a location for creating the scalable template instance;
• Creating at the defined location one or a plurality of contiguous elements ordered and aligned along a given spreadsheet dimension; • Structuring each element according to the element format and/or element profile defined in the scalable template.
20. The method according to the preceding claim wherein the step of defining for each cell belonging to said format illustrative range of cells, one or a plurality of format attributes, comprises the further step of: • Defining for each cell belonging to said format illustrative range of cells, one or a plurality of :
Background attributes; and/or
Alignment attributes; and/or
Font attributes; and/or • Line attributes; and/or
Protection attributes.
21. The method according to any one of claims 19 to 20 wherein the step of defining for each cell belonging to said profile illustrative range of cells, a cell content, comprises the further step of: • Defining for each cell belonging to said profile illustrative range of cells:
• A formula, said formula referring to one or a plurality of cells; or
• A default value.
22. The method according to any one of claims 19 to 21 wherein the step of defining for each cell belonging to said profile illustrative range of cells, a cell content, comprises the further step of:
• Defining for each cell belonging to said profile illustrative range of cells, a cell destination, said cell destination specifying whether the cell is an input cell for receiving an entry or an output cell for producing a result.
23. A computer system comprising means adapted for carrying out the steps of the method according to any one of the preceding claims.
24. A computer program comprising instructions for carrying out the steps of the method according to any one of claims 1 to 22, when said computer program is executed on the system according to the preceding claim.
PCT/EP2004/003048 2003-04-18 2004-02-27 System and method in a data table for creating recursive scalable template instances WO2004092977A2 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
US10/553,494 US7636882B2 (en) 2003-04-18 2004-02-27 System and method in a data table for creating recursive scalable template instances
DE602004003230T DE602004003230T2 (en) 2003-04-18 2004-02-27 System and method in a data table for generating recursive scalable template instances
EP04715322A EP1618491B1 (en) 2003-04-18 2004-02-27 System and method in a data table for creating recursive scalable template instances

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
EP03368037 2003-04-18
EP03368037.2 2003-04-18

Publications (2)

Publication Number Publication Date
WO2004092977A2 true WO2004092977A2 (en) 2004-10-28
WO2004092977A3 WO2004092977A3 (en) 2005-08-18

Family

ID=33186004

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/EP2004/003048 WO2004092977A2 (en) 2003-04-18 2004-02-27 System and method in a data table for creating recursive scalable template instances

Country Status (6)

Country Link
US (1) US7636882B2 (en)
EP (1) EP1618491B1 (en)
CN (1) CN100367275C (en)
AT (1) ATE345533T1 (en)
DE (1) DE602004003230T2 (en)
WO (1) WO2004092977A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2007123456A1 (en) * 2006-04-20 2007-11-01 Sandvik Intellectual Property Ab A tool and a cutting insert for chip removing machining with co-operating primary and secondary engagement means

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE102004007638A1 (en) * 2004-02-17 2005-09-01 Xapio Gmbh A method for generating source code in a procedural, reentrant-capable programming language from a spreadsheet representation
US7500179B2 (en) * 2004-08-04 2009-03-03 Microsoft Corporation Method for optimizing space allocation in table layout
US8024492B2 (en) * 2008-12-23 2011-09-20 Schneider Electric USA, Inc. System for managing a power monitoring system containing a multiplicity of intelligent electronic devices
US8291313B1 (en) * 2009-08-26 2012-10-16 Adobe Systems Incorporated Generation of a container hierarchy from a document design
US20110137917A1 (en) * 2009-12-03 2011-06-09 International Business Machines Corporation Retrieving a data item annotation in a view
US8375012B1 (en) * 2011-08-10 2013-02-12 Hewlett-Packard Development Company, L.P. Computer indexes with multiple representations
US20140075278A1 (en) * 2012-09-12 2014-03-13 International Business Machines Coporation Spreadsheet schema extraction
CN105786299B (en) * 2014-12-22 2019-09-06 远光软件股份有限公司 A kind of information processing method and device
CN109873684B (en) * 2017-12-01 2021-05-18 联发科技股份有限公司 Signal receiving device and signal processing method thereof
CN113688298B (en) * 2021-08-24 2024-08-23 贝壳找房(北京)科技有限公司 Data presentation method and storage medium

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5033009A (en) * 1989-03-03 1991-07-16 Dubnoff Steven J System for generating worksheet files for electronic spreadsheets
US20010049683A1 (en) * 1997-07-04 2001-12-06 Masazumi Yoshikawa Data calculator performing automatic recalculation based on data structure network
WO2003014987A2 (en) * 2001-08-09 2003-02-20 International Business Machines Corporation Spreadsheet system and method for transferring the content of input cells between scalable template instances

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5272628A (en) 1990-04-16 1993-12-21 Microsoft Corporation Method and system for aggregating tables having dissimilar formats
US5613131A (en) 1993-01-29 1997-03-18 Microsoft Corporation Auto-formatting of tables in a spreadsheet program
US5632009A (en) * 1993-09-17 1997-05-20 Xerox Corporation Method and system for producing a table image showing indirect data representations
FR2721728B1 (en) 1994-06-28 1996-07-26 Bull Sa Method and device for automatically generating spreadsheets.
US5754858A (en) 1996-05-01 1998-05-19 Microsoft Corporation Customizable application project generation process and system
US6292811B1 (en) * 1997-09-19 2001-09-18 Modernsoft, Inc. Populating cells of an electronic financial statement
CN1111814C (en) * 1998-04-06 2003-06-18 刘莎 Opening and alli-information template type of language translation method having man-machine dialogue function and all-information semanteme marking system
US7089256B2 (en) * 2000-07-11 2006-08-08 Knowledge Dynamics, Inc. Universal data editor
AU2002222963B2 (en) * 2000-07-13 2007-05-10 Oracle International Corporation Performing spreadsheet-like calculations in a database system
US7051276B1 (en) * 2000-09-27 2006-05-23 Microsoft Corporation View templates for HTML source documents
US6988241B1 (en) * 2000-10-16 2006-01-17 International Business Machines Corporation Client side, web-based spreadsheet
US7246311B2 (en) * 2003-07-17 2007-07-17 Microsoft Corporation System and methods for facilitating adaptive grid-based document layout

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5033009A (en) * 1989-03-03 1991-07-16 Dubnoff Steven J System for generating worksheet files for electronic spreadsheets
US20010049683A1 (en) * 1997-07-04 2001-12-06 Masazumi Yoshikawa Data calculator performing automatic recalculation based on data structure network
WO2003014987A2 (en) * 2001-08-09 2003-02-20 International Business Machines Corporation Spreadsheet system and method for transferring the content of input cells between scalable template instances

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
DJANG R W ET AL: "Similarity inheritance: a new model of inheritance for spreadsheet VPLs" VISUAL LANGUAGES, 1998. PROCEEDINGS. 1998 IEEE SYMPOSIUM ON HALIFAX, NS, CANADA 1-4 SEPT. 1998, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 1 September 1998 (1998-09-01), pages 134-141, XP010297367 ISBN: 0-8186-8712-6 *
HENRION: "WHAT'S WRONG WITH SPREADSHEETS - AND HOW TO FIX THEM WITH ANALYTICA"[Online] 14 July 2004 (2004-07-14), XP002333472 Retrieved from the Internet: URL:http://www.lumina.com/dlana/papers/Wha ts%20wrong%20with%20spreadsheets.pdf> [retrieved on 2005-06-24] *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2007123456A1 (en) * 2006-04-20 2007-11-01 Sandvik Intellectual Property Ab A tool and a cutting insert for chip removing machining with co-operating primary and secondary engagement means
US7510354B2 (en) 2006-04-20 2009-03-31 Sandvik Intellectual Property Ab Tool and a cutting insert for chip removing machining

Also Published As

Publication number Publication date
DE602004003230D1 (en) 2006-12-28
EP1618491B1 (en) 2006-11-15
CN100367275C (en) 2008-02-06
US7636882B2 (en) 2009-12-22
WO2004092977A3 (en) 2005-08-18
US20060206497A1 (en) 2006-09-14
DE602004003230T2 (en) 2007-09-06
ATE345533T1 (en) 2006-12-15
EP1618491A2 (en) 2006-01-25
CN1777887A (en) 2006-05-24

Similar Documents

Publication Publication Date Title
EP1618488B1 (en) System and method in a data table for managing insertion operations in recursive scalable template instances
US7415664B2 (en) System and method in a spreadsheet for exporting-importing the content of input cells from a scalable template instance to another
US7549115B2 (en) System and method for integrated spreadsheets and word processing tables
US8095867B2 (en) System and computer program product for copying and pasting displayed elements of a range of cells in an electronic spreadsheet
US7644133B2 (en) System in an office application for providing content dependent help information
US7143338B2 (en) Method and system in an electronic spreadsheet for handling absolute references in a copy/cut and paste operation according to different modes
US20100199161A1 (en) System and computer program product for displaying and/or hiding a range of cells in an electronic spreadsheet
US20020049784A1 (en) Method and system in an electronic spreadsheet for persistently copy-pasting a source range of cells onto one or more destination ranges of cells
US20030188257A1 (en) System and method in an electronic spreadsheet for displaying and/or hiding range of cells
EP1618491B1 (en) System and method in a data table for creating recursive scalable template instances
US20030188258A1 (en) System and method in an electronic spreadsheet for displaying and/or hiding range of cells
EP1618489B1 (en) System and method in a data table for managing deletion operations in recursive scalable template instances
EP1618490A2 (en) System and method in a data table for exporting and importing recursive scalable templates
Frye Acquisitions Editor: Juliana Aldous Project Editor: Dick Brown Technical Reviewer: Mark Dodge
AU2002337015A1 (en) Spreadsheet system and method for transferring the content of input cells between scalable template instances

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): BW GH GM KE LS MW MZ SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LU MC NL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

DPEN Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed from 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 10553494

Country of ref document: US

WWE Wipo information: entry into national phase

Ref document number: 2004715322

Country of ref document: EP

Ref document number: 20048104359

Country of ref document: CN

WWP Wipo information: published in national office

Ref document number: 2004715322

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 10553494

Country of ref document: US

WWG Wipo information: grant in national office

Ref document number: 2004715322

Country of ref document: EP