[an error occurred while processing this directive]
HP OpenVMS SystemsC Programming Language |
Compaq C
|
Previous | Contents | Index |
Converts the argument, a wide character, to uppercase. If the argument is not a lowercase character, it is returned unchanged.
#include <wctype.h> (ISO C)#include <wchar.h> (XPG4)
int towupper (wint_t wc);
wc
An object of type wint_t representable as a valid wide character in the current locale, or the value of WEOF. For any other value, the behavior is undefined.
If the argument is a lowercase wide character, the corresponing uppercase wide character (as defined in the LC_CTYPE category of the locale) is returned, if it exists. If it does not exist, the function returns the input argument unchanged.
Truncates the argument to an integral value.
#include <math.h>double trunc (double x);
float truncf (float x,);
long double truncl (long double x);
x
A floating-point number.
n The truncated, integral value of the argument.
Changes file length to a specified length in bytes.
#include <unistd.h>int truncate (const char *path, off_t length);
path
The name of a file that is to be truncated. This argument must point to a pathname that names a regular file for which the calling process has write permission.length
The new length of the file in bytes. The off_t type of length is either a 64-bit integer or a 32-bit integer. The 64-bit interface allows for file sizes greater than 2 gigabytes, and can be selected at compile time by defining the _LARGEFILE feature-test macro:
CC/DEFINE=_LARGEFILE
This function changes the length of a file to the size in bytes specified by the length argument.If the new length is less than the previous length, the function removes all data beyond length bytes from the specified file. All file data between the new End-of-File and the previous End-of-File is discarded.
For stream files, if the new length is greater than the previous length, new file data between the previous End-of-File and the new End-of-File is added, consisting of all zeros. (For record files, it is not possible to extend the file in this manner.)
0 Indicates success. --1 An error occurred; errno is set to indicate the error.
Returns a pointer to the null-terminated name of the terminal device associated with file descriptor 0, the default input device (stdin).
#include <unixio.h>char *ttyname (void);
This function is provided only for UNIX compatibility and has limited use in the OpenVMS environment.
x A pointer to a null-terminated string. 0 Indicates that SYS$INPUT is not a TTY device.
Sets and accesses time-zone conversion.
#include <time.h>void tzset (void);
extern char *tzname[];
extern long int timezone;
extern int daylight;
This function initializes time conversion information used by the ctime , localtime , mktime , strftime , and wcsftime functions.
The tzset function sets the following external variables:
- tzname is set as follows, where "std" is a 3-byte name for the standard time zone, and "dst" is a 3-byte name for the Daylight Savings Time zone:
tzname[0] = "std" tzname[1] = "dst"- daylight is set to 0 if Daylight Savings Time should never be applied to the time zone. Otherwise, daylight is set to 1.
- timezone is set to the difference between UTC and local standard time.
The environment variable TZ specifies how tzset initializes time conversion information:
- If TZ is absent from the environment, the implementation-dependent time-zone information is used, as follows:
The best available approximation to local wall-clock time is used, as defined by the system logical SYS$LOCALTIME, which points to a tzfile format file that describes default time-zone rules.
This system logical is set during the installation of OpenVMS Version 7.0 or higher to define a time-zone file based off the root directory SYS$COMMON:[SYS$ZONEINFO.SYSTEM].1- If TZ appears in the environment but its value is a null string, Coordinated Universal Time (UTC) is used (without leap-second correction).
- If TZ appears in the environment and its value is not a null string, the value has one of three formats, as described in Table REF-11.
See also ctime , localtime , mktime , strftime , and wcsftime in this section.
#1 |
---|
EST5EDT4,M4.1.0,M10.5.0 |
This sample TZ specification describes the rule defined in 1987 for the Eastern time zone in the US:
- EST (Eastern Standard Time) is the designation for standard time, which is 5 hours behind UTC.
- EDT (Eastern Daylight Time) is the designation for summer time, which is 4 hours behind UTC. EDT starts on the first Sunday in April and ends on the last Sunday in October.
Because time was not specified in either case, the changes occur at the default time, which is 2:00 a.m. The start and end dates did not need to be specified, because they are the defaults.
1 The Compaq C RTL uses a public-domain, time-zone handling package that puts time-zone conversion rules in easily accessible and modifiable files. These files reside in the directory SYS$COMMON:[SYS$ZONEINFO.SYSTEM.SOURCES]. <tzfile.h> header file. The converted files are created with a root directory of SYS$COMMON:[SYS$ZONEINFO.SYSTEM], which is pointed to by the SYS$TZDIR system logical. This format is readable by the C library functions that handle time-zone information. For example, in the eastern United Stated, SYS$LOCALTIME is defined to be SYS$COMMON:[SYS$ZONEINFO.SYSTEM.US]EASTERN. |
Sets or changes the timeout of interval timers.
#include <unistd.h>useconds_t ualarm (useconds_t mseconds, useconds_t interval);
mseconds
Specifies a number of real time microseconds.interval
Specifies the interval for repeating the timer.
This function causes the SIGALRM signal to be generated for the calling process after the number of real-time microseconds specified by useconds has elapsed. When the interval argument is nonzero, repeated timeout notification occurs with a period in microseconds specified by interval. If the notification signal SIGALRM is not caught or is ignored, the calling process is terminated.If you call a combination of ualarm and setitimer functions, and the AST status is disabled, the return value is invalid.
If you call a combination of ualarm and setitimer functions, and the AST status is enabled, the return value is valid.
This is because you cannot invoke an AST handler to clear the previous value of the timer when ASTs are disabled or invoked from a handler that was invoked at AST level.
Note
Interactions between ualarm and either alarm , or sleep are unspecified.See also setitimer in this section.
n The number of microseconds remaining from the previous ualarm or setitimer call. 0 No timeouts are pending or ualarm not previously called. --1 Indicates an error.
Creates a file protection mask that is used when a new file is created, and returns the previous mask value.
#include <stat.h>mode_t umask (mode_t mode_complement);
mode_complement
Shows which bits to turn off when a new file is created. See the description of chmod to determine what the bits represent.
Initially, the file protection mask is set from the current process's default file protection. This is done when the C main program starts up or when DECC$CRTL_INIT (or VAXC$CRTL_INIT ) is called. You can change this for all files created by your program by calling umask or you can use chmod to change the file protection on individual files. The file protection of a file created by open or creat is the bitwise AND of the open and creat mode argument with the complement of the value passed to umask on the previous call.
Note
The way to create files with OpenVMS RMS default protections using the UNIX system-call functions umask , mkdir , creat , and open is to call mkdir , creat , and open with a file-protection mode argument of 0777 in a program that never specifically calls umask . These default protections include correctly establishing protections based on ACLs, previous versions of files, and so on.
In programs that do vfork / exec calls, the new process image inherits whether umask has ever been called or not from the calling process image. The umask setting and whether the umask function has ever been called are both inherited attributes.
x The old mask value.
Gets system identification information.
#include <utsname.h>int uname (struct utsname *name);
name
The current system identifier.
This function stores null-terminated strings of information identifying the current system into the structure referenced by the name argument.The utsname structure is defined in the <utsname.h> header file and contains the following members:
sysname Name of the operating system implementation nodename Network name of this machine release Release level of the operating system version Version level of the operating system machine Machine hardware platform
0 Indicates success. --1 Indicates an error; errno or vaxc$errno is set as appropriate.
Pushes a character back into the input stream and leaves the stream positioned before the character.
#include <stdio.h>int ungetc (int character, FILE *file_ptr);
character
A value of type int .file_ptr
A file pointer.
When using this function, the character is pushed back onto the file indicated by file_ptr.One pushback is guaranteed, even if there has been no previous activity on the file. The fseek function erases all memory of pushed-back characters. The pushed-back character is not written to the underlying file. If the character to be pushed back is EOF, the operation fails, the input stream is left unchanged, and EOF is returned.
See also fseek and getc in this section.
x The push-back character. EOF Indicates it cannot push the character back.
Pushes a wide character back into the input stream.
#include <wchar.h>wint_t ungetwc (wint_t wc, FILE *file_ptr);
wc
A value of type wint_t .file_ptr
A file pointer.
When using this function, the wide character is pushed back onto the file indicated by file_ptr.One push-back is guaranteed, even if there has been no previous activity on the file. If a file positioning function (such as fseek ) is called before the pushed back character is read, the bytes representing the pushed back character are lost.
If the character to be pushed back is WEOF, the operation fails, the input stream is left unchanged, and WEOF is returned.
See also getwc in this section.
x The push-back character. WEOF Indicates that the function cannot push the character back. errno is set to one of the following:
- EBADF -- The file descriptor is not valid.
- EALREADY -- Operation is already in progress on the same file.
- EILSEQ -- Invalid wide-character code detected.
Previous | Next | Contents | Index |