Difference between revisions of "Documentation/DevGuide/Basic/Library File Structure"

From Apache OpenOffice Wiki
Jump to: navigation, search
m (1 revision(s))
 
(4 intermediate revisions by 2 users not shown)
Line 5: Line 5:
 
|NextPage=Documentation/DevGuide/Basic/Application Library Container
 
|NextPage=Documentation/DevGuide/Basic/Application Library Container
 
}}
 
}}
{{DISPLAYTITLE:Library File Structure}}
+
{{Documentation/DevGuideLanguages|Documentation/DevGuide/Basic/{{SUBPAGENAME}}}}
 +
{{DISPLAYTITLE:Library File Structure}}
 
This section describes how libraries are stored. Generally all data is stored in XML format. Four different XML document types that arespecified in the DTD files installed in ''<OfficePath>/share/dtd/officedocument'' are used:
 
This section describes how libraries are stored. Generally all data is stored in XML format. Four different XML document types that arespecified in the DTD files installed in ''<OfficePath>/share/dtd/officedocument'' are used:
  
 
* A library container is described by a library container index file following the specification given in ''libraries.dtd''. In this file, each library in the library container is described by its name, a flag if the library is a link, the StorageURL (describing where the library is stored) and, only in case of a link, the link read-only status.
 
* A library container is described by a library container index file following the specification given in ''libraries.dtd''. In this file, each library in the library container is described by its name, a flag if the library is a link, the StorageURL (describing where the library is stored) and, only in case of a link, the link read-only status.
 
* A library is described by a library index file following the specification given in ''library.dtd''. This file contains the library name, a flag for the read-only status, a flag if the library is password protected (see below) and the name of each library element.
 
* A library is described by a library index file following the specification given in ''library.dtd''. This file contains the library name, a flag for the read-only status, a flag if the library is password protected (see below) and the name of each library element.
* A Basic source code module is described in a file following the specification given in ''module.dtd''. This file contains the module name, the language (at the moment only {{PRODUCTNAME}} Basic is supported) and the source code.
+
* A Basic source code module is described in a file following the specification given in ''module.dtd''. This file contains the module name, the language (at the moment only {{AOo}} Basic is supported) and the source code.
 
* A dialog is described in a file following the specification given in ''dialog.dtd''. The file contains all data to describe a dialog. As this format is extensive, it is not possible to describe it in this document.
 
* A dialog is described in a file following the specification given in ''dialog.dtd''. The file contains all data to describe a dialog. As this format is extensive, it is not possible to describe it in this document.
  
 
Additionally, a binary format is used to store compiled Basic code for password protected Basic libraries. This is described in more detail in [[Documentation/DevGuide/Basic/Library File Structure|Library File Structure]].
 
Additionally, a binary format is used to store compiled Basic code for password protected Basic libraries. This is described in more detail in [[Documentation/DevGuide/Basic/Library File Structure|Library File Structure]].
  
{{Documentation/Caution|In a password protected Basic library, the password is used to scramble the source code using the Blowfish algorithm. The password itself is not stored, so when the password for a Basic library is lost, the corresponding Basic source code is lost also. There is ''no'' retrieval method if this happens.}}
+
{{Warn|In a password protected Basic library, the password is used to scramble the source code using the Blowfish algorithm. The password itself is not stored, so when the password for a Basic library is lost, the corresponding Basic source code is lost also. There is ''no'' retrieval method if this happens.}}
  
 
Besides the XML format of the library description files, it is necessary to understand the structure in which these files are stored. This is different for application and document libraries. Application libraries are stored directly in the system file system and document libraries are stored inside the document's package file. <!-- For information about package files, see [[Documentation/DevGuide/OfficeDev/Package File Formats|Package File Formats]]. INVALID LINK --> The following sections describe the structure and combination of library container and library structures.
 
Besides the XML format of the library description files, it is necessary to understand the structure in which these files are stored. This is different for application and document libraries. Application libraries are stored directly in the system file system and document libraries are stored inside the document's package file. <!-- For information about package files, see [[Documentation/DevGuide/OfficeDev/Package File Formats|Package File Formats]]. INVALID LINK --> The following sections describe the structure and combination of library container and library structures.
  
 
{{PDL1}}
 
{{PDL1}}
[[Category: Basic and Dialogs]]
+
 
 +
[[Category:Documentation/Developer's Guide/Basic and Dialogs]]

Latest revision as of 13:16, 21 December 2020



This section describes how libraries are stored. Generally all data is stored in XML format. Four different XML document types that arespecified in the DTD files installed in <OfficePath>/share/dtd/officedocument are used:

  • A library container is described by a library container index file following the specification given in libraries.dtd. In this file, each library in the library container is described by its name, a flag if the library is a link, the StorageURL (describing where the library is stored) and, only in case of a link, the link read-only status.
  • A library is described by a library index file following the specification given in library.dtd. This file contains the library name, a flag for the read-only status, a flag if the library is password protected (see below) and the name of each library element.
  • A Basic source code module is described in a file following the specification given in module.dtd. This file contains the module name, the language (at the moment only Apache OpenOffice Basic is supported) and the source code.
  • A dialog is described in a file following the specification given in dialog.dtd. The file contains all data to describe a dialog. As this format is extensive, it is not possible to describe it in this document.

Additionally, a binary format is used to store compiled Basic code for password protected Basic libraries. This is described in more detail in Library File Structure.

Documentation caution.png In a password protected Basic library, the password is used to scramble the source code using the Blowfish algorithm. The password itself is not stored, so when the password for a Basic library is lost, the corresponding Basic source code is lost also. There is no retrieval method if this happens.

Besides the XML format of the library description files, it is necessary to understand the structure in which these files are stored. This is different for application and document libraries. Application libraries are stored directly in the system file system and document libraries are stored inside the document's package file. The following sections describe the structure and combination of library container and library structures.

Content on this page is licensed under the Public Documentation License (PDL).
Personal tools
In other languages