blanco.cg.valueobject.BlancoCgField Maven / Gradle / Ivy
/*
* blanco Framework
* Copyright (C) 2004-2009 IGA Tosiki
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*/
package blanco.cg.valueobject;
import java.util.List;
/**
* フィールドを表現するためのバリューオブジェクト。
*
* プログラミング言語によってはプロパティと呼ばれることもあります。
* ※ポイント:クラス名の名前変形や文字列のエスケープ処理などは、blancoCgに与える前に実施されている必要があります。
*/
public class BlancoCgField {
/**
* このフィールドの名前です。
*
* フィールド: [name]。
*/
private String fName;
/**
* このフィールドの説明です。
*
* フィールド: [description]。
*/
private String fDescription;
/**
* このフィールドの型です。java.lang.Stringなどを指定します。
*
* フィールド: [type]。
*/
private BlancoCgType fType;
/**
* アクセスコントロールを指定します。public/protected/privateなどを指定します。
*
* フィールド: [access]。
* デフォルト: ["private"]。
*/
private String fAccess = "private";
/**
* staticかどうかをあらわします。
*
* フィールド: [static]。
* デフォルト: [false]。
*/
private boolean fStatic = false;
/**
* finalかどうかをあらわします。
*
* フィールド: [final]。
* デフォルト: [false]。
*/
private boolean fFinal = false;
/**
* デフォルト値をあらわします。
*
* Stringなら ""、intなら 3 などのように実際の文を指定します。
* (ダブルクオートなども含んだ形で表現します。)
* フィールド: [default]。
*/
private String fDefault;
/**
* このフィールドに付与されているアノテーションのリストです。
*
* フィールド: [annotationList]。
* デフォルト: [new java.util.ArrayList<java.lang.String>()]。
*/
private List fAnnotationList = new java.util.ArrayList();
/**
* 言語ドキュメントを蓄えます。デフォルト以上の表現を追加する場合には、インスタンスを生成して値をセットしてから自動生成します。なおBlancoCgObjectFactoryを経由してインスタンスを取得した際には、既にオブジェクトはセット済みです。
*
* フィールド: [langDoc]。
*/
private BlancoCgLangDoc fLangDoc;
/**
* フィールド [name] の値を設定します。
*
* フィールドの説明: [このフィールドの名前です。]。
*
* @param argName フィールド[name]に設定する値。
*/
public void setName(final String argName) {
fName = argName;
}
/**
* フィールド [name] の値を取得します。
*
* フィールドの説明: [このフィールドの名前です。]。
*
* @return フィールド[name]から取得した値。
*/
public String getName() {
return fName;
}
/**
* フィールド [description] の値を設定します。
*
* フィールドの説明: [このフィールドの説明です。]。
*
* @param argDescription フィールド[description]に設定する値。
*/
public void setDescription(final String argDescription) {
fDescription = argDescription;
}
/**
* フィールド [description] の値を取得します。
*
* フィールドの説明: [このフィールドの説明です。]。
*
* @return フィールド[description]から取得した値。
*/
public String getDescription() {
return fDescription;
}
/**
* フィールド [type] の値を設定します。
*
* フィールドの説明: [このフィールドの型です。java.lang.Stringなどを指定します。]。
*
* @param argType フィールド[type]に設定する値。
*/
public void setType(final BlancoCgType argType) {
fType = argType;
}
/**
* フィールド [type] の値を取得します。
*
* フィールドの説明: [このフィールドの型です。java.lang.Stringなどを指定します。]。
*
* @return フィールド[type]から取得した値。
*/
public BlancoCgType getType() {
return fType;
}
/**
* フィールド [access] の値を設定します。
*
* フィールドの説明: [アクセスコントロールを指定します。public/protected/privateなどを指定します。]。
*
* @param argAccess フィールド[access]に設定する値。
*/
public void setAccess(final String argAccess) {
fAccess = argAccess;
}
/**
* フィールド [access] の値を取得します。
*
* フィールドの説明: [アクセスコントロールを指定します。public/protected/privateなどを指定します。]。
* デフォルト: ["private"]。
*
* @return フィールド[access]から取得した値。
*/
public String getAccess() {
return fAccess;
}
/**
* フィールド [static] の値を設定します。
*
* フィールドの説明: [staticかどうかをあらわします。]。
*
* @param argStatic フィールド[static]に設定する値。
*/
public void setStatic(final boolean argStatic) {
fStatic = argStatic;
}
/**
* フィールド [static] の値を取得します。
*
* フィールドの説明: [staticかどうかをあらわします。]。
* デフォルト: [false]。
*
* @return フィールド[static]から取得した値。
*/
public boolean getStatic() {
return fStatic;
}
/**
* フィールド [final] の値を設定します。
*
* フィールドの説明: [finalかどうかをあらわします。]。
*
* @param argFinal フィールド[final]に設定する値。
*/
public void setFinal(final boolean argFinal) {
fFinal = argFinal;
}
/**
* フィールド [final] の値を取得します。
*
* フィールドの説明: [finalかどうかをあらわします。]。
* デフォルト: [false]。
*
* @return フィールド[final]から取得した値。
*/
public boolean getFinal() {
return fFinal;
}
/**
* フィールド [default] の値を設定します。
*
* フィールドの説明: [デフォルト値をあらわします。]。
* Stringなら ""、intなら 3 などのように実際の文を指定します。
* (ダブルクオートなども含んだ形で表現します。)
*
* @param argDefault フィールド[default]に設定する値。
*/
public void setDefault(final String argDefault) {
fDefault = argDefault;
}
/**
* フィールド [default] の値を取得します。
*
* フィールドの説明: [デフォルト値をあらわします。]。
* Stringなら ""、intなら 3 などのように実際の文を指定します。
* (ダブルクオートなども含んだ形で表現します。)
*
* @return フィールド[default]から取得した値。
*/
public String getDefault() {
return fDefault;
}
/**
* フィールド [annotationList] の値を設定します。
*
* フィールドの説明: [このフィールドに付与されているアノテーションのリストです。]。
*
* @param argAnnotationList フィールド[annotationList]に設定する値。
*/
public void setAnnotationList(final List argAnnotationList) {
fAnnotationList = argAnnotationList;
}
/**
* フィールド [annotationList] の値を取得します。
*
* フィールドの説明: [このフィールドに付与されているアノテーションのリストです。]。
* デフォルト: [new java.util.ArrayList<java.lang.String>()]。
*
* @return フィールド[annotationList]から取得した値。
*/
public List getAnnotationList() {
return fAnnotationList;
}
/**
* フィールド [langDoc] の値を設定します。
*
* フィールドの説明: [言語ドキュメントを蓄えます。デフォルト以上の表現を追加する場合には、インスタンスを生成して値をセットしてから自動生成します。なおBlancoCgObjectFactoryを経由してインスタンスを取得した際には、既にオブジェクトはセット済みです。]。
*
* @param argLangDoc フィールド[langDoc]に設定する値。
*/
public void setLangDoc(final BlancoCgLangDoc argLangDoc) {
fLangDoc = argLangDoc;
}
/**
* フィールド [langDoc] の値を取得します。
*
* フィールドの説明: [言語ドキュメントを蓄えます。デフォルト以上の表現を追加する場合には、インスタンスを生成して値をセットしてから自動生成します。なおBlancoCgObjectFactoryを経由してインスタンスを取得した際には、既にオブジェクトはセット済みです。]。
*
* @return フィールド[langDoc]から取得した値。
*/
public BlancoCgLangDoc getLangDoc() {
return fLangDoc;
}
/**
* このバリューオブジェクトの文字列表現を取得します。
*
* 使用上の注意
*
* - オブジェクトのシャロー範囲のみ文字列化の処理対象となります。
*
- オブジェクトが循環参照している場合には、このメソッドは使わないでください。
*
*
* @return バリューオブジェクトの文字列表現。
*/
@Override
public String toString() {
final StringBuffer buf = new StringBuffer();
buf.append("blanco.cg.valueobject.BlancoCgField[");
buf.append("name=" + fName);
buf.append(",description=" + fDescription);
buf.append(",type=" + fType);
buf.append(",access=" + fAccess);
buf.append(",static=" + fStatic);
buf.append(",final=" + fFinal);
buf.append(",default=" + fDefault);
buf.append(",annotationList=" + fAnnotationList);
buf.append(",langDoc=" + fLangDoc);
buf.append("]");
return buf.toString();
}
/**
* このバリューオブジェクトを指定のターゲットに複写します。
*
* 使用上の注意
*
* - オブジェクトのシャロー範囲のみ複写処理対象となります。
*
- オブジェクトが循環参照している場合には、このメソッドは使わないでください。
*
*
* @param target target value object.
*/
public void copyTo(final BlancoCgField target) {
if (target == null) {
throw new IllegalArgumentException("Bug: BlancoCgField#copyTo(target): argument 'target' is null");
}
// No needs to copy parent class.
// Name: fName
// Type: java.lang.String
target.fName = this.fName;
// Name: fDescription
// Type: java.lang.String
target.fDescription = this.fDescription;
// Name: fType
// Type: blanco.cg.valueobject.BlancoCgType
// フィールド[fType]はサポート外の型[blanco.cg.valueobject.BlancoCgType]です。
// Name: fAccess
// Type: java.lang.String
target.fAccess = this.fAccess;
// Name: fStatic
// Type: boolean
target.fStatic = this.fStatic;
// Name: fFinal
// Type: boolean
target.fFinal = this.fFinal;
// Name: fDefault
// Type: java.lang.String
target.fDefault = this.fDefault;
// Name: fAnnotationList
// Type: java.util.List
// フィールド[fAnnotationList]はサポート外の型[java.util.List]です。
// Name: fLangDoc
// Type: blanco.cg.valueobject.BlancoCgLangDoc
// フィールド[fLangDoc]はサポート外の型[blanco.cg.valueobject.BlancoCgLangDoc]です。
}
}