© Copyright International Business Machines Corporation 2000, 2005. All rights reserved. US Government Users Restricted Rights - Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
1.0 About this releaseTo view the latest version of this file, see the release notes at www3.software.ibm.com/ibmdl/pub/software/rationalsdp/rwd/6011/html/readme_6011.html.
This file is available in the following national languages:
Brazilian Portuguese Chinese - Simplified Chinese - Traditional French German Italian Japanese Korean Spanish IBM® Rational® Web Developer Fix Pack 6.0.1.1 contains fixes to the version 6.0.1 release and the following enhancements:
EGL Builder performance improvements
The performance of the EGL Builder has been drastically improved. You can expect to see significant improvements in the amount of time required to build an entire workspace and in the amount of time required to build individual parts as they are being developed. In the past if you normally had the "Build automatically" preference turned off, try working with it turned on.
The first time each project is built using version 6.0.1.1 of EGL, the .project file, which is located in the root directory of the project, will automatically be modified so that it references the new EGL Builder. After this update has been completed, all future builds of the project will use the new EGL Builder. It is recommended that users manually invoke a build after starting V6.0.1.1 and loading the workspace, so that the projects will have been built with the new EGL Builder before future development takes place. A manual build can be invoked by selecting Project >Build All from the toolbar.
Note: If the option to Build Automatically is enabled, a project will be changed to use the new EGL Builder the first time version 6.0.1.1 of the product is started for an existing workspace or after a project is imported in both new and existing workspaces. If the option to Build Automatically is disabled, it is necessary to invoke a build manually to migrate to the new EGL Builder. All new projects created with version 6.0.1.1 of the product will already be configured to use the new EGL Builder.
New EGL Problem Types
As part of the builder performance improvements, new problem types have been created for EGL. These problem types are used when displaying errors in the Problems view. After installing V6.0.1.1, it may be necessary to update the Problems View so that these new problem types are displayed correctly. To update the view, select the Filters option from the Problems View drop down menu. In the dialog that is displayed, make sure that the following types have been selected (you will need to scroll the table to find the EDT entries):
- EDT Context Specific Problem
- EDT File Problem
- EDT Problem
- EDT Syntax Problem
Message Differences
As part of the builder performance improvements, an effort was made to be more consistent with regards to the validation error messages that are issued. While all of the same error conditions are caught, it is possible you may see a different number of error messages than before. Also, the text of the messages issued may not be the same as before. Previously, when validating referenced functions from a part (program, library, etc) which invoked the function, all error messages were placed on the function invocation statement. These error messages are now placed in the invoked function on the specific line where the error occurred. Each error message contains the name of the invoking part. This makes it much easier to find the reason for the error.
Use Form Syntax Change
As part of the builder performance improvements, we have made changes in how we process forms. However, this may cause ambiguity errors in the case where a form group has like-named fields on multiple forms and a program has unqualified references to those fields.We have added a new "Use forms" syntax so the customer can specify which forms to look at during name resolution.
use <formgroup-name>.<form-name>, <formgroup-name.form-name>, etc.If you have new validation errors related to resolving form fields, to fix the problems you can either fully qualify your references to the form fields or you can use a new action called "Organize Used Forms". This action analyzes the program to see what forms are actually used and then creates the appropriate Use statement. This action is available on the context menu for an EGL project, EGL package, and EGL file. It is also available from the context menu of the EGL Editor. If there are serious errors with the program, such as a syntax error, unresolved use statements, or using multiple non-help form groups, this action puts up a message saying that it can not run due to errors in the program, and no changes will be applied. However, this action does work when there are other errors, such as the ambiguity error that this action is meant to fix. If there are serious enough errors where EGL does not recognize an I/O statement, this action can not detect the form on that statement and the results may not include all the forms used. Thus, other than the ambiguity error, it is recommended that this action is run with a cleanly compiled program.
Note: useformGroup is still supported and can be used. It is a short cut for listing every form in the form group on the use statement.
EGL SQL Retrieve option for COBOL compatibility
At EGL declaration time, you can use the SQL retrieve feature to create an SQL record from the columns of an SQL table. If you want new SQL records to be compatible with COBOL programs (that is, to have fixed records with level numbers for structure items, and to use CHAR instead of STRING primitive types), select the Create COBOL compatible record definition check box on the SQL Retrieve Preferences window.
JSF Table's Row Edit button label can be customized
Three new Row Edit attributes added to allow button label customization, editLabel for the Edit button label, saveLabel for the Save button label and cancelLabel for the Cancel button label.
This fix pack includes Rational Web Developer version 6.0.1 and the following interim fixes:
(PK12617) When stopping at a breakpoint the debugger performs an inefficient search for the Java source.
- (PK12468) A NullPointerException is thrown when a union is used in the select statement.
- (PK13735) A clob item object of size greater than 8k when written to a file resource does not contain all the data in the clob item.
- (PK15122) When using an SCM system, an eglbld file cannot be modified after check out.
- (PK11964) EGLCMD gives an error complaining about the command file not being found
- (PK14282) Some runtime messages use the language specified using the vgj.nls.code runtime property. Other runtime messages were in the language of the default locale regardless of how the vgj.nls.code was set.
- (PK14107) The Value of a target item remains unchanged on an assignment operation which causes a user overflow error.
- (PK13732) The System function: loblib.attachClobToFile does not produce the expected behavior according to the documentation.
- (PK13842) Cannot dynamically set the destHost and destPort values similar to how you set the userid and password values in the EGL generation wizard and the EGLCMD/EGLSDK commands.
- (PK13149) Setting the MODIFIED attribute of an AUTOSKIP field does not remove the AUTOSKIP.
- (PK13303) Cannot return German date format after applying appropriate properties and date mask values within an eglbld file.
- (PK14663) Add import statements for all tables; add use declarations for message tables used in statements.
- (PK10269) Need to handle subapplications for Smalltalk.
- (PK14662) Negative sign displaying because form field has no sign property defined.
- (PK09523) The Deploy option is greyed out for EJB projects when viewed from the Java perspective.
- (PK09536) If a module contained in an EAR does not have an entry in the module maps file, it throws a null pointer exception when trying to add a new module.
- (PK04446) For a Web project that references a Java project as a Web library project, when creating the WAR file (either by exporting the EAR or by exporting the WAR directly), the created WAR file contains extra metadata files that should be omitted.
- (PK10262) Running a Web application on the server without building the workspace results in missing classes.
- (JR22375) WAR files are not imported properly.
- (PK10262) Web library classes fail to load on a WebSphere Application Server 5.x.
- (PK09191) There is a null pointer error using EJBs with JSF.
- (PK14576) The Web service resource is generated outside of Eclipse and the synchronization fails.
- (PK13756) A headless Ant build generates exceptions.
- (PK10740) The life cycle listener wizard fails to load if either no dynamic Web projects exist in the workspace, or something other than a dynamic Web project was selected prior to opening the wizard.
- (PK10767) If an EJB project has two source folders, only the first source folder that was found is recognized in the ejb-jar.xml file.
- (PK08976) Invalid handle after modifying the context root for a J2EE 1.2 project.
- (PK12579, PK12623) EJB relationship editor incorrectly shows the foreign keys on the wrong side.
- (PK12738) The classpath of an imported EJB project is not set correctly.
- (PK12364) Adding an EJB reference results in a duplicate entry being added in the classpath.
- (PK11260) The EAR deployment descriptor can get out of synch if you modify the xml files outside of the workspace editors.
- (PK12340) Attributes are not being read from the session variables. They can only be read from the properties file.
- (PK11618) Radio button groups cannot refresh correctly.
- (PK09168) Synchronization between JSP files and the Properties view does not update the property values correctly.
- (PK06790) Mailto links cannot be used in a JSF portlet.
- (PK12852) Tabbed panels require that forms be located within the tab.
- (PK13145) When client-side validation is enabled for an JSF inputText field of type date/time and the format of the field did not include "dd" (day of month), an input value fails validation.
- (PK13702) When a file is being uploaded with fileupload, no more Faces requests can complete their cycle until file upload completes.
- (PK09669) If you try to change dynamically the read-only property of an inputRichText, the value will always appear in read-only mode at run time.
- (PK13876) Enabling client side caching disables decode method .
- (PK09580) Some Javascript functions do not work with the <h:inputrichtext> custom tag.
- (PK09629) A warning occurs when dropping a <h:inputrichtext> onto a JSP file.
- (PQ99999, PK11184) Even when h:commandLink components are rendered="false", the separator bars are still rendered.
- (PK12914) Cannot assign default values to fields in a new row when it is added to the datagrid.
- (PK12362) There is a problem with enctype in JSF pages.
- (PK09633 ) The <r:inputrichtext> tag produces incorrect output.
- (PK07608) Fields with MaskConverter cause a conversion error if the field is left empty.
- (PK07517) Browser error 500 occurs if the rows attribute is not set on a datatable when a gotopager is used.
- (PK14376) There is a problem with a JSF multi-part form and DBCS characters on Solaris.
- (PK15481) A file name containing a semicolon entered into the file upload component gets truncated when submitted.
- A table caption can now be added using a 'caption' facet containing an outputText component, for example:
<h:dataTable id="table1" value="#{tabledat}" var="vartabledat">
<f:facet name="caption">
<h:outputText value="text" styleClass="className" />
</f:facet>
.......rest of table.....
</h:dataTable>- Scope, axis and dir attributes can now be rendered using the f:attribute tag within the h:column component. Scope and axis attributes will just be applied to cells within then body of the table. Dir attribute will be applied to body, header and footer cells of the rendered column usage , for example:
<h:column id="column1">
<f:attribute value="row" name="scope" />
<f:attribute value="Price" name="axis" />
<f:attribute value="ltr" name="dir" />
columnn contents.....
</h:column>
- (JR22105) JSF page template cannot be displayed in the Preview page.
- (JR22052) Adding a non-breaking space into a JSP file causes a JSP:translate error.
- (PK13434) When entering text into a JSP file, the text is entered backwards.
- (PK03176) The *+xml mime type is not interpreted as XML content in a JSP file.
- (PK13014) An included JSPF fragment is underlined as an error with misleading hover text.
- (PK12573) A broken link appears for Struts tags containing dynamic expressions.
- (PK11225) An incorrect method is used to setthe value in the Validate field drop-down list
- (PK13382) A StringIndexOutOfBound exception occures during a build of a Struts-enabled Web project.
- (PK12117) There is an unrealized Struts action in a Web diagram.
- (JR21675) When creating a dynamic Web project with Struts enabled, the <bean:message /> tag in a JSP file does not work when the project is checked into Rational ClearCase® LT.
- (PK12387) A Struts config build using Rational ClearCase does not end.
- (PK11332) When referencing a remote server for XSL files, the validator is not using the correct base location.
- (PK13522) When an XML schemas has circular includes, attempting to map one schema to another causes a StackOverflow message.
- (PK12796) When validating XML documents that make use of the SOAP encoding schema, these documents may be marked as not valid.
There is now support for using the DB2® Universal JDBC Driver |for building Java stored procedures which have source larger than 32K |and target a DB2 UDB for z/OS V7 server. Before this support was added, the Universal Driver was supported only for DB2 UDB z/OS V8 Java stored procedures. In order for this support to work, you must install DB2 for z/OS V7 APAR (PK01445).
(PK10862) When using the WebSphere test environment v6, the Add and Remove Projects option with ClearCase views fails using a WAR file with a Web library project.
For information about installing IBM Rational Web Developer Fix Pack 6.0.1.1, installation prerequisites, installing from a command line, and setting up a local mirror of the update server, see the installation instructions at www3.software.ibm.com/ibmdl/pub/software/rationalsdp/rwd/60/install_instruction/6011/install.html.
For hardware requirements for this fix pack, refer to the installation instructions.
This fix pack can be installed on top of IBM Rational Web Developer 6.0, 6.0.0.1, or 6.0.1.
If you use local updates and have more than one product installed, you must download the 6.0.1.1 fix packs for all installed products to your local update site. This is because there are dependencies among them. If you have multiple products installed and download only one fix pack and run the Rational Product Updater, the Updater will give you a warning when you search for updates that one of the required updates is missing. Again, this situation only applies to customers who use local update sites.
To simultaneously install the fix packs, download them to your local update site. Then install all fix packs at the same time from the update site by using the Rational Product Updater.
For example, suppose you have both Rational Application Developer and Rational Software Modeler installed on your system. Because the fix packs for these products depend on each other, they must be installed at the same time. Download both fix packs to your local update site and run the Rational Product Updater to update your installation.
The version 6.0.1 documentation failed to include the following limitations and recommendations for the EGLSDK and EGLCMD commands.
For both:
- To work around an OutOfMemoryError when running either EGLSDK or EGLCMD, try increasing the JVM heap size. Use the following command:
java [-msstart_sizem] -mxmax_sizem application
start_size
An optional beginning size, in megabytes, for the JVM heap used in running application.
max_size
The maximum JVM heap size, in megabytes, to be used in running application. This should not be greater than half the RAM available to the system.
application
Either EGLSDK or EGLCMD, followed by its usual parameters.
The following example assumes the system has 2GB RAM available:
java -ms512m -mx1024m EGLCMD EGLListDetailForTUI/EGLCommandFile.xml -data D:\WorkSpaceFor EGLSDK:
- Make sure that emfworkbenchedit.jar is in your Java classpath. The jar file is in the following directory:
installationDir\rwd\eclipse\plugins\com.ibm.wtp.emf.workbench.edit_version\emfworkbenchedit.jarinstallationDir
The product installation directory, such as C:\Program Files\IBM\RSPD\6.0. If you installed and kept a Rational Developer product before installing the product that you are using now, you may need to specify the directory that was used in the earlier install.
version
The installed version of the plugin; for example, 1.0.0- If you wish to enable COBOL generation for either z/OS® or iSeries™, make sure that the runtime jar file eglgencobol.jar is in your class path. The jar file is in the following directory:
installationDir\egl\eclipse\plugins\com.ibm.etools.egl.batchgeneration_versioninstallationDir
The product installation directory, such as C:\Program Files\IBM\RSPD\6.0. If you installed and kept a Rational Developer product before installing the product that you are using now, you may need to specify the directory that was used in the earlier install.
version
The installed version of the plugin; for example, 6.0.0
- EGL does not support the generation of pageHandlers from the SDK. To create pageHandlers in batch mode, use EGLCMD.
For EGLCMD:
- Close all instances of the workbench UI before executing EGLCMD from a command prompt.
- If you use the wizard to create the command file, do not move that command file to another directory. The command file must be in the workspace containing the parts EGL is using to generate code.
- Use the -data option to specify the workspace for EGLCMD. Otherwise EGL will use the default workspace, which may not be the one you want.
- When you generate a pageHandler with EGLCMD, be sure to use the build descriptor option genProject. This allows EGL to handle all the J2EE deployment information automatically.
- If you use EGLCMD and the genDirectory build descriptor option for a project that contains no Web components, EGL will compile the programs outside the workbench. For this reason the Java compiler (javac.exe) must be in the system path and the EGL Java generation code (eglbatchgen.jar, in the bin directory of your installation directory) must be in the system classpath.
- If you are generating for iSeries, you may also need to put xml.jar on your classpath (you will find it in eclipse\jre\lib in you installation directory). Because having too many items in the classpath for EGLCMD can also cause problems, you should have only these four files in your classpath to generate for the iSeries: eglutil.jar, startup.jar, eglbatchgen.jar, and xml.jar.
- If you do generate pageHandlers using EGLCMD, you must update the faces-config.xml manually with managed-bean and navigation-rule entries in order for the page handler to run correctly.
Starting with version 6.0.1.1, you can create arrays of any type of record, as long as you are generating Java. If you generate COBOL, the old rule still applies: you can only make an array of Basic, SQL, or DLISegment records.
The following functions were documented incorrectly:
These "attach" functions associate a variable (either BLOB or CLOB) with a file resource (either specified or temporary system file), but do not write the contents of the variable to that resourse. Any prior memory or file associations are released. Subsequent operations, such as reading from a database into the variable, will update the file.
- attachBlobToFile()
- attachBlobToTempFile()
- attachClobToFile()
- attachClobToTempFile()
Previously, when you included a limited-length string variable in an EGL string concatenation and itemsNullable was YES, the variable's value was padded with blanks to its maximum length. When itemsNullable was NO, no padding was added. Starting with version 6.0.1.1, no padding will ever be added.
There is no support for making JDBC connections from Crystal Reports to z/OS and iSeries-based database products.
The Crystal Reports XML driver requires an application server to be at least J2EE 1.4 compliant, and therefore does not support Websphere Application Server v5.x runtime, which is J2EE 1.3 compliant.
You can assign default values to fields when adding a new row to the Faces Client Components DataGrid at runtime and set the default value to null.
Using the onRowAdd event handler the new EObject for the new row can be intercepted before it is added to the DataGrid:
- Add the onRowAdd attribute to the datagrid tag :
<odc:dataGrid allowRowAddAndDelete="false" styleClass="dataGrid" showSelectionColumn="false" pageSize="10" id="dataGrid1" onRowAdd = "return myOnRowAddHandler( this, event);">- You can then write any JavaScript in the handler or use the handler to set the default attributes in the EObject for the new row. This handler will be called when the user tries to add a new row to the DataGrid. This code example sets the value of the AGE field in a sample EObject to null:
myOnRowAddHandler(thisObj, thisEvent) {
//thisObj is DataGrid Control
var objs = thisObj.Adapter.EObjects;
objs[objs.length-1].eSet("AGE",null);
}
The product home page for Rational Web Developer is www.ibm.com/software/awdtools/developer/web/. For FAQs, lists of known problems and fixes, and other support information, visit the product support page at www.ibm.com/software/awdtools/developer/web/support/index.html.
© Copyright IBM Corporation 2000, 2005. All Rights Reserved.
The XDoclet Documentation included in this IBM product is used with permission and is covered under the following copyright attribution statement: Copyright © 2000-2005, XDoclet Team. All rights reserved.
Portions based on Design Patterns: Elements of Reusable Object-Oriented Software, by Erich Gamma, Richard Helm, Ralph Johnson and John Vlissides, Copyright © 1995 by Addison-Wesley Publishing Company, Inc. All rights reserved.U.S. Government Users Restricted Rights - Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
This information was developed for products and services offered in the U.S.A. IBM may not offer the products, services, or features discussed in this documentation in other countries. Consult your local IBM representative for information on the products and services currently available in your area. Any reference to an IBM product, program, or service is not intended to state or imply that only that IBM product, program, or service may be used. Any functionally equivalent product, program, or service that does not infringe any IBM intellectual property right may be used instead. However, it is the user's responsibility to evaluate and verify the operation of any non-IBM product, program, or service.
IBM may have patents or pending patent applications covering subject matter described in this documentation. The furnishing of this documentation does not give you any license to these patents. You can send license inquiries, in writing, to:
IBM Director of Licensing
IBM Corporation
North Castle Drive
Armonk, NY 10504-1785
U.S.A.
For license inquiries regarding double-byte (DBCS) information, contact the IBM Intellectual Property Department in your country or send inquiries, in writing, to:
IBM World Trade Asia Corporation
Licensing
2-31 Roppongi 3-chome, Minato-ku
Tokyo 106, Japan
The following paragraph does not apply to the United Kingdom or any other country where such provisions are inconsistent with local law: INTERNATIONAL BUSINESS MACHINES CORPORATION PROVIDES THIS PUBLICATION "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OR CONDITIONS OF NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Some states do not allow disclaimer of express or implied warranties in certain transactions, therefore, this statement may not apply to you.
This information could include technical inaccuracies or typographical errors. Changes are periodically made to the information herein; these changes will be incorporated in new editions of the publication. IBM may make improvements and/or changes in the product(s) and/or the program(s) described in this publication at any time without notice.
Any references in this information to non-IBM Web sites are provided for convenience only and do not in any manner serve as an endorsement of those Web sites. The materials at those Web sites are not part of the materials for this IBM product and use of those Web sites is at your own risk.
IBM may use or distribute any of the information you supply in any way it believes appropriate without incurring any obligation to you.
Licensees of this program who wish to have information about it for the purpose of enabling: (i) the exchange of information between independently created programs and other programs (including this one) and (ii) the mutual use of the information which has been exchanged, should contact:
Intellectual Property Dept. for Rational Software
IBM Corporation
3600 Steeles Avenue East
Markham, Ontario
Canada L3R 9Z7Such information may be available, subject to appropriate terms and conditions, including in some cases, payment of a fee.
The licensed program described in this documentation and all licensed material available for it are provided by IBM under terms of the IBM Customer Agreement, IBM International Program License Agreement or any equivalent agreement between us.
Information concerning non-IBM products was obtained from the suppliers of those products, their published announcements or other publicly available sources. IBM has not tested those products and cannot confirm the accuracy of performance, compatibility or any other claims related to non-IBM products. Questions on the capabilities of non-IBM products should be addressed to the suppliers of those products.
COPYRIGHT LICENSE:
This information contains sample application programs in source language, which illustrates programming techniques on various operating platforms. You may copy, modify, and distribute these sample programs in any form without payment to IBM, for the purposes of developing, using, marketing or distributing application programs conforming to the application programming interface for the operating platform for which the sample programs are written. These examples have not been thoroughly tested under all conditions. IBM, therefore, cannot guarantee or imply reliability, serviceability, or function of these programs.
Each copy or any portion of these sample programs or any derivative work, must include a copyright notice as follows:
© (your company name) (year). Portions of this code are derived from IBM Corp. Sample Programs. © Copyright IBM Corp. 2000, 2005. All rights reserved.
If you are viewing a soft copy of this information, the photographs and color illustrations may not appear.
Programming interface information
Programming interface information is intended to help you create application software using this program.
General-use programming interfaces allow you to write application software that obtain the services of this program's tools.
However, this information may also contain diagnosis, modification, and tuning information. Diagnosis, modification, and tuning information is provided to help you debug your application software.
Warning: Do not use this diagnosis, modification, and tuning information as a programming interface because it is subject to change.
Trademarks and service marks
The following terms are trademarks of International Business Machines Corporation in the United States, other countries, or both:
- ClearCase
- DB2
- IBM
- iSeries
- Rational
- WebSphere
- z/OS
Java and all Java-based trademarks are trademarks of Sun Microsystems, Inc. in the United States, other countries, or both.
Windows® and Windows NT® are trademarks of Microsoft® Corporation in the United States, other countries, or both.
Intel® and Pentium® are trademarks or registered trademarks of Intel Corporation or its subsidiaries in the United States, other countries, or both.
Linux® is a trademark of Linus Torvalds in the United States, other countries, or both.
Other company, product or service names, may be trademarks or service marks of others.