- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- :Done/内部名を再考 へ行く。
- 1 (2016-01-27 (水) 08:24:06)
- 2 (2016-01-27 (水) 08:25:32)
- 3 (2016-01-29 (金) 04:02:34)
- 4 (2016-01-29 (金) 04:19:50)
- 5 (2016-01-29 (金) 08:52:42)
- 6 (2016-01-29 (金) 11:44:26)
- 7 (2016-02-01 (月) 17:57:38)
- 8 (2016-02-03 (水) 05:00:40)
- 9 (2016-03-04 (金) 04:54:56)
- 10 (2016-03-05 (土) 22:15:14)
- 11 (2016-03-05 (土) 23:43:51)
- 12 (2016-03-05 (土) 23:54:46)
- 13 (2016-03-05 (土) 23:58:18)
- 14 (2016-03-06 (日) 01:01:55)
- 15 (2016-03-06 (日) 01:06:18)
- 16 (2016-03-06 (日) 01:11:37)
- 17 (2016-03-06 (日) 01:21:56)
- 18 (2016-03-06 (日) 01:29:46)
- 19 (2016-03-06 (日) 01:44:16)
- 20 (2016-03-06 (日) 03:03:37)
- 21 (2016-03-06 (日) 03:17:46)
- 22 (2017-01-16 (月) 11:30:34)
- 23 (2017-01-16 (月) 11:35:58)
- 24 (2017-01-19 (木) 04:05:48)
ページ名クラス。
項目名、見解ID、版番号
ファイル名として使えるように区切りは「_」
内部名はページ名の分だけ † 
ページ名にのみ内部名を用意。他の区分はシステムが生成するIDだけなので、内部/外部ともにそれでいい。
メジャーID、マイナーID † 
編集をすると版が変わる。それでも同じページには同じ内部名であって欲しいので、編集ごとに変わる部分と変わらない部分とに分ける。
ユーザーが決められる部分…ページ名(+ディレクトリ名)→メジャーID
見解名は上位の名前(ページ名)に依存、合わせないと意味を成さないし、ページ名を指定しないと見解名のリストアップもできない。版番号も上位2つを指定しないとリストアップ不可能。
独立できるのはページ名だけ。→内部では分ける。メジャーID依存しているのをマイナーIDとして、2部構成に。
Entry:Side:Rev → Major:Miner
ファイル構成は内部名依存。Major(Entry)を指定するとMiner(Side:Rev)をリストアップ可能。3層にそれぞれ代表があるから、どれが欠けていても扱うべき内部名は得られるけど。
辞書ファイルはEntryごと:編集があるたびに更新しなければならないので。EntryのメジャーIDと同じ生存期間。ページ名リストは1つじゃないと意味をなさない
版を含まない † 
内部名の版番号を分けたとしても、版番号はページ名に依存する。ページごとに存在する版番号が異なるので。
→ 内部名をページ名と版に分ける。版のほうは外部名とも組み合わせられるので、内部名と呼べるのはページ名に対応する部分だけ。版は外部と共通。
本当にページ名に対応するだけの内部名。同名ページの数だけ同一内部名が存在する。内部名は裏のページ名。
同名ページのIDが必要 † 
ページ名に対応する内部名だけでは複数ある同名ページに対応できないので、それを区別するIDが必要。
→ 結局、見解IDが必要になる。自動リンクを維持するための内部ページ名、同名ページを区別するための見解ID、版を区別するための版番号。
自動リンクされる内部名はどう決まるか † 
自動リンクではページ名変更に対応するため内部名を記録する。でもひとつのページに内部名は複数。複数ある中から選ぶ方法は?
結局、外部名にリンクするしかない?
外部名だと自動リンクの維持が困難。ページ名変更のたびに自動リンクを更新しないと。
→ 自動リンク用の「第二の外部名」必要?
→ 内部名のメジャーIDが必要。
ページ名が変わらない限り同じで、版番号を含まない。
外部名は投票を加味しないと特定のページにはならないし、ならなくていい。でも自動リンクを作るにはページを特定した上で、その内部名を調べなければならない。内部名はページ名変更しても自動リンクを維持するはずなのに、外部名を記録するのでは維持できない。
→ 自動リンクは内部名(ページ名に対応して、それだけではページや版を特定できない部分)と関連付ける。
結局、内部名は必要 † 
メジャーID(同名ページの集約に付けるID)と、マイナーID(これだけでページを特定するGUID)。
同名ページをひとつでも残して名前変更すると、メジャーIDは新しくつけないといけない。古いメジャーIDを残さなければならないうえに、それとは異なるメジャーIDが必要になるので。
ページ名を変更した場合2通り † 
いずれにしてもマイナーIDはそのまま。
版を重ねても既存のマイナーIDはGUIDとして有効なまま。
マイナーIDのほうがメジャーぽい † 
GUIDのほうを「メジャー」としたほうが分かりやすい。
→ ページ名に対応するほうを「裏ページ名」とでもしたほうがいい?
GUIDのほうは「ページID」。
このふたつはつなげたりしない。
#ref(): File not found: "外部名と内部名.png" at page "内部名"
変更点 † 
- 見解IDと版番号(両方合わせてマイナーIDと呼んでいたもの)をGUIDにする。呼び方は
「内部名」か「ページID」でいい。新しい版は全く異なるGUIDになる。 - ページ名(Entry)に対応する別名を用意して
「裏ページ名」または「内部名」と呼ぶ。ページ名変更しても自動リンクを維持するため。
最新版を指すURIがない † 
ページではなく特定版でもなく、
ある同名ページの最新版をURIで指すには?
やはり見解IDは必要?
→ フォークを含んだり含まなかったりするので、ここでは用意しない。
特定のページIDページ名と「この特定版ページの直系子孫のうち最新のもの」や「この特定版ページの派生版を含む子孫のうち最新のもの」といった問い合わせで、最新版を指定。
URIにはページ内容と同じ記法を書けるので、そこで特定のページIDページ名を最新版のものに変換する。
→ 汎用記法
ページIDからでは投票を反映した最新版が得られないので、ページ名を指定。内部名でも可。それで最新版を指す。
再々考 † 
やはり内部名をページインスタンスのIDにすべき?
ページ/名前と、版ID(内部名でGUID)だけで良さそう。特定版とは版ID(ページインスタンスのID)のこと。
名前変更してもリンクを維持するためには?パーマリンクとしても使う。
→ 全版共通のIDが要る。編集しても最新版に引き継がれ、ページ名変更しても変わらないID。ページ名と異なりシステムが生成する。このIDを指定するだけでページひとつの編集履歴が手に入る。フォークには引き継がれない。マージでは一方の全版共通IDだけ引き継ぐ。
- 内部名
(同名ページが複数あるので)ページ名とは1対多になる内部名。最新版に引き継がれる。ページ名変更では変わらない。これでページ名変更時の明示的リンク維持に対応。ページ/属性。以前のメジャーID。 - 特定版ID
版ごとのID。パーマリンクにも使われる。GUID。これだけで版を特定できる。ページ/属性。以前のマイナーID。
ページ名変更は編集のうち † 
ページ名を変更しても過去版に影響しない。履歴には異なるページ名が並ぶことになる。列挙されるのは同じ内部名を持つ版。
当時のページ名を調べやすい。ページ名はページ本文のうちという考え方に合っている。