DataWrapper ライブラリ

- 目次 -


概要

このライブラリ data.DataWrapper は、任意型の変数値を構造体でラッピングする機能を提供します。主に配列データをラッピングするのに使用します。

VCSSLではジャグ配列が禁止されているため、配列の要素数は、各次元内では一様である必要があります。
例えば、要素数の異なる1次元の配列データをまとめて、2次元配列にする事はできません。

そこで配列データを構造体でラッピングする事により、この制約を回避する事ができます。
上の例では、1次元配列データをラッピングした構造体を作り、その構造体の配列を作る事で、2次元のジャグ配列のような構造を実現できます。

このモジュールでは、そのようなラッピング用途のために、ジェネリック構造体 DataWrapperが提供されます。
wrap関数で、任意型変数のデータをラッピングし、DataWrapper 構造体に変換する事ができます。また、unwrap関数で、元のデータを取り出す事もできます。

なお、DataWrapperは、実際にdata.WrappedList,WrappedStack,WrappedQueueの実装に使用されています。
これらのライブラリでは、DataWrapperによって、要素数の異なる配列に対応したコレクション機能を実現しています。


目次

struct DataWrapper<Type>
任意型のデータをラッピングする構造体です。
DataWrapper<Type> wrap<Type>(Type arg)
任意型のデータをラッピングします。
Type unwrap<Type>(DataWrapper<Type> wrapper)
ラッピングしているデータを取り出します。

構造体

構造体名 DataWrapper<Type>
宣言形式 struct DataWrapper<Type>
説明 任意型のデータをラッピングする構造体です。

変数

- なし -


関数

関数名 wrap<Type>
宣言形式 DataWrapper<Type> wrap<Type>(Type arg)
説明 任意型のデータをラッピングします。
引数 (Type型) arg : ラッピングするデータ
戻り値 (DataWrapper<Type>型) 入力値のラッパー
関数名 unwrap<Type>
宣言形式 Type unwrap<Type>(DataWrapper<Type> wrapper)
説明 ラッピングしているデータを取り出します。
引数 (DataWrapper<Type>型) wrapper : データを取り出すラッパー
戻り値 (Type型) ラッパーが保持している値