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
68 private Downloader downloader;
\r
70 private PackageListsManager pkgListMan;
\r
73 /// サイレントインストールをするか否か
\r
75 private bool silent = false;
\r
79 downloader = new Downloader();
\r
80 DownloadListener dl = new DownloadListener();
\r
81 downloader.DownloadEventRaised += new EventHandler<DownloadEventArgs>(dl.OnDownload);
\r
83 pkgListMan = new PackageListsManager();
\r
84 pkgListMan.LoadPackageLists();
\r
87 public void Update()
\r
92 public void LocalUpdate()
\r
97 public void update(bool downloadPackageListFlag)
\r
99 NaGet.SubCommands.NaGetUpdate tasks = new NaGet.SubCommands.NaGetUpdate(pkgListMan, downloadPackageListFlag);
\r
100 tasks.TaskEventRaised += delegate(object sender, TaskEventArgs e) {
\r
102 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
104 case TaskEventType.COMPLETED:
\r
105 Console.WriteLine("Done.");
\r
107 case TaskEventType.STARTED_SUBTASK:
\r
108 Console.Write(" " + e.TaskMessage);
\r
110 case TaskEventType.COMPLETED_SUBTASK:
\r
111 Console.WriteLine(" ... Done. [{0}%]", (int) e.ProgressPercent);
\r
113 case TaskEventType.INFO:
\r
114 Console.WriteLine(" " + e.TaskMessage);
\r
116 case TaskEventType.ERROR:
\r
117 case TaskEventType.WARNING:
\r
118 Console.WriteLine(" [Error]" + e.TaskMessage);
\r
122 DownloadListener dl = new DownloadListener();
\r
123 tasks.Downloader.DownloadEventRaised += dl.OnDownload;
\r
128 public void CheckUpgrade()
\r
130 foreach (Package pkg in UpgradeFinder.GetUpgradePackages(pkgListMan)) {
\r
131 bool isSystem = false;
\r
132 Package instPkg = null;
\r
134 instPkg = pkgListMan.SystemInstalledPkgList.GetPackageForName(pkg.Name);
\r
135 if (instPkg != null) {
\r
138 instPkg = pkgListMan.InstalledPkgList.GetPackageForName(pkg.Name);
\r
139 if (instPkg != null) {
\r
142 System.Diagnostics.Debug.Fail("internal error.");
\r
146 Console.WriteLine("{0} ({1}){3} => ({2})", pkg.Name, instPkg.Version, pkg.Version, (isSystem)? "@sys" : "");
\r
150 public void Search(string keys)
\r
152 foreach(Package package in pkgListMan.AvailablePkgList.Search(keys)) {
\r
153 Console.WriteLine("{0} ({1}) - {2}", package.Name, package.Version, package.Summary);
\r
156 foreach(InstalledPackage package in pkgListMan.InstalledPkgList.Search(keys)) {
\r
157 Console.WriteLine("{0} ({1})[@install] - {2}", package.Name, package.Version, package.Summary);
\r
160 foreach(InstalledPackage package in pkgListMan.SystemInstalledPkgList.Search(keys)) {
\r
161 Console.WriteLine("{0} ({1})[@sys] - {2}", package.Name, package.Version, package.Summary);
\r
165 public void Show(string packagename)
\r
167 PackageList<Package> allPkgs = new PackageList<Package>();
\r
168 allPkgs.AddPackages(pkgListMan.GetAllPackages());
\r
170 foreach (Package pkg in allPkgs.GetPackagesForName(packagename)) {
\r
171 Console.WriteLine("Package: {0}", pkg.Name);
\r
172 Console.WriteLine("Version: {0}", pkg.Version);
\r
173 Console.WriteLine("Summary: {0}", pkg.Summary);
\r
174 if (pkg.Url != null) Console.WriteLine("Website: {0}", pkg.Url.Href);
\r
175 if (pkg.Tags != null) Console.WriteLine("Tag: {0}", pkg.Tags.ToLower());
\r
176 Console.WriteLine("Type: {0}", pkg.Type);
\r
177 if (pkg.License != null) Console.WriteLine("License: {0}", pkg.License);
\r
178 if (pkg is InstalledPackage) Console.WriteLine("State: Installed");
\r
179 Console.WriteLine("Repository: {0}", pkg.PackageListName);
\r
181 if (pkg.Description != null) {
\r
182 Console.WriteLine("Description:");
\r
183 Console.WriteLine(pkg.Description);
\r
185 Console.WriteLine();
\r
189 public void Download(string[] packagenames)
\r
191 Installation[] installations = null;
\r
193 List<Package> downloadList = new List<Package>();
\r
195 foreach(string packagename in packagenames) {
\r
196 Package foundPackage = pkgListMan.AvailablePkgList.GetPackageForName(packagename);
\r
197 if (foundPackage == null) {
\r
198 Console.WriteLine("E: Couldn't find package "+packagename);
\r
199 Environment.Exit(1);
\r
201 if (! downloadList.Contains(foundPackage)) {
\r
202 downloadList.Add(foundPackage);
\r
206 installations = new Installation[downloadList.Count];
\r
207 for (int i = 0; i < installations.Length; i++) {
\r
208 installations[i] = new Installation(downloadList[i]);
\r
212 Console.WriteLine("The following packages will be downloaded:");
\r
213 Console.WriteLine(" {0}", Installation.ToString(installations));
\r
214 if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
215 Console.WriteLine("Abort.");
\r
216 Environment.Exit(0);
\r
219 NaGet.SubCommands.NaGetDownloadToCache tasks = new NaGet.SubCommands.NaGetDownloadToCache(pkgListMan, installations);
\r
220 tasks.TaskQueryRaised += delegate(object sender, NaGetTaskQueryArgs e) {
\r
221 char result = '\u0000';
\r
222 if (e.SelectionFlag == (NaGetTaskQueryResult.CONTINUE | NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
223 result = AllGet.Util.Query(e.Message + " [y/R/n]?", "yrn", 'r');
\r
224 } else if (e.SelectionFlag == (NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
225 result = AllGet.Util.Query(e.Message + " [R/n]?", "rn", 'r');
\r
226 } else if (e.SelectionFlag == NaGetTaskQueryResult.CONTINUE) {
\r
227 result = AllGet.Util.Query(e.Message + " [Y]?", "y", 'y');
\r
229 result = AllGet.Util.Query(e.Message + " [Y/n]?", "yn", 'y');
\r
234 return NaGetTaskQueryResult.CONTINUE;
\r
236 return NaGetTaskQueryResult.CANCEL;
\r
238 return NaGetTaskQueryResult.RETRY;
\r
240 return NaGetTaskQueryResult.CANCELED_AUTOMATICALLY;
\r
243 tasks.TaskEventRaised += delegate(object sender, TaskEventArgs e) {
\r
245 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
247 case TaskEventType.COMPLETED:
\r
248 Console.WriteLine("Done.");
\r
250 case TaskEventType.STARTED_SUBTASK:
\r
251 Console.Write(" " + e.TaskMessage);
\r
253 case TaskEventType.COMPLETED_SUBTASK:
\r
254 Console.WriteLine(" ... Done. [{0}%]", (int) e.ProgressPercent);
\r
256 case TaskEventType.INFO:
\r
257 Console.WriteLine(" " + e.TaskMessage);
\r
259 case TaskEventType.ERROR:
\r
260 case TaskEventType.WARNING:
\r
261 Console.WriteLine(" [Error] " + e.TaskMessage);
\r
265 DownloadListener dl = new DownloadListener();
\r
266 tasks.Downloader.DownloadEventRaised += dl.OnDownload;
\r
271 public void Install(string[] packagenames)
\r
273 if (! NaGet.Utils.IsAdministrators()) {
\r
274 Console.WriteLine("W: you are not administrators!");
\r
277 Installation[] installations = null;
\r
279 List<Package> downloadList = new List<Package>();
\r
281 foreach(string packagename in packagenames) {
\r
282 Package foundPackage = pkgListMan.AvailablePkgList.GetPackageForName(packagename);
\r
283 if (foundPackage == null) {
\r
284 Console.WriteLine("E: Couldn't find package "+packagename);
\r
285 Environment.Exit(1);
\r
287 if (! downloadList.Contains(foundPackage)) {
\r
288 downloadList.Add(foundPackage);
\r
292 installations = new Installation[downloadList.Count];
\r
293 for (int i = 0; i < installations.Length; i++) {
\r
294 installations[i] = new Installation(downloadList[i]);
\r
296 installations[i].Silent = silent; // サイレントインストールのフラグの設定
\r
298 if (! installations[i].IsInstallablePackage()) {
\r
299 Console.WriteLine("E: Can not install package {0} to your PC.", installations[i].ToString());
\r
300 Environment.Exit(1);
\r
305 Installation[] depInstallations;
\r
307 Installation[] resolved;
\r
308 DependeciesResolver.ResolveInstallations(installations, pkgListMan, out resolved, out depInstallations);
\r
309 installations = resolved;
\r
312 Console.WriteLine("The following packages will be downloaded:");
\r
313 Console.WriteLine(" {0}", Installation.ToString(installations));
\r
314 if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
315 Console.WriteLine("Abort.");
\r
316 Environment.Exit(0);
\r
319 NaGet.SubCommands.NaGetInstall tasks = new NaGet.SubCommands.NaGetInstall(pkgListMan, installations);
\r
320 tasks.TaskQueryRaised += delegate(object sender, NaGetTaskQueryArgs e) {
\r
321 char result = '\u0000';
\r
322 if (e.SelectionFlag == (NaGetTaskQueryResult.CONTINUE | NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
323 result = AllGet.Util.Query(e.Message + " [y/R/n]?", "yrn", 'r');
\r
324 } else if (e.SelectionFlag == (NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
325 result = AllGet.Util.Query(e.Message + " [R/n]?", "rn", 'r');
\r
326 } else if (e.SelectionFlag == NaGetTaskQueryResult.CONTINUE) {
\r
327 result = AllGet.Util.Query(e.Message + " [Y]?", "y", 'y');
\r
329 result = AllGet.Util.Query(e.Message + " [Y/n]?", "yn", 'y');
\r
334 return NaGetTaskQueryResult.CONTINUE;
\r
336 return NaGetTaskQueryResult.CANCEL;
\r
338 return NaGetTaskQueryResult.RETRY;
\r
340 return NaGetTaskQueryResult.CANCELED_AUTOMATICALLY;
\r
343 tasks.TaskEventRaised += delegate(object sender, TaskEventArgs e) {
\r
345 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
347 case TaskEventType.COMPLETED:
\r
348 Console.WriteLine("Done.");
\r
350 case TaskEventType.STARTED_SUBTASK:
\r
351 Console.Write(" " + e.TaskMessage);
\r
353 case TaskEventType.COMPLETED_SUBTASK:
\r
354 Console.WriteLine(" ... Done. [{0}%]", (int) e.ProgressPercent);
\r
356 case TaskEventType.INFO:
\r
357 Console.WriteLine(" " + e.TaskMessage);
\r
359 case TaskEventType.ERROR:
\r
360 case TaskEventType.WARNING:
\r
361 Console.WriteLine(" [Error] " + e.TaskMessage);
\r
365 DownloadListener dl = new DownloadListener();
\r
366 tasks.Downloader.DownloadEventRaised += dl.OnDownload;
\r
371 public void Remove(string[] packagenames)
\r
373 if (! NaGet.Utils.IsAdministrators()) {
\r
374 Console.WriteLine("W: you are not administrators!");
\r
377 this.LocalUpdate();
\r
379 PackageList<InstalledPackage> installedPkgList = new PackageList<InstalledPackage>();
\r
380 installedPkgList.AddPackages(pkgListMan.GetAllInstalledPackages());
\r
382 Uninstallation[] uninstallations = new Uninstallation[packagenames.Length];
\r
383 for (int i = 0; i < packagenames.Length; i++) {
\r
384 InstalledPackage pkg = installedPkgList.GetPackageForName(packagenames[i]);
\r
387 Console.WriteLine("E: could not found package " + packagenames[i]);
\r
388 Environment.Exit(1);
\r
391 uninstallations[i] = new Uninstallation(pkg);
\r
394 // if (AllGet.Util.Confirm("Do you want to continue [Y/n]?", true) == false) {
\r
395 // Console.WriteLine("Abort.");
\r
396 // Environment.Exit(0);
\r
399 NaGet.SubCommands.NaGetUninstall tasks = new NaGet.SubCommands.NaGetUninstall(pkgListMan, uninstallations);
\r
400 tasks.TaskEventRaised += delegate(object sender, TaskEventArgs e) {
\r
402 // case NaGetTaskSetEventType.COMPLETED_TASKSET
\r
404 case TaskEventType.COMPLETED:
\r
405 Console.WriteLine("Done.");
\r
407 case TaskEventType.STARTED_SUBTASK:
\r
408 Console.Write(" " + e.TaskMessage);
\r
410 case TaskEventType.COMPLETED_SUBTASK:
\r
411 Console.WriteLine(" ... Done. [{0}%]", (int) e.ProgressPercent);
\r
413 case TaskEventType.INFO:
\r
414 Console.WriteLine(" " + e.TaskMessage);
\r
416 case TaskEventType.ERROR:
\r
417 case TaskEventType.WARNING:
\r
418 Console.WriteLine(" [Error] " + e.TaskMessage);
\r
426 public void CleanCache(string[] packages)
\r
428 if (! Directory.Exists(NaGet.Env.ArchiveFolderPath)) {
\r
433 if (packages.Length == 0) {
\r
434 foreach (string folder in Directory.GetDirectories(NaGet.Env.ArchiveFolderPath)) {
\r
435 Directory.Delete(folder, true);
\r
439 foreach (string package in packages) {
\r
440 foreach (string folder in Directory.GetDirectories(NaGet.Env.ArchiveFolderPath, package+"*", SearchOption.TopDirectoryOnly)) {
\r
441 Directory.Delete(folder, true);
\r
447 Console.WriteLine("... Done.");
\r
453 string executeFileName = System.AppDomain.CurrentDomain.FriendlyName;
\r
454 Console.Write("Usage:");
\r
456 Console.WriteLine("\t{0} update|localupdate", executeFileName);
\r
457 Console.WriteLine("\t{0} search|show pkg1 [pkg2 ...]", executeFileName);
\r
458 Console.WriteLine("\t{0} cleancache [pkg ...]", executeFileName);
\r
459 Console.WriteLine("\t{0} download pkg1 [pkg2 ...]", executeFileName);
\r
460 Console.WriteLine("\t{0} [--quiet] install|uninstall pkg1 [pkg2 ...]", executeFileName);
\r
461 Console.WriteLine();
\r
462 Console.WriteLine("{0} is a simple command line interface for downloading and "+
\r
463 "installing packages. The most frequently used commands are update "+
\r
464 "and install.", executeFileName);
\r
465 Console.WriteLine();
\r
466 Console.WriteLine("Commands:");
\r
467 Console.WriteLine(" update - Retrieve new lists of packages");
\r
468 Console.WriteLine(" localupdate - Update installed-soft-list only");
\r
469 Console.WriteLine(" checkupgrade - Show upgraded-soft list");
\r
470 Console.WriteLine(" search - Search the package list for not a regex pattern");
\r
471 Console.WriteLine(" show - Show package detail");
\r
472 Console.WriteLine(" cleancache - Clear cached archived file(s)");
\r
473 Console.WriteLine(" download - Download only - do NOT install or unpack archives");
\r
474 Console.WriteLine(" install - Install new packages");
\r
475 Console.WriteLine(" remove - Uninstall packages");
\r
476 Console.WriteLine();
\r
479 public void FooBar()
\r
481 foreach (InstalledPackage pkg in pkgListMan.SystemInstalledPkgList) {
\r
482 Console.WriteLine("{0} : {1}", pkg.Name, pkg.UninstallInfo.UninstallString);
\r
488 foreach (UninstallInformation uInfo in RegistriedUninstallers.Uninstallers) {
\r
489 if (! uInfo.IsOSPatch && ! uInfo.IsSystemComponent) {
\r
490 Console.WriteLine("{0}", uInfo.DisplayName);
\r
497 // TODO スーパー牛さんパワー化
\r
499 string executeFileName = System.AppDomain.CurrentDomain.FriendlyName;
\r
500 Console.WriteLine("誰か {0} をスーパー牛さんパワー化してくれ", executeFileName);
\r
504 public static void Main(string[] args)
\r
506 // アーカイブSYSTEM32をパスに足す
\r
507 NaGet.Utils.AddDirectoryToPath(NaGet.Env.ArchiveSystem32);
\r
509 MainClass mc = new MainClass();
\r
511 if (args.Length == 0) {
\r
514 Environment.Exit(1);
\r
517 NaGet.ArgParser argParser = new NaGet.ArgParser();
\r
518 argParser["quiet"] = false;
\r
519 args = argParser.Parse(args);
\r
520 mc.silent = (bool) argParser["quiet"];
\r
521 } catch (ApplicationException e) {
\r
522 Console.WriteLine(e.Message);
\r
523 Environment.Exit(1);
\r
531 if (args.Length != 1) {
\r
532 Console.WriteLine("E: The update command takes no arguments");
\r
533 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: You must give exactly one pattern");
\r
547 Environment.Exit(1);
\r
550 mc.Search(string.Join(" ", args, 1, args.Length - 1));
\r
553 if (args.Length <= 1) {
\r
554 Console.WriteLine("E: You must give exactly one pattern");
\r
555 Environment.Exit(1);
\r
558 for (int i = 1; i < args.Length; i++) {
\r
563 if (args.Length <= 1) {
\r
564 Console.WriteLine("E: Invalid operation download");
\r
565 Environment.Exit(1);
\r
567 string[] packages = new string[args.Length - 1];
\r
568 Array.Copy(args, 1, packages, 0, packages.Length);
\r
570 mc.Download(packages);
\r
574 if (args.Length <= 1) {
\r
575 Console.WriteLine("E: Invalid operation install");
\r
576 Environment.Exit(1);
\r
578 string[] packages = new string[args.Length - 1];
\r
579 Array.Copy(args, 1, packages, 0, packages.Length);
\r
581 mc.Install(packages);
\r
584 case "checkupgrade":
\r
588 if (args.Length <= 1) {
\r
589 Console.WriteLine("E: Invalid operation remove");
\r
590 Environment.Exit(1);
\r
592 string[] packages = new string[args.Length - 1];
\r
593 Array.Copy(args, 1, packages, 0, packages.Length);
\r
595 mc.Remove(packages);
\r
600 string[] packages = new string[args.Length - 1];
\r
601 Array.Copy(args, 1, packages, 0, packages.Length);
\r
603 mc.CleanCache(packages);
\r
618 Environment.Exit(1);
\r