Rational Team Concert - SCM control of USS files - any codepage problems with certain types?
One answer
You should take care to set the mime-type, character encoding and line delimiter metadata on each file when they are first shared or checked-in so that Jazz SCM can use this information to check the consistency of the line-endings, allow merging of conflicts and show line annotations.
You can find this information in the property dialog by right-clicking on the file from the package/project explorer in the RTC eclipse client. In the RTC CLI client you can use the "lscm list properties" and "lscm property set" subcommands.
To set the default mime-type and line delimiters for a particular file extension you can use the Team->Jazz Source Control->File Properties preference page for the RTC eclipse client or create a magic.properties file in your .jazz-scm directory for the RTC CLI.
When pushing files from your PC to z/OS USS the files may be converted from ASCII to EBCDIC if you are in ascii mode in the ftp client. The ascii mode will even attempt to convert them if they are already in EBCDIC. To transfer files as-is then you need to use binary mode.
Comments
Note that it's not always the case that loading files preserves the original character encoding -- there are cases where the RTC SCM will convert files from the encoding in which they are stored in the repository. The primary case is when loading files to the MVS filesystem on z/OS but loads to z/OS USS can be configured to do this conversion as well. (A more detailed description of the algorithm used to determine which, if any, conversion to apply can be found here).
I agree with the gist of this answer, though -- if FTP is being used to push the files to USS, rather than loading directly to USS from RTC, none of these conversion routines will apply, the original encoding will be preserved when loading from the repository to the PC, and conversion may or may not be done by FTP itself, depending on whether FTP is in ASCII or binary mode.