home *** CD-ROM | disk | FTP | other *** search
/ DOS/V Power Report 1999 October / VPR9910A.BIN / OLS / tar32053 / tar32053.exe / SDK / TARTECH.DOC < prev   
Text File  |  1999-05-23  |  7KB  |  155 lines

  1. =====================================================================
  2. (注)このファイルはDOS版kmtarに付属していたファイルです。
  3. =====================================================================
  4. ---------------------------------------------------------------------
  5.       kmtar 2.00 パワーアップキット3.7
  6.       Technical DOC for Power Up Kit
  7.                                            1995-03-04
  8.                                    tantan  SGL00213@niftyserve.or.jp
  9. ---------------------------------------------------------------------
  10.  
  11. 『コンパイル』
  12.     kmtar は、本来 LSI-C86 でコンパイルされていました。これに従っ
  13.   てPower Up Kit も v2.0 までは、LSI-C86 v3.30 試食版を使っていま
  14.   した。しかし、compress や gzip の取り込みに伴いsmall model では
  15.   作成が困難な状況となってまいりました。LSI-C86 v3.30 試食版は、s
  16.   mall model のみサポートとなっていますので、ここで、LSI-C86 の使
  17.   用を諦めてPower Up Kit v3.0 からMS-C v7.0に変更しました。さらに
  18.   v3.7からのgzipの圧縮機能の取り込みにより、DOSの640Kのメモリ内で
  19.   は十分なパフォーマンスが発揮できなくなりました。そこで、GO32 と
  20.   いうDOS-EXTENDERの力を借りて386 以上のマシンで動作するtar32とし
  21.   て公開します。このソースのコンパイルには、同じくGO32の上で動く
  22.   DOS用GCCのdjgpp 1.12 が必要です。
  23.  
  24.   VC++ 1.0 版
  25.     機能的にはフルスペックですが、残りメモリが少ないため展開時のファ
  26.     イル名比較時に重複チェックを取りやめる場合があります。中間ファイ
  27.     ルは、XMS,EMS,DISK に作成されます。
  28.  
  29.   VC++ 4.0 版
  30.     現在、WIN32版は、VC++4.0でコンパイルされています。
  31.  
  32.   djgpp(GO32) 版
  33.     中間ファイルは作成されません。また、実行にGO32 v1.12 以降を必要
  34.     とするため、PC/AT 及びそのBIOSレベル互換機とPC98しか作動しません。
  35.     チェックは GCC 2.6.3 on GO32 v1.12 で行いました。フルスペックの
  36.     実行形式が出来ます。
  37.  
  38.   ソースのアーカイブには、TOWNS-gpp ,TCC++ 用のmake fileが含まれて
  39.   いますがこれらはあくまで移植しようとする方の参考に入れてあるだけ
  40.   です。
  41.  
  42. 『ファイル名重複防止機能の補強』
  43.     kmtar 2.00は、展開時のファイル名の重複を防ぐために一度展開した
  44.   ファイル名は、TABLE に記憶しておき次の展開時に重複していないかど
  45.   うかを調べます。オリジナルはテーブル確保のメモリが無くなればこの
  46.   機能を停止していたのですが、puk v3.7では、警告を出して作業を続行
  47.   します。
  48.  
  49. 『"tar.Z" "tar.z" ファイルからの直接展開』
  50.     compress 4.3d と gzip 1.2.4 のinflate関数を取り込みました。
  51.       ファイル形式は自動認識です、ファイル形式認識ルーチンは、gzip
  52.     とcompress 以外のもので、最初が NULL またはASCII 文字なら非圧縮
  53.     のtar と判断します。
  54.     また圧縮ファイル展開時はVC++版は、中間ファイルを作ります。gcc-2
  55.     .4.2 の展開の場合330K程度です。
  56.     compress は中間ファイルを作らないで実現できますが、gzip と仕様を
  57.     合わせるため同じく中間ファイルを作ります。
  58.       中間ファイルは、MS-C の仮想記憶関数を使って EMS XMS DISK の順
  59.     に作成します。EMS XMS に作成する場合は、比較的速いですが、DISK
  60.     に作成する場合は、自分で単純にDISK SWAPした方が速いので、EMS も
  61.     XMS も無い方は、makefile の BUFFERING マクロをコメントに落として
  62.     コンパイルして下さい。また、速度はgo32 版が最も高速です。
  63.  
  64.  
  65. 『圧縮ファイルの直接吐き出し』
  66.   gzip 1.2.4のdeflate関数を取り込んだため、圧縮しての吐き出しが可
  67.   能です。VC++ 版は、中間ファイルを作成しますが、GO32版は作成しま
  68.   せん。圧縮形式はgzip のものだけです。でもgnutarと異なり圧縮レベ
  69.   ルの指定が可能です。
  70.  
  71. 『マシン認識ルーチン』
  72.       K369 氏のアドバイスで 0xFFFF0003 からの2byte を見て決めています。
  73.     従って、B16, FMR/TOWNS 系や PC98 normal 系は自動認識出来る様ですが、
  74.     AT, J3100系は例外が有り、一筋なわでは行かないようです。
  75.     この辺の機能は強化して行きたいと思っていますが、日本で使われている
  76.     kmtar が動くDOS マシンはBIOS で見るとFMR,PC98,PCAT の3種類だと思う
  77.     ので_tar ファイルで指定すれば将来的にも問題とはならないでしょう。
  78.  
  79. 『kmori 氏がinternet上で公開されたgnu tar展開用の差分取り込み。』
  80.     kmori 氏がinternet 上で公開された差分は、DMA のバンク境界の対策を含
  81.     んでいましたがこれはAssistantIO 氏の前回の差分2.00->2.01 と部分的に
  82.     衝突するため、kmori氏の差分は一部分をカットしました。差分を頂いた
  83.     tmasu 氏 Paci 氏に感謝します。
  84.  
  85.  
  86. ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆
  87.       Technical DOC for kmtar 2.00  
  88.  
  89.        kmtar は、改良により機能はどんどん向上しても使用説明書などには必ずし
  90.        も反映されていません。
  91.          そこで、このパワーアップキットを作成するにあたり得た知見を説明書の
  92.        補足として収録します。
  93. ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆
  94.   1.名前の長さの制限
  95.     kmtar 内部では、ファイル名の長さは、100以下です。これを打破するために
  96.     ././@LongLink というエントリーの擬似ファイルが使われます。このファイル
  97.   のデータ領域に次のファイルのフルネームが入っています。tarnt096ではこの
  98.   形式に対応しました。
  99.  
  100.   2.DOS になじまない名前の自動変更に付いて
  101.     ファイル名に使えない文字は、アンダースコア "_" に変更されます。
  102.       例えば、 g++           ->   g__
  103.                Q+A           ->   Q_A
  104.                abc.dd.tar    ->   abc_dd.tar
  105.     また、キャラクタデバイスと重複する名前は先頭にアンダースコア "_"
  106.     が追加されます。
  107.       例えば、98では
  108.            clock.s    ->  _clock.s
  109.  
  110.   3.重複するファイル名の処理
  111.     展開時にファイル名が重複する場合は、拡張子を変更して区別をつけます。
  112.     例えば、
  113.               gcc.texinfo-1
  114.               gcc.texinfo-2
  115.               gcc.texinfo-3
  116.               gcc.texinfo-4
  117.               gcc.texinfo-5
  118.               gcc.texinfo-6
  119.     とのようなファイル群は
  120.               gcc.tex
  121.               gcc.000
  122.               gcc.001
  123.               gcc.002
  124.               gcc.003
  125.               gcc.004
  126.               gcc.005
  127.  
  128.     のように変更されます。従って、もとのファイル名との対応はつきません。
  129.  
  130.       さらに、ファイル名が重複するかどうかの判断は、メモリ上に展開したファ
  131.     イル名のリストを持っておりこのリストの参照によって判断します。kmtar は
  132.     LSI-C86のスモールモデルでコンパイルされているため、データ領域は64Kに限
  133.     られています。従って、余り多くのファイル名を保持する事は出来ません。実
  134.     験では、ほぼ500 程度でした。例えば、glibc103.tarでは、ファイル名の重複
  135.     チェック機構は正常に作動しません。
  136.  
  137.   4.機種依存性について
  138.       kmtar は、NEWS などワークステーションのディスクを読めるようにBIOS レ
  139.     ベルの物理読みだしをサポートしています。機種依存するのは、この部分のル
  140.     ーチンです。従って他の部分は、DOS にのみ依存します。つまり通常の使用を
  141.     する限りDOS 汎用です。
  142.  
  143.   5.漢字のファイル名の取扱い
  144.       kmtar は漢字のファイル名ディレクトリ名の取扱いが可能です。
  145.   
  146.   6.@response_file の大きさ
  147.       @response_file は、別名ファイルを読み込むファイルですが、これを格納
  148.       する配列の大きさは、1000 です。
  149.  
  150.   7.x コマンドでワイルドカード展開が出来るとchange.log に有りますが、ワイル
  151.     ドカードと言うより簡易正規表現が出来ます。便利ですよ。
  152.     ( PUK 適用後のtar.doc 参照 )
  153.  
  154.    以上
  155.