home *** CD-ROM | disk | FTP | other *** search
/ DOS/V Power Report 2001 January / VPR0101A.BIN / OLS / TAR32053 / tar32053.exe / SDK / TAR32SDK.TXT < prev    next >
Text File  |  1999-05-23  |  8KB  |  146 lines

  1. ***************************************************************************
  2. TAR32.DLL SDK(Sotware Developers Kit)
  3. 開発者向けの説明
  4. ***************************************************************************
  5. ここではTAR32.DLLを用いたプログラム作成について簡単に説明します。
  6.  
  7. ●このディレクトリのファイル一覧
  8. _tar:        DOS版TARに付属のアーカイブのデフォルト定義(なくてもいい(はず))
  9. tartech.doc:    DOS版TARに付属のTARついての資料
  10. change.nt:    DOS版TARに付属のバージョン履歴
  11. readment.txt:    DOS版TARに付属の説明
  12. api_tar.txt:    TAR32.DLLのAPIの説明
  13. dll_tech.txt:    DLL版TAR開発にあたっての資料(たわごと)
  14. tar32sdk.txt:    この文書
  15. tar32.h:    TAR32 APIのヘッダファイル
  16. cmd_tar.txt:    TAR32 のコマンドについての説明。(Tar関数から利用する)
  17. tar32.lib:    TAR32.DLLのリンクライブラリ。(VC++5用)
  18.  
  19. なお、ファイル名が「~e.txt」となっているファイルは簡単かついいかげんな英語文書です。
  20.  
  21. ●説明(DLL版独自の仕様など)
  22.   TAR32.DLLはTAR/TAR.GZ(TGZ)/TAR.Z(TAZ)/TAR.BZ2/GZIP(GZ)/COMPRESS(Z)/BZIP2(BZ2)のファイルを圧縮/展開するためのライブラリです。
  23.   kmtar Powerupkit for WIN-NTを元に作成しましたので、基本的なコマンドはkmtarと同じです。
  24.   但し、DLL化にあたり、主に次の点を変更しています。
  25. ・TARの絡まないGZ,Z単独をファイルを圧縮/展開できるようにした。(Gオプション)
  26.   (GZIP.DLLやCOMPRESS.DLLを別に作るのもなんなので,,)
  27.      tar -Gxvf filename.gz filename
  28.   というようにして使えます。
  29.   Ver0.45以降はGオプションがなくても展開できます。
  30. ・長いファイル名のサポート(これが主目的か?)
  31. ・標準出力への展開(pオプション)
  32.      tar -pxf foo.tgz file.txt
  33.   というようにすると,file.txtの内容をバッファに展開して返します。
  34. ・間接引数(レスポンス(response)ファイル)をサポート。(UNLHA32.DLL互換)
  35.   もともとのtarの@はファイルの一覧を並べることしかできなかったが,
  36.   これをUNLHA32.DLLなどと同じように,@fileとすると,ファイルの中身をコマンド
  37.   行引数として取り込むようにした。(unix toolsのルーチンを使用)
  38. ・ワイルドカード(*,?)ルールをUNLHA32.DLLとほぼ互換の方法にした。
  39.   *.*ですべてのファイルにマッチするようにした。(今まではディレクトリなどに
  40.   マッチしなかった。)(--check-all-pathオプションで変更可能)
  41. ・基準ディレクトリをunlha32.dllと同じように指定できるようにした。
  42.   オリジナルはoオプションを用いていたが、\で終わるパス名を指定できるようにした。但し、展開先は1つのみ。(tar -zxvf foo.tgz pathname\ [files...])
  43. ・--use-directory=0とすることで、パス名を展開せず、ファイル名のみ圧縮/展開できるようにした。(unlha32.dllのaコマンド、eコマンドとほぼ同じように..)
  44. ・NKF32.DLLがあれば、ファイル名の漢字コード(自動判別)変換を行います。
  45.   Unix環境でEUCで保存されたファイル名を取り出すことができます。
  46.   NKFのオプションは--nkf-set-filename-conversion及び--nkf-get-filename-conversionにて行うこともできます。
  47. ・rコマンドでファイルが存在しない場合cコマンドと同様に動作するようにした。
  48. ・--self-extracting=1オプションで自己解答書庫が作成できる(オマケ)
  49. ・bzip2形式の圧縮・解凍のサポート。
  50.       tar -Bcvf foo.tar.bz2 file.txt
  51.   とすることで作成できます。
  52.  
  53. 詳しくはcmd_tar.txtなどを参照してください。
  54. また,FindFirst,FindNext系の関数もサポートしています。
  55. Ver0.30以降ではSetOwnerWindow系の関数もサポートしています。
  56. APIについてはapi_tar.txtを参照してください。
  57.  
  58. ●使用にあたって。
  59. ・具体的なコマンドについては,cmd_tar.txtを見て下さい。コマンド例も載っています。
  60. ・Gオプションを用いることで,GZ/Zの単独圧縮/解凍ができます(Zの圧縮を除く)
  61. ・pオプションを用いることで,ファイルの内容をバッファに書き出すことができます。
  62. ・すべてのファイルについての情報(INDIVIDUALINFO)を得る場合は
  63. FinfFirst関数の第二引数には,"*.*"又は,""(空文字列)を与えて下さい。
  64. (Visual Basicからは""の代わりにChr$(0)を与えて下さい)
  65. なるべく""の使用を勧めます。
  66.  
  67. ・単純にTGZファイルを圧縮する場合は,-zcvf foo.tgz foo のようにしてください。
  68. ・単純にTGZファイルを展開する場合は,-zxvf foo.tgz foo のようにしてください。
  69. ・単純にTAR.BZ2ファイルを圧縮する場合は,-Bcvf foo.tgz foo のようにしてください。
  70. (その他さまざまな例がcmd_tar.txtの最後の方に載っています。)
  71.  
  72. ●注意
  73. COMPRESSの圧縮はできません。
  74. まだできたてなので,変な所があると思います。FWINDC MES#3やメールなどで言ってください。
  75.  
  76. ●Tar形式について
  77. tarはUnix系のOSでアーカイバ(書庫)作成によく使われるフォーマットです。
  78. ただ、tarはlhaのように圧縮しながら書庫を作成するのではなく、複数のファイルを1つにまとめるだけです。
  79.  そこで、gzipという圧縮ソフトでtar形式のファイルを圧縮します。こうしてできるのがtar.gz形式の書庫です。
  80.  このような構造上、tar.gz書庫の中のファイルの中味、ファイル名、その他のファイル情報は一度gzip形式を展開してtar形式に直さないとわかりません。これはlhaがそれぞれのファイル情報を簡単にすばやくのぞける点と異なっています。また逆にtar.gzは複数のファイルをまとめて圧縮するので圧縮率は一般にlhaよりあがります。
  81.   また、compress形式で圧縮したtar.Z書庫もありますが、普通はtar.gzの方が圧縮率が高く、tar.gzの方がよく利用されているようです。
  82.   次に、gzip形式単独で見てみると、これはファイル名などのファイル情報を含まず、ただ1つのファイルを圧縮するだけです。(ファイル情報を持っているgzip形式もあるようですが、、)
  83.   bzip2形式は最近でてきた新しいフォーマットです。gzipより1-2割ほど圧縮率が高いことが多いようです。
  84.  
  85. ●LZW特許
  86. ・compressのアルゴリズムはLZW(Lempel-Ziv method)と深く関わっています。
  87. ・LZWはUNYSYS社がアメリカ、日本などで特許を取得しています。
  88. ・tar.Z形式の展開をサポートすると、特許に抵触する可能性があるかもしれません。
  89. ・アルゴリズムと特許の関係など微妙な問題をはらんでいます。
  90. ・この問題に関しては必要に応じて各自で判断・処理を行ってください。
  91.  
  92. ●参考資料
  93. =========FEXT LIB#3=================
  94.  421  SGL00213 96/09/24  192539  376 B TARNT096.LZH kmtar for WIN32 v0.96
  95.     このtar32.dllはkmtar PowerUp kit for WINNT32 ver0.96を元に
  96.     作成されています。したがって、基本的な仕様はうけつがれています。
  97. =========FEXT LIB#13==================
  98.  488  RGD00165 96/10/28   71947   27 B GZP124B .ZIP GNU gzip 1.2.4
  99.  489  RGD00165 96/10/28  253425    6 B GZP124S .ZIP GNU gzip 1.2.4 sources
  100.     kmtar Power Up Kitはgzip ver1.2.4を受け継いでいるようです。
  101. =========FGALTLB LIB#4===============
  102.  516  KFA05024 95/04/04  143095 2589 B GZ124D5F.LZH gzip 1.2.4(MSDOS_05)FullSet
  103.      kmtar Power Up Kitはgzip ver1.2.4を受け継いでいるようです。
  104.     特にこのファイルはマニュアルを含めて日本語化されているようです。
  105.     readme.jpnには「zip vs. gzip」でzipとgzipの違いについてかかれてます。
  106.     ここでのzipについてはlhaもほぼ当てはまると思います。    
  107. ==========FEXT LIB#4===============
  108.   74  NBA00546 91/11/25   38486 1197 B COMP16  .LZH compress 4.3d
  109.     kmtar Power Up Kitはcompress 4.3dを組み込んでいるようです。
  110. ===========FEXT LIB#4===================
  111.  158  SGL00213 95/04/01   76675  962 B PUK37BN .LZH kmtar Power Up v3.7 BIN
  112.  160  SGL00213 95/04/01  140775  145 B PUK37SRC.LZH kmtar Power Up v3.7-SRC
  113.  161  SGL00213 95/04/05      10   48 B PUK37SRC.MIS PUK37SRC の入れ忘れfile
  114.     kmtar Power Up KitのDOS版です。
  115. ==========FWINAL LIB#11=================
  116.  345  GCA02652 96/07/09   14528  349 B NKF32100.LZH Network Kanji Filter32 1.00
  117.     このNKF32.DLLがあれば、ファイル名の漢字コード自動判別変換を行います。
  118.     ただ一つ残念なのは、ソースがなくなったため、バージョンアップの可能性が
  119.     非常に低いということです。
  120. ==========FEXT LIB#4====================
  121.  224  SDI00618 96/09/08   32556   88 B NKF16   .LZH 漢字コード変換フィルタ
  122.     NKF.EXE(DOS版)です。NKF32.DLLは基本的にこの仕様をうけついでいるようです。
  123. ========================================
  124. http://www.csdinc.co.jp/archiver/      (統合化ホームページ)
  125.     アーカイバ統合化計画に関するさまざまな情報があります。DLLやアプリケーションがここからダウンロードできます。
  126.  
  127. ●その他
  128. このDLLを使ったソフトが増えてくれるとうれしいです。
  129. # いまのところほとんどないようですし。。(^^;
  130. バグ,感想などは会議室かメールでどしどしどうぞ。
  131. (どんなバグ、要望などでも言ってくれた方がうれしいです)
  132.  
  133. ●著作権など
  134. もともとのkmtarはPublic Domain Softwareでしたが,gzip/compressというGPLのソフト
  135. を取り込んだため,kmtar Power Up kitはGPLに従うようです。GPLのソフトを変更
  136. したものは,GPLに従わないといけないため,このDLL版も当然GPLであり,また,
  137. ソースプログラムも公開しています。
  138.   DLL版では間接引数展開にUnix Tools Ver2.09cに付属のsetarg.cを(改造して)
  139. 使わせてもらってます。これはもともと斉藤靖氏によって書かれたものを新出さん
  140. が改良されたものです。詳しくはsetarg.h/setarg.cを見て下さい。
  141.   なお,以下のファイルは私(吉岡)が追加したもので,この部分については自由に
  142. 使ってもらっても結構です。
  143. defconf.h,ioctrl.h,ioctrl.c,mkvcsrc.bat,mkvcsrc.pl,nkf.h,nkf.c,tar32.cpp,tar32.h,dfltwin.c,dfltwin.h,tarmsg.h,tarmsg.c
  144.  
  145. (tar32.hはほとんどunlha32.h/unzip32.hのコピーだけど,自由に使っていいようです。)
  146.