「[[Open棟梁 wiki>https://opentouryo.osscons.jp]]」は、「[[Open棟梁Project>https://github.com/OpenTouryoProject/]]」,「[[OSSコンソーシアム .NET開発基盤部会>https://www.osscons.jp/dotNetDevelopmentInfrastructure/]]」によって運営されています。

-[[戻る>リリース情報]]

*目次 [#p14e365a]
#contents

*概要 [#sa0c2baa]
**改善点 [#ved121d6]
-[[v01-72>リリース情報#g5e9bdde]]から、[[NuGet利用>#mda95a7a]]を開始した。~
これによりビルド・システムは大幅に改善した。

-[[v02-00>リリース情報#j62bae77]]から、[[ASP.NET の Modernization>https://techinfoofmicrosofttech.osscons.jp/index.php?ASP.NET%20%E3%81%AE%20Modernization]]により、~
[[NuGet利用>#l902543f]]を大幅に拡大し、更なるビルド・システムの改善を図った。

-[[v02-10>リリース情報#j62bae77]]から、[[NuGet登録>#l902543f]]を行い、
--更なるビルド・システムの改善と、
--リポジトリ内のソース・ファイルの重複の軽減を図る。

**参考 [#m3b342a5]
-NuGet Gallery | Packages matching Touryo~
https://www.nuget.org/packages?q=Touryo

*NuGet利用 [#mda95a7a]
NuGet利用を開始したことにより、ビルド・システムは大幅に改善した。

**[[v01-72>リリース情報#g5e9bdde]]から、 [#m04b1223]
-log4net や DotNetZip などのライブラリ管理を NuGet に変更。
-これにより、今まで別途ダウンロードする必要のあったDLLをNuGetから取得可能になった。

**[[v02-00>リリース情報#i11149ce]]から、 [#y5dd5d4e]
-[[ASP.NET Web Optimization>https://techinfoofmicrosofttech.osscons.jp/index.php?ASP.NET%20%E3%81%AE%20Modernization]]を行ったため、多数のコンポーネントをNuGet から追加した。

-また、[[Nuget使用時に「error MSB3086 Task could not find AL.exe」が発生>https://techinfoofmicrosofttech.osscons.jp/index.php?Nuget%E4%BD%BF%E7%94%A8%E6%99%82%E3%81%AB%E3%80%8Cerror%20MSB3086%20Task%20could%20not%20find%20AL.exe%E3%80%8D%E3%81%8C%E7%99%BA%E7%94%9F]]し、~
コレを解決するために、NuGet 2.7 以降の自動復元への移行を行った。

**[[v02-10>リリース情報#j62bae77]]から、 [#waae1717]
[[カスタマイズ可能レイヤ>ベースクラス2]]以外のライブラリを[[NuGet登録>#l902543f]]を行い、

-更なるビルド・システムの改善と、
-リポジトリ内のソース・ファイルの重複の軽減を図る。

*NuGet登録 [#l902543f]

**対象 [#t3904a3d]
***Public名前空間 [#zff034a6]
-Public.dll
-その他、各種Dam*.dll
--NuGetにdllが''適切に''登録されているものに限る
---DamManagedOdp
---DamMySQL
---DamPstGrS

--これにより、テンプレート版も既定で以下のDBをサポートできるようになる。
---SQL Server
---ODBC, OLEDB
---Oracle
---MySQL
---PostgreSQL

***Framework名前空間 [#v5069030]
-Framework.dll
-Framework.RichClient.dll

**構成の変更 [#b311f203]
***本体(母体) [#a8abbd84]
Public名前空間、Framework名前空間にのみ適用される。

-実装 ---> テストの容易性を維持するために本体(母体)側の基本的なビルド・システムは現行を維持する。
-しかし、NuGetパッケージに登録するためのTarget Framework毎のビルドが可能になるようにする。
--[[Target Framework>https://docs.microsoft.com/ja-jp/nuget/schema/target-frameworks#supported-frameworks]]として、以下をサポートする。
---%%net35%% ( .NET Standard がサポートしている .NET Framework は 4.5 以上)
---%%net452%% ( VS2015テンプレートが、既にnet46のため。)
---net46
---net47

--プロジェクト・ファイル(*.csproj)をTarget Framework毎に準備する。
---プロジェクト・ファイル(*.csproj)の名称付与基準は、「*{framework name}[{version}].csproj」とする。
---プロジェクト・ファイル(*.csproj)では、以下のようなビルド出力を行う(src側のフォルダ構成を参考にする)。~
以下は、[[*.nuspecファイル>https://techinfoofmicrosofttech.osscons.jp/index.php?NuGet%E3%83%91%E3%83%83%E3%82%B1%E3%83%BC%E3%82%B8%E3%81%AE%E9%96%8B%E7%99%BA%E3%81%A8%E5%85%AC%E9%96%8B]]のfilesセクションの定義例。
 <files>
   <file src="bin\Release\net46\MyAssembly.dll" target="lib\net46" />
   <file src="bin\Release\net461\MyAssembly.dll" target="lib\net461" />    
   <file src="bin\Release\uap\MyAssembly.dll" target="lib\uap" />    
   <file src="bin\Release\netcore\MyAssembly.dll" target="lib\netcore" />
 </files>

--Target Framework毎のプロジェクト・ファイル(*.csproj)を纏めるソリューション・ファイル(*.sln)を準備する。
---ソリューション・ファイル(*.sln)の名称付与基準は、「*{framework name}[{version}].sln」とする。
--ビルドバッチ(*.bat)では全てのTarget Framework毎のソリューション・ファイル(*.sln)をビルドする。

-本体(母体)側のVisual Studioのバージョン
--本体(母体)側は、最古のバージョンに固定するが、
--Public名前空間、Framework名前空間については、
---ソリューション・ファイル(*.sln)
---プロジェクト・ファイル(*.csproj)

>>を複数用意してmulti-version化する。

***テンプレート [#f6b03dfc]
Public名前空間、Framework名前空間が、Nuget化される。

-[[対象となる、Public名前空間、Framework名前空間のライブラリ>#t3904a3d]]の参照設定をNuGetに置き換える。

-以下のカスタマイズ可能レイヤ、テンプレート部分は、~
root_VS20XXのテンプレートに重複して保持する。

--カスタマイズ可能レイヤ
---Business名前空間
---各種カスタムコントロール
---各種サービスインターフェイス
--- , etc.

--テンプレート部分
---Web系
---C/S系
---バッチ系
--- , etc.

*nuspecファイル [#ifcb5f31]
以下にnuspecファイルのコンテンツの方向性を纏める。

**概要 [#vba9aa7f]
|#|要素|内容|h
|1|id|Touryo.Infrastructure.Public, etc.|
|2|title|OpenTouryo.Public, etc.|
|3|version|・02-00 -> 2.0.0&br;・02-10 - > 2.1.0&br;・α・β -> [[こちら>https://techinfoofmicrosofttech.osscons.jp/index.php?NuGet%E3%83%91%E3%83%83%E3%82%B1%E3%83%BC%E3%82%B8%E3%81%AE%E9%96%8B%E7%99%BA%E3%81%A8%E5%85%AC%E9%96%8B#r8c14f07]]|
|4|authors|OSS Consortium .net subcommittee(※ comma 区切り)|
|5|owners|daisukenishino77(※ comma 区切り)|
|6|projectUrl|https://github.com/OpenTouryoProject|
|7|licenseUrl|https://github.com/OpenTouryoProject/OpenTouryo/blob/master/license/LICENSE.txt|
|8|iconUrl|64 * 64.icoファイルを別途準備してリンク&br; - https://jyn.jp/iconfile_how_to_create/#i-5&br; - https://opentouryo.osscons.jp/OpenTouryo.ico|
|9|releaseNotes|https://github.com/OpenTouryoProject/OpenTouryo/releases|
|10|requireLicenseAcceptance|true (エンプラ風)|
|11|tags|OpenTouryo(※ space 区切り)|
|12|summary|概要説明文(一覧用)|
|13|description|詳細説明文|
|14|frameworkAssemblies - frameworkAssembly|.NET Frameworkアセンブリへの参照だが、テンプレート・プロジェクト経由の利用なので必須ではない。|
|15|dependencies - dependency|NuGetパッケージへの参照だが、テンプレート・プロジェクト経由の利用なので必須ではない。|
|16|files - file|複数のTarget Frameworksのサポートする場合、Target Frameworks向けのassemblyを直接指定する|
|17|contentFiles - file|該当無し|


**参考 [#o3af6449]
https://github.com/OpenTouryoProject/OpenTouryo/blob/develop/root/programs/C%23/NuGet/template.nuspec

>★ は必須入力

**Public, Framework [#uaf034ae]
共通部品とフレームワーク

***Public [#eb5af401]
https://github.com/OpenTouryoProject/OpenTouryo/blob/develop/root/programs/C%23/NuGet/Public.nuspec

***Framework [#m5957d45]
-https://github.com/OpenTouryoProject/OpenTouryo/blob/develop/root/programs/C%23/NuGet/Framework.nuspec
-https://github.com/OpenTouryoProject/OpenTouryo/blob/develop/root/programs/C%23/NuGet/Framework.RichClient.nuspec

**DataAccess [#ucc38ee5]
データーアクセス部品

***DamManagedOdp [#be7d9f19]
https://github.com/OpenTouryoProject/OpenTouryo/blob/develop/root/programs/C%23/NuGet/DamManagedOdp.nuspec

***DamPstGrS [#m14b4102]
https://github.com/OpenTouryoProject/OpenTouryo/blob/develop/root/programs/C%23/NuGet/DamPstGrS.nuspec

***DamMySQL [#d1867e65]
https://github.com/OpenTouryoProject/OpenTouryo/blob/develop/root/programs/C%23/NuGet/DamMySQL.nuspec

**カスタマイズ [#ref774bb]
Public名前空間、Framework名前空間をカスタマイズが必要になった場合は、~
[[本体(母体)>#a8abbd84]]側からソースコードを取出してローカルでビルド・参照設定を行う。


*.NET Standard [#l070e9eb]
-Public名前空間から、.NET Standardに対応可能なクラスライブラリを抽出、~
Standard名前空間のStandard.dllとして、NuGetパッケージに登録する。

-このライブラリは、Linuxや、Win10 IoT Core上で動作する~
プログラム開発でユーティリティとして利用されることを想定する。

*注意 [#x579d11b]
**一度登録すると通常消せない。 [#g6945e13]
-バージョン番号を上げてアップロードすることでアップデートする。
-必要に応じて、別途、運営に連絡して削除することはできる。

**ビルドとデバッグ [#y6c3d936]
***ビルド [#x1b78e6d]
'*.pdbを同梱する場合は、ビルド時のフォルダ構成に注意すること。

***デバッグ [#l1981569]
なお、Debugが必要になるときの手順も確立しておく必要がある。

**Dependencies [#u9a8011d]
'*.nspecに明記していなくても、自動で反映される~
(package.configなのか、バイナリの解析によるのか不明だが)

***.NET Framework [#z42d92a5]
***.NET Standard [#rf8521d0]

*参考 [#maff7024]
**マイクロソフト系技術情報 Wiki [#c6789f33]
***[[NuGet>https://techinfoofmicrosofttech.osscons.jp/index.php?NuGet]] [#z83884b2]

-[[NuGet を使用したパッケージ管理>https://techinfoofmicrosofttech.osscons.jp/index.php?NuGet%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%9F%E3%83%91%E3%83%83%E3%82%B1%E3%83%BC%E3%82%B8%E7%AE%A1%E7%90%86]]

-[[NuGetパッケージの開発と公開>https://techinfoofmicrosofttech.osscons.jp/index.php?NuGet%E3%83%91%E3%83%83%E3%82%B1%E3%83%BC%E3%82%B8%E3%81%AE%E9%96%8B%E7%99%BA%E3%81%A8%E5%85%AC%E9%96%8B]]

-,etc.

***[[.NETバージョンアップ > .NET Framework のバージョン>https://techinfoofmicrosofttech.osscons.jp/index.php?.NET%E3%83%90%E3%83%BC%E3%82%B8%E3%83%A7%E3%83%B3%E3%82%A2%E3%83%83%E3%83%97#kc9b3965]] [#i7606ad2]

トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS