[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 901- 1001- 2ch.scのread.cgiへ]
Update time : 04/24 17:46 / Filesize : 290 KB / Number-of Response : 1031
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

スレ立てるまでもない質問はここで 144匹目



306 名前:デフォルトの名無しさん mailto:sage [2016/11/04(金) 23:44:11.39 ID:TD4/YqE6.net]
あぁINIってヒント出てたのかw うん。だからおかしいと言ったのよ。
よっぽど簡単なのは除くけど設定ファイルはクラスにするべきだよ。
クラスにすると言っても、config.get('クラス/セクション/キー') みたいなことはしないようにw

INIのクラスやセクションごとに別々のクラスにするかどうかは場合次第だけど
使い方としてはconfig.key1 とか config.key2 とか。これは基本で、例えばINIに

[section]
name1=value1
name2=value2
name3=value3

みたいなのがあればconfig.section.getNames() で配列を返したり。

[log]
enable=1
filename="/var/log/hoge.log"

みたいなのがあれば、config.log.getEnable()はあえて作らずconfig.log.getFilename() で取得する値が
enable=1のときはfilenameの値、enable=0の時はnullになるとか。
何が言いたいかというと if config.log.getEnable() == true && config.log.getFilename() != null then みたいな
アホらしいコードをアプリ側で書く必要は無くなるよ if config.log.getFilename() != null then だけでよくなるよってこと

最大値とかもさ、configクラスが読み取ったときに超えていればエラーにすることだってできるし、
初期値なんかもconfig.getSomeValue()メソッドを用意してキーがなければこの値って書いておけば、アプリ側からは普通に値を参照するだけでいい
もしかしてアプリ側 に some_value = (config[SOME_VALUE_KEY] == null) ? DEFAULT_SOME_VALUE : config[SOME_VALUE_KEY] とか
いうのが大量に溢れていたりしない?w あー、あと型の変換もconfigクラスでやるべきだね。

ようするにconfigクラスっていうのは単にキーと値を定義してマッピングするだけの機能にしてはだめってこと。
バリデーションや初期値や複数のキーの組み合わせをまとめたりアプリ側からより使いやすくする。
こうやっておくとINI形式からXML形式やJSON形式に変えたとしても、configクラスが変わらなければ
参照側に影響はないし、バージョンアップ等で互換性を保ったままセクション名やキー名を変えることだってできる。






[ 続きを読む ] / [ 携帯版 ]

全部読む 前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<290KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef