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
14 class DownloadListener
\r
16 private string line = null;
\r
19 /// lineのコンソール上における長さ
\r
21 private int lineWidth = 0;
\r
23 public void OnDownload(object sender, DownloadEventArgs a) {
\r
26 int newpos = (lineWidth <= 0)? 0 : Console.CursorLeft - lineWidth;
\r
27 if (newpos < 0) newpos = 0;
\r
30 Console.CursorLeft = newpos;
\r
31 for (int i = 0; i < lineWidth && Console.CursorLeft < Console.BufferWidth; i++) {
\r
34 Console.CursorLeft = newpos;
\r
36 line = null; lineWidth = 0;
\r
40 switch (a.DownloadTaskType) {
\r
41 case DownloadEventType.INITED:
\r
42 line = "starting...";
\r
44 case DownloadEventType.CONNECTED:
\r
45 case DownloadEventType.DOWNLOADING:
\r
46 line = a.TaskMessage;
\r
48 case DownloadEventType.COMPLETED:
\r
52 case DownloadEventType.ERROR:
\r
53 Console.Write("interrupted! ERROR!");
\r
59 int posOld = Console.CursorLeft;
\r
60 Console.Write(line);
\r
61 lineWidth = Console.CursorLeft - posOld;
\r
66 sealed class TaskSetEventHandlers
\r
68 public static void OnTaskSetEvent(object sender, TaskEventArgs e) {
\r
70 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
72 case TaskEventType.COMPLETED:
\r
73 Console.WriteLine("Done.");
\r
75 case TaskEventType.STARTED_SUBTASK:
\r
76 Console.Write(" " + e.TaskMessage);
\r
78 case TaskEventType.COMPLETED_SUBTASK:
\r
79 Console.WriteLine(" ... Done. [{0}%]", (int) e.ProgressPercent);
\r
81 case TaskEventType.INFO:
\r
82 Console.WriteLine(" " + e.TaskMessage);
\r
84 case TaskEventType.ERROR:
\r
85 case TaskEventType.WARNING:
\r
86 Console.WriteLine(" [Error]" + e.TaskMessage);
\r
91 public static void OnDownloadSubTaskEvent(object sender, TaskEventArgs e)
\r
93 if (sender is NaGet.SubCommands.SubTask.DownloadSubTask) {
\r
94 if (e.Type == TaskEventType.STARTED) {
\r
95 Console.WriteLine();
\r
98 int origPosX = Console.CursorLeft;
\r
99 for (int i = 0; i < Console.WindowWidth - 1; i++) {
\r
100 Console.Write(' ');
\r
102 Console.CursorLeft = origPosX;
\r
105 case TaskEventType.PING:
\r
107 int origPos = Console.CursorLeft;
\r
108 Console.Write(e.TaskMessage);
\r
109 Console.CursorLeft = origPos;
\r
112 case TaskEventType.WARNING:
\r
113 case TaskEventType.ERROR:
\r
114 Console.WriteLine(" [Error]" + e.TaskMessage);
\r
117 Console.WriteLine(e.TaskMessage);
\r
123 public static NaGetTaskQueryResult OnTaskQueryEvent(object sender, NaGetTaskQueryArgs e)
\r
125 char result = '\u0000';
\r
126 if (e.SelectionFlag == (NaGetTaskQueryResult.CONTINUE | NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
127 result = AllGet.Util.Query(e.Message + " [y/R/n]?", "yrn", 'r');
\r
128 } else if (e.SelectionFlag == (NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
129 result = AllGet.Util.Query(e.Message + " [R/n]?", "rn", 'r');
\r
130 } else if (e.SelectionFlag == NaGetTaskQueryResult.CONTINUE) {
\r
131 result = AllGet.Util.Query(e.Message + " [Y]?", "y", 'y');
\r
133 result = AllGet.Util.Query(e.Message + " [Y/n]?", "yn", 'y');
\r
138 return NaGetTaskQueryResult.CONTINUE;
\r
140 return NaGetTaskQueryResult.CANCEL;
\r
142 return NaGetTaskQueryResult.RETRY;
\r
144 return NaGetTaskQueryResult.CANCELED_AUTOMATICALLY;
\r
152 private Downloader downloader;
\r
154 private PackageListsManager pkgListMan;
\r
157 /// サイレントインストールをするか否か
\r
159 private bool silent = false;
\r
163 downloader = new Downloader();
\r
164 DownloadListener dl = new DownloadListener();
\r
165 downloader.DownloadEventRaised += new EventHandler<DownloadEventArgs>(dl.OnDownload);
\r
167 pkgListMan = new PackageListsManager();
\r
168 pkgListMan.LoadPackageLists();
\r
171 public void Update()
\r
176 public void LocalUpdate()
\r
181 public void update(bool downloadPackageListFlag)
\r
183 NaGet.SubCommands.NaGetUpdate2 tasks = new NaGet.SubCommands.NaGetUpdate2(pkgListMan, downloadPackageListFlag);
\r
184 tasks.TaskEventRaised += TaskSetEventHandlers.OnTaskSetEvent;
\r
185 tasks.SubTaskEventRaised += TaskSetEventHandlers.OnDownloadSubTaskEvent;
\r
190 public void CheckUpgrade()
\r
192 foreach (Package pkg in UpgradeFinder.GetUpgradePackages(pkgListMan)) {
\r
193 bool isSystem = false;
\r
194 Package instPkg = null;
\r
196 instPkg = pkgListMan.SystemInstalledPkgList.GetPackageForName(pkg.Name);
\r
197 if (instPkg != null) {
\r
200 instPkg = pkgListMan.InstalledPkgList.GetPackageForName(pkg.Name);
\r
201 if (instPkg != null) {
\r
204 System.Diagnostics.Debug.Fail("internal error.");
\r
208 Console.WriteLine("{0} ({1}){3} => ({2})", pkg.Name, instPkg.Version, pkg.Version, (isSystem)? "@sys" : "");
\r
212 public void Search(string keys)
\r
214 foreach(Package package in pkgListMan.AvailablePkgList.Search(keys)) {
\r
215 Console.WriteLine("{0} ({1}) - {2}", package.Name, package.Version, package.Summary);
\r
218 foreach(InstalledPackage package in pkgListMan.InstalledPkgList.Search(keys)) {
\r
219 Console.WriteLine("{0} ({1})[@install] - {2}", package.Name, package.Version, package.Summary);
\r
222 foreach(InstalledPackage package in pkgListMan.SystemInstalledPkgList.Search(keys)) {
\r
223 Console.WriteLine("{0} ({1})[@sys] - {2}", package.Name, package.Version, package.Summary);
\r
227 public void Show(string packagename)
\r
229 PackageList<Package> allPkgs = new PackageList<Package>();
\r
230 allPkgs.AddPackages(pkgListMan.GetAllPackages());
\r
232 foreach (Package pkg in allPkgs.GetPackagesForName(packagename)) {
\r
233 Console.WriteLine("Package: {0}", pkg.Name);
\r
234 Console.WriteLine("Version: {0}", pkg.Version);
\r
235 Console.WriteLine("Summary: {0}", pkg.Summary);
\r
236 if (pkg.Url != null) Console.WriteLine("Website: {0}", pkg.Url.Href);
\r
237 if (pkg.Tags != null) Console.WriteLine("Tag: {0}", pkg.Tags.ToLower());
\r
238 Console.WriteLine("Type: {0}", pkg.Type);
\r
239 if (pkg.License != null) Console.WriteLine("License: {0}", pkg.License);
\r
240 if (pkg is InstalledPackage) Console.WriteLine("State: Installed");
\r
241 Console.WriteLine("Repository: {0}", pkg.PackageListName);
\r
243 if (pkg.Description != null) {
\r
244 Console.WriteLine("Description:");
\r
245 Console.WriteLine(pkg.Description);
\r
247 Console.WriteLine();
\r
252 public void Download(string[] packagenames)
\r
254 Installation[] installations = null;
\r
256 List<Package> downloadList = new List<Package>();
\r
258 foreach(string packagename in packagenames) {
\r
259 Package foundPackage = pkgListMan.AvailablePkgList.GetPackageForName(packagename);
\r
260 if (foundPackage == null) {
\r
261 Console.WriteLine("E: Couldn't find package "+packagename);
\r
262 Environment.Exit(1);
\r
264 if (! downloadList.Contains(foundPackage)) {
\r
265 downloadList.Add(foundPackage);
\r
269 installations = new Installation[downloadList.Count];
\r
270 for (int i = 0; i < installations.Length; i++) {
\r
271 installations[i] = new Installation(downloadList[i]);
\r
275 Console.WriteLine("The following packages will be downloaded:");
\r
276 Console.WriteLine(" {0}", Installation.ToString(installations));
\r
277 if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
278 Console.WriteLine("Abort.");
\r
279 Environment.Exit(0);
\r
282 NaGet.SubCommands.NaGetDownloadToCache2 tasks = new NaGet.SubCommands.NaGetDownloadToCache2(pkgListMan, installations);
\r
283 tasks.TaskEventRaised += TaskSetEventHandlers.OnTaskSetEvent;
\r
284 tasks.SubTaskEventRaised += TaskSetEventHandlers.OnDownloadSubTaskEvent;
\r
285 tasks.TaskQueryRaised += TaskSetEventHandlers.OnTaskQueryEvent;
\r
290 public void Install(string[] packagenames)
\r
292 if (! NaGet.Utils.IsAdministrators()) {
\r
293 Console.WriteLine("W: you are not administrators!");
\r
296 Installation[] installations = null;
\r
298 List<Package> downloadList = new List<Package>();
\r
300 foreach(string packagename in packagenames) {
\r
301 Package foundPackage = pkgListMan.AvailablePkgList.GetPackageForName(packagename);
\r
302 if (foundPackage == null) {
\r
303 Console.WriteLine("E: Couldn't find package "+packagename);
\r
304 Environment.Exit(1);
\r
306 if (! downloadList.Contains(foundPackage)) {
\r
307 downloadList.Add(foundPackage);
\r
311 installations = new Installation[downloadList.Count];
\r
312 for (int i = 0; i < installations.Length; i++) {
\r
313 installations[i] = new Installation(downloadList[i]);
\r
315 installations[i].Silent = silent; // サイレントインストールのフラグの設定
\r
317 if (! installations[i].IsInstallablePackage()) {
\r
318 Console.WriteLine("E: Can not install package {0} to your PC.", installations[i].ToString());
\r
319 Environment.Exit(1);
\r
324 Installation[] depInstallations;
\r
326 Installation[] resolved;
\r
327 DependeciesResolver.ResolveInstallations(installations, pkgListMan, out resolved, out depInstallations);
\r
328 installations = resolved;
\r
331 Console.WriteLine("The following packages will be downloaded:");
\r
332 Console.WriteLine(" {0}", Installation.ToString(installations));
\r
333 if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
334 Console.WriteLine("Abort.");
\r
335 Environment.Exit(0);
\r
338 NaGet.SubCommands.NaGetInstall tasks = new NaGet.SubCommands.NaGetInstall(pkgListMan, installations);
\r
339 tasks.TaskQueryRaised += delegate(object sender, NaGetTaskQueryArgs e) {
\r
340 char result = '\u0000';
\r
341 if (e.SelectionFlag == (NaGetTaskQueryResult.CONTINUE | NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
342 result = AllGet.Util.Query(e.Message + " [y/R/n]?", "yrn", 'r');
\r
343 } else if (e.SelectionFlag == (NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
344 result = AllGet.Util.Query(e.Message + " [R/n]?", "rn", 'r');
\r
345 } else if (e.SelectionFlag == NaGetTaskQueryResult.CONTINUE) {
\r
346 result = AllGet.Util.Query(e.Message + " [Y]?", "y", 'y');
\r
348 result = AllGet.Util.Query(e.Message + " [Y/n]?", "yn", 'y');
\r
353 return NaGetTaskQueryResult.CONTINUE;
\r
355 return NaGetTaskQueryResult.CANCEL;
\r
357 return NaGetTaskQueryResult.RETRY;
\r
359 return NaGetTaskQueryResult.CANCELED_AUTOMATICALLY;
\r
362 tasks.TaskEventRaised += delegate(object sender, TaskEventArgs e) {
\r
364 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
366 case TaskEventType.COMPLETED:
\r
367 Console.WriteLine("Done.");
\r
369 case TaskEventType.STARTED_SUBTASK:
\r
370 Console.Write(" " + e.TaskMessage);
\r
372 case TaskEventType.COMPLETED_SUBTASK:
\r
373 Console.WriteLine(" ... Done. [{0}%]", (int) e.ProgressPercent);
\r
375 case TaskEventType.INFO:
\r
376 Console.WriteLine(" " + e.TaskMessage);
\r
378 case TaskEventType.ERROR:
\r
379 case TaskEventType.WARNING:
\r
380 Console.WriteLine(" [Error] " + e.TaskMessage);
\r
384 DownloadListener dl = new DownloadListener();
\r
385 tasks.Downloader.DownloadEventRaised += dl.OnDownload;
\r
390 public void Remove(string[] packagenames)
\r
392 if (! NaGet.Utils.IsAdministrators()) {
\r
393 Console.WriteLine("W: you are not administrators!");
\r
396 this.LocalUpdate();
\r
398 PackageList<InstalledPackage> installedPkgList = new PackageList<InstalledPackage>();
\r
399 installedPkgList.AddPackages(pkgListMan.GetAllInstalledPackages());
\r
401 InstalledPackage[] insPkgs = new InstalledPackage[packagenames.Length];
\r
402 for (int i = 0; i < packagenames.Length; i++) {
\r
403 insPkgs[i] = installedPkgList.GetPackageForName(packagenames[i]);
\r
405 if (insPkgs[i] == null) {
\r
406 Console.WriteLine("E: could not found package " + packagenames[i]);
\r
407 Environment.Exit(1);
\r
411 // if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
412 // Console.WriteLine("Abort.");
\r
413 // Environment.Exit(0);
\r
416 NaGet.SubCommands.NaGetUninstall2 tasks = new NaGet.SubCommands.NaGetUninstall2(pkgListMan, insPkgs);
\r
417 tasks.TaskEventRaised += TaskSetEventHandlers.OnTaskSetEvent;
\r
422 public void CleanCache(string[] packages)
\r
424 if (! Directory.Exists(NaGet.Env.ArchiveFolderPath)) {
\r
429 if (packages.Length == 0) {
\r
430 foreach (string folder in Directory.GetDirectories(NaGet.Env.ArchiveFolderPath)) {
\r
431 Directory.Delete(folder, true);
\r
435 foreach (string package in packages) {
\r
436 foreach (string folder in Directory.GetDirectories(NaGet.Env.ArchiveFolderPath, package+"*", SearchOption.TopDirectoryOnly)) {
\r
437 Directory.Delete(folder, true);
\r
443 Console.WriteLine("... Done.");
\r
449 string executeFileName = System.AppDomain.CurrentDomain.FriendlyName;
\r
450 Console.Write("Usage:");
\r
452 Console.WriteLine("\t{0} update|localupdate", executeFileName);
\r
453 Console.WriteLine("\t{0} search|show pkg1 [pkg2 ...]", executeFileName);
\r
454 Console.WriteLine("\t{0} cleancache [pkg ...]", executeFileName);
\r
455 Console.WriteLine("\t{0} download pkg1 [pkg2 ...]", executeFileName);
\r
456 Console.WriteLine("\t{0} [--quiet] install|uninstall pkg1 [pkg2 ...]", executeFileName);
\r
457 Console.WriteLine();
\r
458 Console.WriteLine("{0} is a simple command line interface for downloading and "+
\r
459 "installing packages. The most frequently used commands are update "+
\r
460 "and install.", executeFileName);
\r
461 Console.WriteLine();
\r
462 Console.WriteLine("Commands:");
\r
463 Console.WriteLine(" update - Retrieve new lists of packages");
\r
464 Console.WriteLine(" localupdate - Update installed-soft-list only");
\r
465 Console.WriteLine(" checkupgrade - Show upgraded-soft list");
\r
466 Console.WriteLine(" search - Search the package list for not a regex pattern");
\r
467 Console.WriteLine(" show - Show package detail");
\r
468 Console.WriteLine(" cleancache - Clear cached archived file(s)");
\r
469 Console.WriteLine(" download - Download only - do NOT install or unpack archives");
\r
470 Console.WriteLine(" install - Install new packages");
\r
471 Console.WriteLine(" remove - Uninstall packages");
\r
472 Console.WriteLine();
\r
475 public void FooBar()
\r
477 foreach (InstalledPackage pkg in pkgListMan.SystemInstalledPkgList) {
\r
478 Console.WriteLine("{0} : {1}", pkg.Name, pkg.UninstallInfo.UninstallString);
\r
484 foreach (UninstallInformation uInfo in RegistriedUninstallers.Uninstallers) {
\r
485 if (! uInfo.IsOSPatch && ! uInfo.IsSystemComponent) {
\r
486 Console.WriteLine("{0}", uInfo.DisplayName);
\r
493 // TODO スーパー牛さんパワー化
\r
495 string executeFileName = System.AppDomain.CurrentDomain.FriendlyName;
\r
496 Console.WriteLine("誰か {0} をスーパー牛さんパワー化してくれ", executeFileName);
\r
500 public static void Main(string[] args)
\r
502 // アーカイブSYSTEM32をパスに足す
\r
503 NaGet.Utils.AddDirectoryToPath(NaGet.Env.ArchiveSystem32);
\r
505 MainClass mc = new MainClass();
\r
507 if (args.Length == 0) {
\r
510 Environment.Exit(1);
\r
513 NaGet.ArgParser argParser = new NaGet.ArgParser();
\r
514 argParser["quiet"] = false;
\r
515 args = argParser.Parse(args);
\r
516 mc.silent = (bool) argParser["quiet"];
\r
517 } catch (ApplicationException e) {
\r
518 Console.WriteLine(e.Message);
\r
519 Environment.Exit(1);
\r
527 if (args.Length != 1) {
\r
528 Console.WriteLine("E: The update command takes no arguments");
\r
529 Environment.Exit(1);
\r
534 if (args.Length != 1) {
\r
535 Console.WriteLine("E: The update command takes no arguments");
\r
536 Environment.Exit(1);
\r
541 if (args.Length <= 1) {
\r
542 Console.WriteLine("E: You must give exactly one pattern");
\r
543 Environment.Exit(1);
\r
546 mc.Search(string.Join(" ", args, 1, args.Length - 1));
\r
549 if (args.Length <= 1) {
\r
550 Console.WriteLine("E: You must give exactly one pattern");
\r
551 Environment.Exit(1);
\r
554 for (int i = 1; i < args.Length; i++) {
\r
559 if (args.Length <= 1) {
\r
560 Console.WriteLine("E: Invalid operation download");
\r
561 Environment.Exit(1);
\r
563 string[] packages = new string[args.Length - 1];
\r
564 Array.Copy(args, 1, packages, 0, packages.Length);
\r
566 mc.Download(packages);
\r
570 if (args.Length <= 1) {
\r
571 Console.WriteLine("E: Invalid operation install");
\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.Install(packages);
\r
580 case "checkupgrade":
\r
584 if (args.Length <= 1) {
\r
585 Console.WriteLine("E: Invalid operation remove");
\r
586 Environment.Exit(1);
\r
588 string[] packages = new string[args.Length - 1];
\r
589 Array.Copy(args, 1, packages, 0, packages.Length);
\r
591 mc.Remove(packages);
\r
596 string[] packages = new string[args.Length - 1];
\r
597 Array.Copy(args, 1, packages, 0, packages.Length);
\r
599 mc.CleanCache(packages);
\r
614 Environment.Exit(1);
\r