HP OpenVMS Systems Documentation |
| 前へ | 次へ | 目次 | 索引 |
終端の null 文字も含む source のすべての内容を dest にコピーします。
#include <string.h>関数バリアント strcpy関数は,それぞれ 32 ビットと 64 ビットのポインタ・サイズで使用するための _strcpy32と _strcpy64という名前のバリアントを持っています。ポインタ・サイズ固有の関数の使用方法については,『HP C ランタイム・ライブラリ・リファレンス・マニュアル(上巻)』第 1.10 節を参照してください。char *strcpy (char *dest, const char *source);
dest
デスティネーション文字列へのポインタ。source
ソース文字列へのポインタ。
strcpy関数は, source を dest にコピーし, source の null 文字をコピーした後に停止します。dest がポイントする領域が source がポイントする領域とオーバラップしている場合,この関数の動作は未定義です。
x dest のアドレス。
指定された文字セットに含まれていない文字のみから構成される文字列の接頭辞の長さを返します。
#include <string.h>size_t strcspn (const char *str, const char *charset);
str
文字列へのポインタ。この文字列が null 文字列だった場合には,0 が返されます。charset
文字のセットを含んだ文字列へのポインタ。
strcspn関数は,文字列内の文字をスキャンし, charset に含まれる文字を検出した時点で停止し, charset に含まれない文字から構成される文字列の先頭のセグメントの長さを返します。str と charset がポイントする文字列のどの文字も一致しない場合, strcspnは文字列の長さを返します。
x セグメントの長さ。
指定された文字列を複製します。
#include <string.h>関数バリアント strdup関数は,それぞれ 32 ビットと 64 ビットのポインタ・サイズで使用するための _strdup32と _strdup64という名前のバリアントを持っています。ポインタ・サイズ固有の関数の使用方法については,『HP C ランタイム・ライブラリ・リファレンス・マニュアル(上巻)』第 1.10 節を参照してください。char *strdup (const char *s1);
s1
複製する文字列。
strdup関数は,s1 がポイントする文字列の正確な複製である文字列へのポインタを返します。新しい文字列のためのスペースの割り当てには malloc関数が使用されます。 strdup関数は,既存のシステムとの互換性のために用意されています。
x 結果として得られる文字列へのポインタ。 NULL エラーを示します。
error_code の中のエラー番号を,ロケール依存のエラー・メッセージ文字列にマップします。
#include <string.h>char *strerror (int error_code); (ANSI C)
char *strerror (int error_code[, int vms_error_code]); (HP C Extension)
error_code
エラー・コード。vms_error_code
OpenVMS エラー・コード。
strerror関数は, error_code の中のエラー番号を使用して,適切なロケール依存のエラー・メッセージを取得します。エラー・メッセージ文字列の内容は,プログラムの現在のロケールの LC_MESSAGES カテゴリによって決定されます。プログラムが標準関連の機能テスト・マクロ ( 『HP C ランタイム・ライブラリ・リファレンス・マニュアル(上巻)』第 1.5.1 項を参照 ) を指定せずにコンパイルされた場合, strerrorは以下のように使用される第 2 の引数 (vms_error_code) を取ります。
- error_code が EVMSERR で,第 2 引数が存在する場合には,その第 2 引数が vaxc$errno値として使用される。
- error_code が EVMSERR で,第 2 引数が存在しない場合には, vaxc$errnoを参照して OpenVMS エラー条件を取得する。
「例」の項を参照してください。
第 2 の引数は, strerrorの ANSI C の定義には含まれていないので,移植性はありません。
エラーを示す戻り値は予約されていないため,アプリケーションは errnoの値を 0 に設定した後に strerrorを呼び出し, errnoの値をテストしなくてはなりません。ゼロ以外の値はエラー条件を示します。
x 該当するエラー・メッセージを含んでいるバッファへのポインタ。プログラム内でこのバッファを変更しないでください。また, strerror 関数の呼び出しにより,このバッファは新しいメッセージで上書きされることがあります。
#include <stdio.h> #include <errno.h> #include <string.h> #include <stdlib.h> #include <ssdef.h> main() { puts(strerror(EVMSERR)); errno = EVMSERR; vaxc$errno = SS$_LINKEXIT; puts(strerror(errno)); puts(strerror(EVMSERR, SS$_ABORT)); exit(1); }
この例のプログラムを実行すると,次の出力が生成されます。
nontranslatable vms error code: <none> network partner exited abort |
金額値を文字列に変換します。変換は書式文字列によって制御されます。
#include <monetary.h>ssize_t strfmon (char *s, size_t maxsize, const char *format, ...);
s
結果として得られる文字列へのポインタ。maxsize
結果として得られる文字列に格納される最大バイト数。format
出力文字列の書式を制御する文字列へのポインタ。...
出力文字列へと整形される double型の金額値。 format がポイントする書式文字列の中の変換指定と同じ数の値がなくてはなりません。値が足りなかった場合,関数は実行に失敗します。余分な引数は無視されます。
strfmon関数は,指定された金額値を使用して, s がポイントする文字列を作成します。最高 maxsize バイトが s にコピーされます。format がポイントする書式文字列は,通常の文字と変換指定から構成されています。すべての通常の文字は,変更なしに出力文字列にコピーされます。変換指定は,指定された金額値の 1 つが,出力文字列でどのように整形されるかを定義します。
変換指定は,パーセント文字 (%),いくつかのオプションの文字 ( 表 REF-5 を参照 ),および変換指定子 ( 表 REF-6 を参照 ) から構成されます。
表 REF-5 に示しているオプション文字が変換指定に含まれる場合,それらの文字は表に示した順序で現れなくてはなりません。
表 REF-5 strfmon の変換指定に含まれるオプションの文字 文字 意味 = character 小数点以上の桁数を指定した場合に, character を数値フィル文字として使用する。デフォルトの数値フィル文字はスペース文字である。フィル文字は,有効桁数と幅のカウントに対応できるように, 1 バイトとして表現できなくてはならない。この変換指定子は,小数点以上の桁数が指定されなかった場合には無視される。また,幅のフィルはつねにスペース文字を使用するので,この変換指定子の影響を受けない。 ^ 数値の書式指定に区切り文字を使用しない。デフォルトでは,桁は現在のロケールの LC_MONETARY カテゴリの mon_grouping フィールドに従ってグループ化される。 + 現在のロケールの positive_sign または negative_sign フィールドで指定された文字列を追加する。 p_sign_posn または n_sign_posn が 0 に設定されている場合,デフォルトでは負の値を示すために括弧が使用される。それ以外の場合には,符号文字列が値の符号を示すために使用される。同じ変換指定で + と ( を同時に使用することはできない。 ( 負の値を括弧で囲む。デフォルトの設定には,現在のロケールの p_sign_posn または n_sign_posn フィールドが使用される。 p_sign_posn または n_sign_posn が 0 に設定されている場合,デフォルトでは負の値を示すために括弧が使用される。それ以外の場合には,符号文字列が値の符号を示すために使用される。同じ変換指定で + と ( を同時に使用することはできない。 ! 通貨シンボルを抑止する。デフォルトでは,通貨シンボルが追加される。 -- フィールド内で値を左揃えにする。デフォルトでは,値は右揃えになる。 フィールド幅 変換の結果の位置を揃えるときに使用される最小のフィールド幅を指定する 10 進整数。デフォルトのフィールド幅は,結果を格納できる最も小さいフィールドである。 #left_precision # の後の 10 進整数は,小数点以上の桁数を指定する。余った桁はフィル文字によって埋められる。デフォルトでは,引数に必要な最小限の桁数が使用される。 ^ 変換指定子でグループ化が抑止されておらず,現在のロケールでグループ化が定義されていた場合には,フィル文字が追加される前にグループ化の区切り文字が挿入される。グループ化の区切り文字は,フィル文字が数字として定義されている場合でも,フィル文字には適用されない。 .right_precision ピリオド (.) の後の 10 進整数は,小数点以下の桁数を指定する。余分な桁はゼロで埋められる。値はこの小数点以下の桁数にまで丸められる。小数点以下の桁数がゼロである場合,出力には小数点は含められない。デフォルトでは,小数点以下の桁数は現在のロケールの frac_digits または int_frac_digits フィールドによって定義される。
表 REF-6 strfmon の変換指定子 指定子 意味 i 通貨シンボルが抑止されていなければ,現在のロケールの int_currency_symbol フィールドによって定義されている国際通貨シンボルを使用する。 n 通貨シンボルが抑止されていなければ,現在のロケールの currency_symbol フィールドによって定義されているローカル通貨シンボルを使用する。 % % 文字を出力する。変換指定は %% でなくてはならない。この指定子では,どのオプション文字も使用できない。
x s がポイントする文字列に書き込まれるバイト数。終端の null 文字は含みません。 - 1 エラーを示します。関数は errno を以下のいずれかの値に設定します。
- EINVAL---変換指定の構文が間違っている。
- E2BIG---書式文字列全体を処理すると,出力が maxsize バイトを超える。
#include <stdlib.h> #include <stdio.h> #include <locale.h> #include <monetary.h> #include <errno.h> #define MAX_BUF_SIZE 124 main() { size_t ret; char buffer[MAX_BUF_SIZE]; double amount = 102593421; /* Display a monetary amount using the en_US.ISO8859-1 */ /* locale and a range of different display formats. */ if (setlocale(LC_ALL, "en_US.ISO8859-1") == (char *) NULL) { perror("setlocale"); exit(EXIT_FAILURE); } ret = strfmon(buffer, MAX_BUF_SIZE, "International: %i\n", amount); printf(buffer); ret = strfmon(buffer, MAX_BUF_SIZE, "National: %n\n", amount); printf(buffer); ret = strfmon(buffer, MAX_BUF_SIZE, "National: %=*#10n\n", amount); printf(buffer); ret = strfmon(buffer, MAX_BUF_SIZE, "National: %(n\n", -1 * amount); printf(buffer); ret = strfmon(buffer, MAX_BUF_SIZE, "National: %^!n\n", amount); printf(buffer); }
この例のプログラムを実行すると,次の出力が生成されます。
International: USD 102,593,421.00 National: $102,593,421.00 National: $**102,593,421.00 National: ($102,593,421.00) National: 102593421.00 |
tm構造体に格納されている日付および時刻情報を使って出力文字列を作成します。出力文字列の書式は書式文字列によって制御されます。
#include <time.h>関数バリアント _DECC_V4_SOURCE および _VMS_V6_SOURCE 機能テスト・マクロを定義してコンパイルすると,OpenVMS Version 7.0 およびそれ以前の動作と等価な, strftime関数へのローカル時刻ベースのエントリ・ポイントが使用可能となります。size_t strftime (char *s, size_t maxsize, const char *format, const struct tm *timeptr);
s
結果として得られる文字列へのポインタ。maxsize
結果として得られる文字列に格納される最大バイト数 ( 終端の null を含みます )。format
出力文字列の書式を制御する文字列へのポインタ。timeptr
ローカル時刻 ( tm) 構造体へのポインタ。 tm構造体は <time.h>ヘッダ・ファイルに定義されています。
strftime関数は,timeptr がポイントする構造体に含まれているデータを使用して,s がポイントする文字列を作成します。最高 maxsize バイトが s にコピーされます。書式文字列は,0 個以上の変換指定と通常の文字から構成されています。すべての通常の文字は ( 終端の null 文字を含めて ),変更なしに出力文字列にコピーされます。変換指定は, tm構造体の中のデータが,出力文字列でどのように整形されるかを定義します。
変換指定は,パーセント文字 (%), 1 つまたは複数のオプションの文字 ( 表 REF-7 を参照 ),および変換指定子 ( 表 REF-8 を参照) から構成されます。 表 REF-7 に示しているオプション文字が指定される場合,それらの文字は表に示した順序で現れなくてはなりません。
strftime関数は, tzsetを呼び出した場合と同じように動作します。
表 REF-7 strftime 変換指定のオプション要素 要素 意味 -- フィールド幅にオプションとして付け,そのフィールドが左揃えされ,スペースでパディングされることを示す。0 要素と同時に使用することはできない。 0 フィールド幅にオプションとして付け,そのフィールドが右揃えされ,ゼロでパディングされることを示す。 -- 要素と同時に使用することはできない。 フィールド幅 最大フィールド幅を指定する 10 進整数。 .precision フィールド内のデータの精度を指定する 10 進整数。 d, H, I, j, m, M, o, S, U, w, W, y, および Y 変換指定子では,精度指定子は,フィールド内の桁数の最小値である。変換指定が精度によって指定された桁数よりも少ない場合には,先頭にゼロが追加される。
a, A, b, B, c, D, E, h, n, N, p, r, t, T, x, X, Z, および % 変換指定子では,精度指定子は,フィールド内の文字数の最大値である。変換指定が精度によって指定された桁数よりも多くの文字を含んでいる場合には,右側の文字が切り捨てられる。
d, H, I, m, M, o, S, U, w, W, y および Y 変換指定子のデフォルトの精度は 2 である。 j 変換指定子のデフォルトの精度は 3 である。
表 REF-7 の変換指定のリストは, XPG4 仕様の拡張であることに注意してください。
表 REF-8 は変換指定子を示しています。 strftime関数は,プログラムの現在のロケールの LC_TIME カテゴリのフィールドから値を取得します。たとえば, %Bが指定されている場合,関数は LC_TIME の mon フィールドにアクセスして, tm構造体で指定された月の完全な名前を取得します。無効な変換指定子を使用したときの結果は未定義です。
表 REF-8 strftime の変換指定子 指定子 置き換え a ロケールの短縮された曜日名。 A ロケールの完全な曜日名。 b ロケールの短縮された月の名前。 B ロケールの完全な月の名前。 c ロケールの適切な日付および時刻表現。 C 10 進数 (00〜99) として表現される世紀 (年を 100 で割り,整数に切り捨て)。 d その月の 10 進数 (01〜31) として表現される日付。 D %m/%d/%y と同じ。 e 先頭がスペース文字でフィルされた 2 桁のフィールドに格納される,その月の 10 進数 (1〜31) として表現される日付。 Ec ロケールの代替日付および時刻表現。 EC ロケールの代替表現における基本年 (期間) の名前。 Ex ロケールの代替日付表現。 EX ロケールの代替時刻表現。 Ey ロケールの代替表現における基本年 ( %EC ) からのオフセット。 EY ロケールの完全な代替年表現。 h %b と同じ。 H 10 進数 (00〜23) としての時刻 (24 時間制)。 I 10 進数 (01〜12) としての時刻 (12 時間制)。 j 10 進数 (001〜366) としての,その年の中での日。 m 10 進数 (01〜12) としての月。 M 10 進数 (00〜59) としての分。 n 改行文字。 Od ロケールの代替数値シンボルを使用した,その月の中での日。 Oe ロケールの代替数値シンボルを使用した,その月の中での日付。 OH ロケールの代替数値シンボルを使用した時刻 (24 時間制)。 OI ロケールの代替数値シンボルを使用した時刻 (12 時間制)。 Om ロケールの代替数値シンボルを使用した月。 OM ロケールの代替数値シンボルを使用した分。 OS ロケールの代替数値シンボルを使用した秒。 Ou ロケールの代替表現での曜日を数値で表したもの (月曜日 =1)。 OU ロケールの代替数値シンボルを使用した,その年の中での週 (週は日曜日から始まる)。 OV ロケールの代替数値シンボルを使用した,10 進数 (01〜53) としての,その年の中での週 (週は月曜日から始まる)。1 月 1 日を含んでいる週が,新年に 4 日以上ある場合には,その週が 1 番目の週と見なされる。そうでない場合は,前年の 53 番目の週と見なされ,次の週が 1 番目の週となる。 Ow ロケールの代替数値シンボルを使用した,数値としての曜日 (日曜日 =0)。 OW ロケールの代替数値シンボルを使用した,その年の中での数値としての週 (週は月曜日から始まる)。 Oy ロケールの代替数値シンボルを使用した,世紀を除いた年。 p ロケールの 12 時間制における AM/PM 指定。 r AM/PM 表記での時刻。 R 24 時間表記での時刻 ( %H:%M )。 S 10 進数 (00〜61) としての秒。 t タブ文字。 T 時刻 ( %H:%M:%S )。 u 1〜7 の範囲の 10 進数としての曜日 (月曜日 =1)。 U 10 進数 (00〜53) としての,その年の中の週 (最初の日曜日が 1 番目の週の最初の日と見なされる)。 V 10 進数 (00〜53) としての,その年の中の週 (週は月曜日から始まる)。 1 月 1 日を含んでいる週が,新年に 4 日以上ある場合には,その週が 1 番目の週と見なされる。そうでない場合は,前年の 53 番目の週と見なされ,次の週が 1 番目の週となる。 w 10 進数 (0 [日曜日]〜6) としての曜日。 W 10 進数 (00〜53) としての,その年の中での週 (最初の月曜日が 1 番目の週の最初の日と見なされる)。 x ロケールの適切な日付表現。 X ロケールの適切な時刻表現。 y 10 進数 (00〜99) としての,世紀を除いた年。 Y 10 進数としての,世紀を含んだ年。 Z タイム・ゾーン名またはその短縮形。タイム・ゾーン情報がない場合には,文字は出力されない。 % リテラルの % 文字。
x s がポイントする配列に格納された文字数。終端の null 文字は含まれません。 0 エラーが発生したことを示します。配列の内容は不定です。
前へ 次へ 目次 索引