站内搜索: 请输入搜索关键词
当前页面: 在线文档首页 > NetBeans API Javadoc 5.0.0

Modules - NetBeans Architecture Questions - NetBeans API Javadoc 5.0.0

NetBeans Architecture Answers for Modules module

WARNING: answering questions version 1.12 rather than the current 1.26.

Interfaces table

Group of java interfaces
Interface NameIn/OutStabilitySpecified in What Document?
ModulesAPIExportedOfficial .../org/openide/modules/doc-files/api.html

UtilitiesAPIImportedOfficial .../org/openide/util/doc-files/api.html

../org-openide-util/overview-summary.html

The module is needed for compilation. The module is used during runtime. Specification version 6.2 is required.

FilesystemsAPIImportedOfficial .../openide/filesystems/doc-files/api.html

CoreModulesAPIExportedFriend .../org/netbeans/core/modules/package.html

Group of property interfaces
Interface NameIn/OutStabilitySpecified in What Document?
netbeans.homeImportedPrivate

NetBeans installation directory.

netbeans.userImportedPrivate

User directory.

netbeans.dirsImportedPrivate

Additional installation component directories.

netbeans.systemclassloader.patchesExportedFriend

Classpath appended to the system class loader. Used for automated testing infrastructure.

netbeans.classpathImportedFriend

May be used to prepend items to the same class loader as is used for openide.jar and core.jar, similarly to JARs found in lib/patches/.

netbeans.cache.manifestsExportedPrivate

By default true, may be turned off to disable manifest caching.

netbeans.patches.MODULE.CODE.NAME.BASEExportedFriend

Patch directories or JARs to add to the class loader for a module, besides patches/MODULE-CODE-NAME-BASE/*.jar.

netbeans.preresolve.classesExportedPrivate

If true, all module classes are forcibly loaded at startup, to help detect possible linkage errors.

org.netbeans.core.modules.NbInstaller.noAutoDepsExportedPrivate

Disables automatic module dependency upgrades.

org.netbeans.core.modulesExportedPrivate

If set to 0, enables logging for the module system.

org.netbeans.core.modules.NbInstaller.NO_COMPAT_AUTO_TRANSITIVE_DEPSExportedPrivate

Disabled automatic transitive class loader dependencies for old modules.

netbeans.modules.quietExportedPrivate

Avoids text messaging (other than ErrorManager logging) to the console from the module system.

netbeans.moduleitem.dontverifyclassloaderExportedPrivate

Suppresses checks to ensure that module section classes are actually loaded from the module itself.

netbeans.full.hackImportedFriend

Avoids using GUI when user-visible error conditions occur.

netbeans.mainclassImportedFriend

Name of class from core.jar which will handle most of the startup sequence; by default, org.netbeans.core.Main.

netbeans.security.nocheckExportedFriend

Suppress security checks in the VM, even from "untrusted" code.

netbeans.classloader.verboseExportedPrivate

Prints messages when resources or classes are loaded from JARs.

netbeans.cache.layersExportedPrivate

Used to control the XML layer cache mechanism. Value may be a fully-qualified class name to load as a manager (implement org.netbeans.core.projects.cache.LayerCacheManager), or - to disable caching and always parse the XML layers directly. Current default is to use a binary cache manager.

Group of dtd interfaces
Interface NameIn/OutStabilitySpecified in What Document?
module-status-1_0.dtdExportedUnder Development .../dtds/module-status-1_0.dtd

-//NetBeans//DTD Module Status 1.0//EN

module-auto-deps-1_0.dtdExportedUnder Development .../dtds/module-auto-deps-1_0.dtd

-//NetBeans//DTD Module Automatic Dependencies 1.0//EN

filesystem-1_1.dtdExportedStable .../www.netbeans.org/dtds/filesystem-1_1.dtd

-//NetBeans//DTD Filesystem 1.1//EN


General Information

    Question (arch-what): What is this project good for?

    Answer: The Modules API lies at the core of NetBeans and describes how plug-in modules are added and managed. ModulesAPI

    Question (arch-overall): Describe the overall architecture.

    WARNING: Question with id="arch-overall" has not been answered!

    Question (arch-usecases): Describe the main use cases of the new API. Who will use it under what circumstances? What kind of code would typically need to be written to use the module?

    WARNING: Question with id="arch-usecases" has not been answered!

    Question (arch-time): What are the time estimates of the work?

    WARNING: Question with id="arch-time" has not been answered!

    Question (arch-quality): How will the quality of your code be tested and how are future regressions going to be prevented?

    WARNING: Question with id="arch-quality" has not been answered!

    Question (arch-where): Where one can find sources for your module?

    WARNING: Question with id="arch-where" has not been answered!

Project and platform dependencies

    Question (dep-nb): What other NetBeans projects and modules does this one depend on?

    Answer: UtilitiesAPI And in the implementation only: FilesystemsAPI

    Default answer to this question is:

    These modules are required in project.xml file:

    • UtilitiesAPI - The module is needed for compilation. The module is used during runtime. Specification version 6.2 is required.

    Question (dep-non-nb): What other projects outside NetBeans does this one depend on?

    Answer: None, other than any available SAX parser.

    Question (dep-platform): On which platforms does your module run? Does it run in the same way on each?

    Answer: Any.

    Question (dep-jre): Which version of JRE do you need (1.2, 1.3, 1.4, etc.)?

    Answer: 1.3

    Question (dep-jrejdk): Do you require the JDK or is the JRE enough?

    Answer: JRE

Deployment

    Question (deploy-jar): Do you deploy just module JAR file(s) or other files as well?

    Answer: The API portion is inside openide.jar; the implementation refers to this and is inside core.jar.

    Question (deploy-nbm): Can you deploy an NBM via the Update Center?

    Answer: Yes (as part of openide.nbm and core.nbm).

    Question (deploy-shared): Do you need to be installed in the shared location only, or in the user directory only, or can your module be installed anywhere?

    Answer: Must be installed in the shared location as it is part of the very core of NetBeans.

    Question (deploy-packages): Are packages of your module made inaccessible by not declaring them public?

    Answer:

    The entire API is one public package. ModulesAPI

    The implementation is in another package and is not considered public, though it is made available to autoupdate and apisupport as these special modules deal directly with the module system at a deeper level than the API provides for. CoreModulesAPI

    Question (deploy-dependencies): What do other modules need to do to declare a dependency on this one?

    WARNING: Question with id="deploy-dependencies" has not been answered!

Compatibility with environment

    Question (compat-i18n): Is your module correctly internationalized?

    Answer: Yes

    Question (compat-standards): Does the module implement or define any standards? Is the implementation exact or does it deviate somehow?

    Answer: It defines and implements the Modules API. No intentional deviations.

    Question (compat-version): Can your module coexist with earlier and future versions of itself? Can you correctly read all old settings? Will future versions be able to read your current settings? Can you read or politely ignore settings stored by a future version?

    Answer: Backward compatibility of setting storage for the list of configured modules is considered a design priority. The implementation of the Modules API uses an XML format to store this list; it has an associated versioned DTD, and the 1.0 format additionally supports expansion through arbitrary named parameters. Also, the modules themselves can be considered settings in that a user directory may contain them, so backward compatibility of the directory layout is maintained.

Access to resources

    Question (resources-file): Does your module use java.io.File directly?

    Answer:

    Yes, module JARs and associated resource JARs must be real files. They are loaded as defined by module enablement XML files.

    Module enablement XML files are loaded via Filesystems. The public API (partially) specifies them only in these terms. autoupdate uses Filesystems to manipulate them when necessary, though it relies on some additional implementation-specific knowledge of their format (which is fairly stable, especially since changes are limited by compatibility constraints on old user directories). The NetBeans build scripts use some additional implementation knowledge to pregenerate suitable XML files for modules included in the application distribution.

    Question (resources-layer): Does your module provide own layer? Does it create any files or folders in it? What it is trying to communicate by that and with which components?

    Answer: The Modules API defines some layer folders:
    • Modules/*.xml (read from and written to)
    • ModuleAutoDeps/*.xml (only read from)

    Question (resources-read): Does your module read any resources from layers? For what purpose?

    Answer: XML files are read from the two folders defined by the API. Note however that since these folders control the module system itself, contents generally should not be placed in module layers, but in the system/ subfolder of the installation or user directory (generally, in the NBM).

    Question (resources-mask): Does your module mask/hide/override any resources provided by other modules in their layers?

    Answer: No.

Lookup of components

    Question (lookup-lookup): Does your module use org.openide.util.Lookup or any similar technology to find any components to communicate with? Which ones?

    Answer: All registered InstalledFileLocator instances are queried and used to implement InstalledFileLocator.getDefault().

    Question (lookup-register): Do you register anything into lookup for other code to find?

    Answer:
    • TestModuleDeployer (from META-INF), used by apisupport
    • InstalledFileLocator (from META-INF), used by its public default method
    • an instance of every known ModuleInfo, via a custom lookup insertion (specified in API)
    • an instance of ClassLoader, via a custom lookup insertion (used broadly)

    Question (lookup-remove): Do you remove entries of other modules from lookup?

    Answer: No.

Execution Environment

    Question (exec-property): Is execution of your code influenced by any environment or Java system (System.getProperty) property?

    Answer: netbeans.home - NetBeans installation directory. netbeans.user - User directory. netbeans.dirs - Additional installation component directories. netbeans.systemclassloader.patches - Classpath appended to the system class loader. Used for automated testing infrastructure. netbeans.classpath - May be used to prepend items to the same class loader as is used for openide.jar and core.jar, similarly to JARs found in lib/patches/. netbeans.cache.manifests - By default true, may be turned off to disable manifest caching. netbeans.patches.MODULE.CODE.NAME.BASE - Patch directories or JARs to add to the class loader for a module, besides patches/MODULE-CODE-NAME-BASE/*.jar. netbeans.preresolve.classes - If true, all module classes are forcibly loaded at startup, to help detect possible linkage errors. org.netbeans.core.modules.NbInstaller.noAutoDeps - Disables automatic module dependency upgrades. org.netbeans.core.modules - If set to 0, enables logging for the module system. org.netbeans.core.modules.NbInstaller.NO_COMPAT_AUTO_TRANSITIVE_DEPS - Disabled automatic transitive class loader dependencies for old modules. netbeans.modules.quiet - Avoids text messaging (other than ErrorManager logging) to the console from the module system. netbeans.moduleitem.dontverifyclassloader - Suppresses checks to ensure that module section classes are actually loaded from the module itself. netbeans.full.hack - Avoids using GUI when user-visible error conditions occur. netbeans.mainclass - Name of class from core.jar which will handle most of the startup sequence; by default, org.netbeans.core.Main. netbeans.security.nocheck - Suppress security checks in the VM, even from "untrusted" code. netbeans.classloader.verbose - Prints messages when resources or classes are loaded from JARs. netbeans.cache.layers -

    Used to control the XML layer cache mechanism. Value may be a fully-qualified class name to load as a manager (implement org.netbeans.core.projects.cache.LayerCacheManager), or - to disable caching and always parse the XML layers directly. Current default is to use a binary cache manager.

    Question (exec-component): Is execution of your code influenced by any (string) property of any of your components?

    Answer: No.

    Question (exec-ant-tasks): Do you define or register any ant tasks that other can use?

    WARNING: Question with id="exec-ant-tasks" has not been answered!

    Question (exec-classloader): Does your code create its own class loader(s)?

    Answer: The implementation creates one class loader for each enabled module, plus a special "system" class loader.

    Question (exec-reflection): Does your code use Java Reflection to execute other code?

    Answer: Of course components present in modules are initially loaded using reflection. Otherwise there is little semantic use of it (transparent optimizations only). One exception: pending a solution to #29382, one portion of the Filesystems API is accessed via reflection when merging XML layers from modules.

    Question (exec-privateaccess): Are you aware of any other parts of the system calling some of your methods by reflection?

    Answer: No.

    Question (exec-process): Do you execute an external process from your module? How do you ensure that the result is the same on different platforms? Do you parse output? Do you depend on result code?

    WARNING: Question with id="exec-process" has not been answered!

    Question (exec-introspection): Does your module use any kind of runtime type information (instanceof, work with java.lang.Class, etc.)?

    WARNING: Question with id="exec-introspection" has not been answered!

    Question (exec-threading): What threading models, if any, does your module adhere to?

    WARNING: Question with id="exec-threading" has not been answered!

    Question (security-policy): Does your functionality require modifications to the standard policy file?

    WARNING: Question with id="security-policy" has not been answered!

    Question (security-grant): Does your code grant additional rights to some other code?

    WARNING: Question with id="security-grant" has not been answered!

Format of files and protocols

    Question (format-types): Which protocols and file formats (if any) does your module read or write on disk, or transmit or receive over the network? Do you generate an ant build script? Can it be edited and modified?

    Answer:
    • Module JAR files, as specified by the Modules API
    • module-status-1_0.dtd - -//NetBeans//DTD Module Status 1.0//EN
    • module-auto-deps-1_0.dtd - -//NetBeans//DTD Module Automatic Dependencies 1.0//EN
    • filesystem-1_1.dtd - -//NetBeans//DTD Filesystem 1.1//EN
    • a custom binary format for caching merged layer contents
    • a custom binary format for caching module manifests
    • a custom binary (serialized) format for caching folder lookup
    • Java serialization for externalized ModuleInstalls (deprecated)

    Question (format-dnd): Which protocols (if any) does your code understand during Drag & Drop?

    Answer: N/A

    Question (format-clipboard): Which data flavors (if any) does your code read from or insert to the clipboard (by access to clipboard on means calling methods on java.awt.datatransfer.Transferable?

    Answer: N/A

Performance and Scalability

    Question (perf-startup): Does your module run any code on startup?

    Answer: Yes, of course - it finds and loads all modules.

    Question (perf-exit): Does your module run any code on exit?

    Answer: Delegates to exit handlers of enabled modules. Saves lookup cache.

    Question (perf-scale): Which external criteria influence the performance of your program (size of file in editor, number of files in menu, in source directory, etc.) and how well your code scales?

    Answer: Scalability of the standalone system seems reasonably good; even with a thousand modules (an order of magnitude higher than current reality) startup time and memory consumption in the module system itself are not large (7 seconds, 6 Mb).

    Question (perf-limit): Are there any hard-coded or practical limits in the number or size of elements your code can handle?

    Answer: No.

    Question (perf-mem): How much memory does your component consume? Estimate with a relation to the number of windows, etc.

    Answer: Not a lot. On modules which are well-formed (layers, JAR entries, complex interdependencies) but which do not run any code there is a modest incremental cost: 3.1msec and 4.5Kb per module at least measurement.

    Question (perf-wakeup): Does any piece of your code wake up periodically and do something even when the system is otherwise idle (no user interaction)?

    Answer: No.

    Question (perf-progress): Does your module execute any long-running tasks?

    Answer: Bulk module installation can be time-consuming. org.netbeans.core.ui.ModuleBean is a Swing-safe bean that serves as a nonblocking wrapper for all module system modifications and is used e.g. in the Modules node.

    Question (perf-huge_dialogs): Does your module contain any dialogs or wizards with a large number of GUI controls such as combo boxes, lists, trees, or text areas?

    Answer: No. Occasionally small dialogs only.

    Question (perf-menus): Does your module use dynamically updated context menus, or context-sensitive actions with complicated and slow enablement logic?

    Answer: No.

    Question (perf-spi): How the performance of the plugged in code will be enforced?

    WARNING: Question with id="perf-spi" has not been answered!

Built on May 3 2007.  |  Portions Copyright 1997-2005 Sun Microsystems, Inc. All rights reserved.