1 // project created on 2007/09/08 at 20:20
\r
4 using System.Collections.Generic;
\r
6 using NaGet.Packages;
\r
7 using NaGet.Packages.Install;
\r
8 using NaGet.SubCommands;
\r
13 class DownloadListener
\r
15 private string line = null;
\r
18 /// lineのコンソール上における長さ
\r
20 private int lineWidth = 0;
\r
22 public void OnDownload(object sender, DownloadEventArgs a) {
\r
25 int newpos = (lineWidth <= 0)? 0 : Console.CursorLeft - lineWidth;
\r
26 if (newpos < 0) newpos = 0;
\r
29 Console.CursorLeft = newpos;
\r
30 for (int i = 0; i < lineWidth && Console.CursorLeft < Console.BufferWidth; i++) {
\r
33 Console.CursorLeft = newpos;
\r
35 line = null; lineWidth = 0;
\r
40 case DownloadEventType.INITED:
\r
41 line = "starting...";
\r
43 case DownloadEventType.CONNECTED:
\r
44 case DownloadEventType.DOWNLOADING:
\r
45 line = a.TaskMessage;
\r
47 case DownloadEventType.COMPLETED:
\r
51 case DownloadEventType.ERROR:
\r
52 Console.Write("interrupted! ERROR!");
\r
58 int posOld = Console.CursorLeft;
\r
59 Console.Write(line);
\r
60 lineWidth = Console.CursorLeft - posOld;
\r
67 private Downloader downloader;
\r
69 private PackageListsManager pkgListMan;
\r
72 /// サイレントインストールをするか否か
\r
74 private bool silent = false;
\r
78 downloader = new Downloader();
\r
79 DownloadListener dl = new DownloadListener();
\r
80 downloader.DownloadEventRaised += new EventHandler<DownloadEventArgs>(dl.OnDownload);
\r
82 pkgListMan = new PackageListsManager();
\r
83 pkgListMan.LoadPackageLists();
\r
86 public void Update()
\r
91 public void LocalUpdate()
\r
96 public void update(bool downloadPackageListFlag)
\r
98 NaGet.SubCommands.NaGetUpdate tasks = new NaGet.SubCommands.NaGetUpdate(pkgListMan, downloadPackageListFlag);
\r
99 tasks.TaskSetRaised += delegate(object sender, NaGetTaskSetEventArgs e) {
\r
101 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
103 case NaGetTaskSetEventType.COMPLETED:
\r
104 Console.WriteLine("Done.");
\r
106 case NaGetTaskSetEventType.STARTED_TASKSET:
\r
107 Console.Write(" " + e.TaskMessage);
\r
109 case NaGetTaskSetEventType.COMPLETED_TASKSET:
\r
110 Console.WriteLine(" ... Done. [{0}%]", (int) e.TaskProgressPercent);
\r
112 case NaGetTaskSetEventType.INFO:
\r
113 Console.WriteLine(" " + e.TaskMessage);
\r
115 case NaGetTaskSetEventType.ERROR:
\r
116 case NaGetTaskSetEventType.WARNING:
\r
117 Console.WriteLine(" [Error]" + e.TaskMessage);
\r
121 DownloadListener dl = new DownloadListener();
\r
122 tasks.Downloader.DownloadEventRaised += dl.OnDownload;
\r
127 public void CheckUpgrade()
\r
129 PackageList<Package> packageList = pkgListMan.AvailablePkgList;
\r
131 VersionComparetor verComp = new VersionComparetor();
\r
133 foreach (InstalledPackage pkg in pkgListMan.InstalledPkgList) {
\r
134 Package avaiablePkg = packageList.GetPackageForName(pkg.Name);
\r
136 if (avaiablePkg != null) {
\r
137 if (verComp.Compare(pkg.Version, avaiablePkg.Version) < 0 &&
\r
138 pkgListMan.InstalledPkgList.GetPackageForPackage(pkg.Name, avaiablePkg.Version) == null) {
\r
140 Console.WriteLine("{0} ({1}) => ({2})", pkg.Name, pkg.Version, avaiablePkg.Version);
\r
144 foreach (InstalledPackage pkg in pkgListMan.SystemInstalledPkgList) {
\r
145 Package avaiablePkg = packageList.GetPackageForName(pkg.Name);
\r
147 if (avaiablePkg != null) {
\r
148 if (verComp.Compare(pkg.Version, avaiablePkg.Version) < 0 &&
\r
149 pkgListMan.SystemInstalledPkgList.GetPackageForPackage(pkg.Name, avaiablePkg.Version) == null) {
\r
151 Console.WriteLine("{0} ({1})@sys => ({2})", pkg.Name, pkg.Version, avaiablePkg.Version);
\r
157 public void Search(string keys)
\r
159 foreach(Package package in pkgListMan.AvailablePkgList.Search(keys)) {
\r
160 Console.WriteLine("{0} ({1}) - {2}", package.Name, package.Version, package.Summary);
\r
163 foreach(InstalledPackage package in pkgListMan.InstalledPkgList.Search(keys)) {
\r
164 Console.WriteLine("{0} ({1})[@install] - {2}", package.Name, package.Version, package.Summary);
\r
167 foreach(InstalledPackage package in pkgListMan.SystemInstalledPkgList.Search(keys)) {
\r
168 Console.WriteLine("{0} ({1})[@sys] - {2}", package.Name, package.Version, package.Summary);
\r
172 public void Show(string packagename)
\r
174 PackageList<Package> allPkgs = new PackageList<Package>();
\r
175 allPkgs.AddPackages(pkgListMan.GetAllPackages());
\r
177 foreach (Package pkg in allPkgs.GetPackagesForName(packagename)) {
\r
178 Console.WriteLine("Package: {0}", pkg.Name);
\r
179 Console.WriteLine("Version: {0}", pkg.Version);
\r
180 Console.WriteLine("Summary: {0}", pkg.Summary);
\r
181 if (pkg.Url != null) Console.WriteLine("Website: {0}", pkg.Url.Href);
\r
182 if (pkg.Tags != null) Console.WriteLine("Tag: {0}", pkg.Tags.ToLower());
\r
183 Console.WriteLine("Type: {0}", pkg.Type);
\r
184 if (pkg.License != null) Console.WriteLine("License: {0}", pkg.License);
\r
185 if (pkg is InstalledPackage) Console.WriteLine("State: Installed");
\r
186 Console.WriteLine("Repository: {0}", pkg.PackageListName);
\r
188 if (pkg.Description != null) {
\r
189 Console.WriteLine("Description:");
\r
190 Console.WriteLine(pkg.Description);
\r
192 Console.WriteLine();
\r
196 public void Download(string[] packagenames)
\r
198 Installation[] installations = null;
\r
200 List<Package> downloadList = new List<Package>();
\r
202 foreach(string packagename in packagenames) {
\r
203 Package foundPackage = pkgListMan.AvailablePkgList.GetPackageForName(packagename);
\r
204 if (foundPackage == null) {
\r
205 Console.WriteLine("E: Couldn't find package "+packagename);
\r
206 Environment.Exit(1);
\r
208 if (! downloadList.Contains(foundPackage)) {
\r
209 downloadList.Add(foundPackage);
\r
213 installations = new Installation[downloadList.Count];
\r
214 for (int i = 0; i < installations.Length; i++) {
\r
215 installations[i] = new Installation(downloadList[i]);
\r
219 Console.WriteLine("The following packages will be downloaded:");
\r
220 Console.WriteLine(" {0}", Installation.ToString(installations));
\r
221 if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
222 Console.WriteLine("Abort.");
\r
223 Environment.Exit(0);
\r
226 NaGet.SubCommands.NaGetDownloadToCache tasks = new NaGet.SubCommands.NaGetDownloadToCache(pkgListMan, installations);
\r
227 tasks.TaskQueryRaised += delegate(object sender, NaGetTaskQueryArgs e) {
\r
228 char result = '\u0000';
\r
229 if (e.SelectionFlag == (NaGetTaskQueryResult.CONTINUE | NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
230 result = AllGet.Util.Query(e.Message + " [y/R/n]?", "yrn", 'r');
\r
231 } else if (e.SelectionFlag == (NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
232 result = AllGet.Util.Query(e.Message + " [R/n]?", "rn", 'r');
\r
233 } else if (e.SelectionFlag == NaGetTaskQueryResult.CONTINUE) {
\r
234 result = AllGet.Util.Query(e.Message + " [Y]?", "y", 'y');
\r
236 result = AllGet.Util.Query(e.Message + " [Y/n]?", "yn", 'y');
\r
241 return NaGetTaskQueryResult.CONTINUE;
\r
243 return NaGetTaskQueryResult.CANCEL;
\r
245 return NaGetTaskQueryResult.RETRY;
\r
247 return NaGetTaskQueryResult.CANCELED_AUTOMATICALLY;
\r
250 tasks.TaskSetRaised += delegate(object sender, NaGetTaskSetEventArgs e) {
\r
252 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
254 case NaGetTaskSetEventType.COMPLETED:
\r
255 Console.WriteLine("Done.");
\r
257 case NaGetTaskSetEventType.STARTED_TASKSET:
\r
258 Console.Write(" " + e.TaskMessage);
\r
260 case NaGetTaskSetEventType.COMPLETED_TASKSET:
\r
261 Console.WriteLine(" ... Done. [{0}%]", (int) e.TaskProgressPercent);
\r
263 case NaGetTaskSetEventType.INFO:
\r
264 Console.WriteLine(" " + e.TaskMessage);
\r
266 case NaGetTaskSetEventType.ERROR:
\r
267 case NaGetTaskSetEventType.WARNING:
\r
268 Console.WriteLine(" [Error] " + e.TaskMessage);
\r
272 DownloadListener dl = new DownloadListener();
\r
273 tasks.Downloader.DownloadEventRaised += dl.OnDownload;
\r
278 public void Install(string[] packagenames)
\r
280 if (! NaGet.Utils.IsAdministrators()) {
\r
281 Console.WriteLine("W: you are not administrators!");
\r
284 Installation[] installations = null;
\r
286 List<Package> downloadList = new List<Package>();
\r
288 foreach(string packagename in packagenames) {
\r
289 Package foundPackage = pkgListMan.AvailablePkgList.GetPackageForName(packagename);
\r
290 if (foundPackage == null) {
\r
291 Console.WriteLine("E: Couldn't find package "+packagename);
\r
292 Environment.Exit(1);
\r
294 if (! downloadList.Contains(foundPackage)) {
\r
295 downloadList.Add(foundPackage);
\r
299 installations = new Installation[downloadList.Count];
\r
300 for (int i = 0; i < installations.Length; i++) {
\r
301 installations[i] = new Installation(downloadList[i]);
\r
303 installations[i].Silent = silent; // サイレントインストールのフラグの設定
\r
305 if (! installations[i].IsInstallablePackage()) {
\r
306 Console.WriteLine("E: Can not install package {0} to your PC.", installations[i].ToString());
\r
307 Environment.Exit(1);
\r
312 Installation[] depInstallations;
\r
314 Installation[] resolved;
\r
315 DependeciesResolver.ResolveInstallations(installations, pkgListMan, out resolved, out depInstallations);
\r
316 installations = resolved;
\r
319 Console.WriteLine("The following packages will be downloaded:");
\r
320 Console.WriteLine(" {0}", Installation.ToString(installations));
\r
321 if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
322 Console.WriteLine("Abort.");
\r
323 Environment.Exit(0);
\r
326 NaGet.SubCommands.NaGetInstall tasks = new NaGet.SubCommands.NaGetInstall(pkgListMan, installations);
\r
327 tasks.TaskQueryRaised += delegate(object sender, NaGetTaskQueryArgs e) {
\r
328 char result = '\u0000';
\r
329 if (e.SelectionFlag == (NaGetTaskQueryResult.CONTINUE | NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
330 result = AllGet.Util.Query(e.Message + " [y/R/n]?", "yrn", 'r');
\r
331 } else if (e.SelectionFlag == (NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
332 result = AllGet.Util.Query(e.Message + " [R/n]?", "rn", 'r');
\r
333 } else if (e.SelectionFlag == NaGetTaskQueryResult.CONTINUE) {
\r
334 result = AllGet.Util.Query(e.Message + " [Y]?", "y", 'y');
\r
336 result = AllGet.Util.Query(e.Message + " [Y/n]?", "yn", 'y');
\r
341 return NaGetTaskQueryResult.CONTINUE;
\r
343 return NaGetTaskQueryResult.CANCEL;
\r
345 return NaGetTaskQueryResult.RETRY;
\r
347 return NaGetTaskQueryResult.CANCELED_AUTOMATICALLY;
\r
350 tasks.TaskSetRaised += delegate(object sender, NaGetTaskSetEventArgs e) {
\r
352 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
354 case NaGetTaskSetEventType.COMPLETED:
\r
355 Console.WriteLine("Done.");
\r
357 case NaGetTaskSetEventType.STARTED_TASKSET:
\r
358 Console.Write(" " + e.TaskMessage);
\r
360 case NaGetTaskSetEventType.COMPLETED_TASKSET:
\r
361 Console.WriteLine(" ... Done. [{0}%]", (int) e.TaskProgressPercent);
\r
363 case NaGetTaskSetEventType.INFO:
\r
364 Console.WriteLine(" " + e.TaskMessage);
\r
366 case NaGetTaskSetEventType.ERROR:
\r
367 case NaGetTaskSetEventType.WARNING:
\r
368 Console.WriteLine(" [Error] " + e.TaskMessage);
\r
372 DownloadListener dl = new DownloadListener();
\r
373 tasks.Downloader.DownloadEventRaised += dl.OnDownload;
\r
378 public void Remove(string[] packagenames)
\r
380 if (! NaGet.Utils.IsAdministrators()) {
\r
381 Console.WriteLine("W: you are not administrators!");
\r
384 this.LocalUpdate();
\r
386 PackageList<InstalledPackage> installedPkgList = new PackageList<InstalledPackage>();
\r
387 installedPkgList.AddPackages(pkgListMan.GetAllInstalledPackages());
\r
389 Uninstallation[] uninstallations = new Uninstallation[packagenames.Length];
\r
390 for (int i = 0; i < packagenames.Length; i++) {
\r
391 InstalledPackage pkg = installedPkgList.GetPackageForName(packagenames[i]);
\r
394 Console.WriteLine("E: could not found package " + packagenames[i]);
\r
395 Environment.Exit(1);
\r
398 uninstallations[i] = new Uninstallation(pkg);
\r
401 // if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
402 // Console.WriteLine("Abort.");
\r
403 // Environment.Exit(0);
\r
406 NaGet.SubCommands.NaGetUninstall tasks = new NaGet.SubCommands.NaGetUninstall(pkgListMan, uninstallations);
\r
407 tasks.TaskSetRaised += delegate(object sender, NaGetTaskSetEventArgs e) {
\r
409 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
411 case NaGetTaskSetEventType.COMPLETED:
\r
412 Console.WriteLine("Done.");
\r
414 case NaGetTaskSetEventType.STARTED_TASKSET:
\r
415 Console.Write(" " + e.TaskMessage);
\r
417 case NaGetTaskSetEventType.COMPLETED_TASKSET:
\r
418 Console.WriteLine(" ... Done. [{0}%]", (int) e.TaskProgressPercent);
\r
420 case NaGetTaskSetEventType.INFO:
\r
421 Console.WriteLine(" " + e.TaskMessage);
\r
423 case NaGetTaskSetEventType.ERROR:
\r
424 case NaGetTaskSetEventType.WARNING:
\r
425 Console.WriteLine(" [Error] " + e.TaskMessage);
\r
433 public void CleanCache(string[] packages)
\r
435 if (! Directory.Exists(NaGet.Env.ArchiveFolderPath)) {
\r
440 if (packages.Length == 0) {
\r
441 foreach (string folder in Directory.GetDirectories(NaGet.Env.ArchiveFolderPath)) {
\r
442 Directory.Delete(folder, true);
\r
446 foreach (string package in packages) {
\r
447 foreach (string folder in Directory.GetDirectories(NaGet.Env.ArchiveFolderPath, package+"*", SearchOption.TopDirectoryOnly)) {
\r
448 Directory.Delete(folder, true);
\r
454 Console.WriteLine("... Done.");
\r
460 string executeFileName = System.AppDomain.CurrentDomain.FriendlyName;
\r
461 Console.Write("Usage:");
\r
463 Console.WriteLine("\t{0} update|localupdate", executeFileName);
\r
464 Console.WriteLine("\t{0} search|show pkg1 [pkg2 ...]", executeFileName);
\r
465 Console.WriteLine("\t{0} cleancache [pkg ...]", executeFileName);
\r
466 Console.WriteLine("\t{0} download pkg1 [pkg2 ...]", executeFileName);
\r
467 Console.WriteLine("\t{0} [--quiet] install|uninstall pkg1 [pkg2 ...]", executeFileName);
\r
468 Console.WriteLine();
\r
469 Console.WriteLine("{0} is a simple command line interface for downloading and "+
\r
470 "installing packages. The most frequently used commands are update "+
\r
471 "and install.", executeFileName);
\r
472 Console.WriteLine();
\r
473 Console.WriteLine("Commands:");
\r
474 Console.WriteLine(" update - Retrieve new lists of packages");
\r
475 Console.WriteLine(" localupdate - Update installed-soft-list only");
\r
476 Console.WriteLine(" checkupgrade - Show upgraded-soft list");
\r
477 Console.WriteLine(" search - Search the package list for not a regex pattern");
\r
478 Console.WriteLine(" show - Show package detail");
\r
479 Console.WriteLine(" cleancache - Clear cached archived file(s)");
\r
480 Console.WriteLine(" download - Download only - do NOT install or unpack archives");
\r
481 Console.WriteLine(" install - Install new packages");
\r
482 Console.WriteLine(" remove - Uninstall packages");
\r
483 Console.WriteLine();
\r
486 public void FooBar()
\r
488 foreach (InstalledPackage pkg in pkgListMan.SystemInstalledPkgList) {
\r
489 Console.WriteLine("{0} : {1}", pkg.Name, pkg.UninstallInfo.UninstallString);
\r
495 foreach (UninstallInformation uInfo in RegistriedUninstallers.Uninstallers) {
\r
496 if (! uInfo.IsOSPatch && ! uInfo.IsSystemComponent) {
\r
497 Console.WriteLine("{0}", uInfo.DisplayName);
\r
504 // TODO スーパー牛さんパワー化
\r
506 string executeFileName = System.AppDomain.CurrentDomain.FriendlyName;
\r
507 Console.WriteLine("誰か {0} をスーパー牛さんパワー化してくれ", executeFileName);
\r
511 public static void Main(string[] args)
\r
513 // アーカイブSYSTEM32をパスに足す
\r
514 NaGet.Utils.AddDirectoryToPath(NaGet.Env.ArchiveSystem32);
\r
516 MainClass mc = new MainClass();
\r
518 if (args.Length == 0) {
\r
521 Environment.Exit(1);
\r
524 NaGet.ArgParser argParser = new NaGet.ArgParser();
\r
525 argParser["quiet"] = false;
\r
526 args = argParser.Parse(args);
\r
527 mc.silent = (bool) argParser["quiet"];
\r
528 } catch (ApplicationException e) {
\r
529 Console.WriteLine(e.Message);
\r
530 Environment.Exit(1);
\r
538 if (args.Length != 1) {
\r
539 Console.WriteLine("E: The update command takes no arguments");
\r
540 Environment.Exit(1);
\r
545 if (args.Length != 1) {
\r
546 Console.WriteLine("E: The update command takes no arguments");
\r
547 Environment.Exit(1);
\r
552 if (args.Length <= 1) {
\r
553 Console.WriteLine("E: You must give exactly one pattern");
\r
554 Environment.Exit(1);
\r
557 mc.Search(string.Join(" ", args, 1, args.Length - 1));
\r
560 if (args.Length <= 1) {
\r
561 Console.WriteLine("E: You must give exactly one pattern");
\r
562 Environment.Exit(1);
\r
565 for (int i = 1; i < args.Length; i++) {
\r
570 if (args.Length <= 1) {
\r
571 Console.WriteLine("E: Invalid operation download");
\r
572 Environment.Exit(1);
\r
574 string[] packages = new string[args.Length - 1];
\r
575 Array.Copy(args, 1, packages, 0, packages.Length);
\r
577 mc.Download(packages);
\r
581 if (args.Length <= 1) {
\r
582 Console.WriteLine("E: Invalid operation install");
\r
583 Environment.Exit(1);
\r
585 string[] packages = new string[args.Length - 1];
\r
586 Array.Copy(args, 1, packages, 0, packages.Length);
\r
588 mc.Install(packages);
\r
591 case "checkupgrade":
\r
595 if (args.Length <= 1) {
\r
596 Console.WriteLine("E: Invalid operation remove");
\r
597 Environment.Exit(1);
\r
599 string[] packages = new string[args.Length - 1];
\r
600 Array.Copy(args, 1, packages, 0, packages.Length);
\r
602 mc.Remove(packages);
\r
607 string[] packages = new string[args.Length - 1];
\r
608 Array.Copy(args, 1, packages, 0, packages.Length);
\r
610 mc.CleanCache(packages);
\r
625 Environment.Exit(1);
\r