X-Git-Url: http://git.sourceforge.jp/view?p=applistation%2FAppliStation.git;a=blobdiff_plain;f=AppliStation%2FPackageListViewForm.cs;h=a66d9a69137f1bdb64f72e25524780ca4c63f860;hp=46da5efffb9de78ac726a8468b805deb084234ab;hb=202377d120df8670eca37760385d1f3616b6f8a1;hpb=5c657d2488b269b308fa65b56027968e5b2c94cd
diff --git a/AppliStation/PackageListViewForm.cs b/AppliStation/PackageListViewForm.cs
index 46da5ef..a66d9a6 100644
--- a/AppliStation/PackageListViewForm.cs
+++ b/AppliStation/PackageListViewForm.cs
@@ -6,6 +6,8 @@ using NaGet.Packages.Install;
using System.IO;
using System.Collections.Generic;
+using AppliStation.PackageInfo;
+
namespace AppliStation
{
///
@@ -13,7 +15,7 @@ namespace AppliStation
///
public partial class PackageListViewForm : Form
{
- protected PackageListsManager pkgListsMan = null;
+ private PackageListsManager pkgListsMan = null;
public PackageListViewForm()
{
@@ -26,6 +28,7 @@ namespace AppliStation
uninstallToolStripMenuItem.Font = new Font(uninstallToolStripMenuItem.Font, FontStyle.Bold);
pkgListsMan = new PackageListsManager();
+ packageListView.Data = pkgListsMan;
this.Icon = Icon.ExtractAssociatedIcon(Application.ExecutablePath);
AppliStation.Util.NativeMethods.ListView_EnableVistaExplorerTheme(packageListView);
@@ -47,8 +50,10 @@ namespace AppliStation
}
detailBox.AppendText("\r\n");
}
- if (pkg is InstalledPackage) {
- InstalledPackage iPkg = (InstalledPackage) pkg;
+
+ // ã¤ã³ã¹ãã¼ã«æ¸ã¿ããã±ã¼ã¸ã®å ´å
+ InstalledPackage iPkg = pkg as InstalledPackage;
+ if (iPkg != null) {
System.Text.StringBuilder sb = new System.Text.StringBuilder();
if (iPkg.UninstallInfo.InstallDate != null) {
sb.AppendFormat("ã¤ã³ã¹ãã¼ã«ããæ¥: {0:d} ", iPkg.UninstallInfo.InstallDate.Value);
@@ -74,41 +79,53 @@ namespace AppliStation
void PackageListViewSelectedIndexChanged(object sender, EventArgs e)
{
+ updateSelectedPackages();
+ }
+
+ private void updateSelectedPackages()
+ {
uint installPkgCount = 0;
uint uninstallPkgCount = 0;
bool installBtnEnabled, uninstallBtnEnabled;
- Package[] selectedPkgs = NaGet.Utils.IEnumerable2Array(SelectedPackages());
- foreach (Package pkg in selectedPkgs) {
+ foreach (Package pkg in packageListView.SelectedPackages) {
if (pkg is InstalledPackage) {
uninstallPkgCount ++;
} else {
installPkgCount ++;
}
}
+
+ uint pkgCount = installPkgCount + uninstallPkgCount;
installBtnEnabled = (installPkgCount > 0) && (uninstallPkgCount == 0);
uninstallBtnEnabled = (uninstallPkgCount == 1) && (installPkgCount == 0);
- upgradeToolStripButton.Visible = (selectedPkgs.Length <= 0);
- informationToolStripDropDownButton.Visible = (selectedPkgs.Length == 1);
+ // ToolStrip
+ informationToolStripDropDownButton.Visible = (pkgCount == 1);
uninstallToolStripButton.Visible = uninstallBtnEnabled;
installToolStripButton.Visible = installBtnEnabled;
+ // MenuStrip
+ webResourceToolStripMenuItem.Visible = (pkgCount == 1);
+ uninstallToolStripMenuItem.Visible = uninstallBtnEnabled;
+ installToolStripMenuItem.Visible = installBtnEnabled;
+ downloadToolStripMenuItem.Visible = (pkgCount > 0);
// detailBoxã®ã¡ãã»ã¼ã¸è¨å®
- detailBox.Clear();
- switch (selectedPkgs.Length) {
+ switch (pkgCount) {
case 0:
int count = packageListView.Items.Count;
+ detailBox.Clear();
detailBox.Text = (count > 0) ? string.Format("{0}åã®ã½ãããããã¾ãã", count)
: "該å½ããã½ãããããã¾ããã";
break;
case 1:
- ShowInfoToDetailBoxFor(selectedPkgs[0]);
+ ShowInfoToDetailBoxFor(packageListView.SelectedPackage);
break;
default: // case 2 and over:
+ detailBox.Clear();
detailBox.Text = (installBtnEnabled)? string.Format("{0}åã®ã½ãããé¸æããã¦ãã¾ãã", installPkgCount) :
(uninstallBtnEnabled)? string.Format("{0}åã®ã¤ã³ã¹ãã¼ã«æ¸ã¿ã®ã½ãããé¸æããã¦ãã¾ãã", uninstallPkgCount) :
- string.Format("{0}åã®ã½ãããé¸æããã¦ãã¾ãã\r\n(ãã¡{1}åã¯ã¤ã³ã¹ãã¼ã«æ¸ã¿ã{2}åã¯ã¤ã³ã¹ãã¼ã«å¯è½)", installPkgCount+uninstallPkgCount, uninstallPkgCount, installPkgCount);
+ string.Format("{0}åã®ã½ãããé¸æããã¦ãã¾ãã\r\n(ãã¡{1}åã¯ã¤ã³ã¹ãã¼ã«æ¸ã¿ã{2}åã¯ã¤ã³ã¹ãã¼ã«å¯è½)", pkgCount, uninstallPkgCount, installPkgCount);
break;
}
@@ -122,103 +139,41 @@ namespace AppliStation
void PackageListViewItemActivate(object sender, EventArgs e)
{
- if (packageListView.SelectedItems.Count <= 0) {
- return; // exit
- }
+ Package pkg = packageListView.SelectedPackage;
- foreach (ListViewItem item in packageListView.SelectedItems) {
- Package pkg = (Package) item.Tag;
-
+ if (pkg != null) {
if (pkg is InstalledPackage) {
UninstallToolStripButtonClick(sender, e);
} else {
InstallToolStripButtonClick(sender, e);
}
-
- break;
}
}
- private void buildInstalledDirectoryMenuItemStripChildren(InstalledPackage pkg)
- {
- //installedDirectoryStripMenuItem.BaseFolderPath = pkg.UninstallInfo.InstallLocation;
- installedDirectoryStripMenuItem.BaseFolderPath = pkg.discoverInstalledLocation();
- }
-
- #region packageListViewã®Sorté¢é£
-
- AppliStation.Util.ListViewItemSortComparer packageListViewSortComparer;
-
- void PackageListViewColumnClick(object sender, ColumnClickEventArgs e)
- {
- SortOrder order = SortOrder.None;
-
- if (packageListViewSortComparer == null) {
- order = SortOrder.Ascending;
- packageListViewSortComparer = new AppliStation.Util.ListViewItemSortComparer(e.Column, order);
- packageListView.ListViewItemSorter = packageListViewSortComparer;
- } else {
- if (packageListViewSortComparer.Column == e.Column) {
- order = (packageListViewSortComparer.Order == SortOrder.Ascending)? SortOrder.Descending : SortOrder.Ascending;
-
- packageListViewSortComparer.Order = order;
- } else {
- order = packageListViewSortComparer.Order;
- packageListViewSortComparer.Column = e.Column;
- }
-
- packageListView.Sort();
- }
- AppliStation.Util.NativeMethods.ColumnHeader_SetSortState(packageListView, e.Column, order);
-
- // ã½ã¼ã対象åã®è²ä»ã
- try {
- // SendMessage(hWnd, LVM_SETSELECTEDCOLUMN, column, NULL);
- AppliStation.Util.NativeMethods.SendMessage(packageListView.Handle, 0x1000+140, (uint) e.Column, 0);
- } catch (Exception) {
- }
- }
-
- #endregion
-
void Form_OnLoad(object sender, EventArgs e)
{
packageListViewImageList.Images.Add("installed", Icon.ExtractAssociatedIcon(Application.ExecutablePath));
updatePackageFilterToolStripMenuItemCheckState();
+ notInstalledPackageFilterToolStripMenuItem.Image = packageListViewImageList.Images["available-new"];
installedASPackageFilterToolStripMenuItem.Image = packageListViewImageList.Images["installed"];
installedSysPackageFilterToolStripMenuItem.Image = packageListViewImageList.Images["sys"];
+
+ packageListView.UpdateItems();
+ updateSelectedPackages();
}
#region PackageFilteré¢é£
- private enum PackageFilterIndex : int
- {
- All = 0,
- NotInstalled = 1,
- InstalledAS = 2,
- InstalledSys = 3,
- }
-
- private PackageFilterIndex currentPackageFilter = PackageFilterIndex.All;
-
- private PackageFilterIndex CurrentPackageFilter {
- get {
- return currentPackageFilter;
- }
- set {
- currentPackageFilter = value;
-
- updatePackageFilterToolStripMenuItemCheckState();
- }
- }
-
+ ///
+ /// packgageFilterToolStripã®ãªã¹ããæ´æ°ããã
+ ///
private void updatePackageFilterToolStripMenuItemCheckState()
{
ToolStripMenuItem selected = getCheckedPackageFilterToolStripItem();
foreach (ToolStripMenuItem item in packageFilterToolStripDropDownButton.DropDown.Items) {
- item.Checked = selected == item;
+ item.Checked = (selected == item);
}
packageFilterToolStripDropDownButton.Text = selected.Text;
@@ -228,12 +183,12 @@ namespace AppliStation
private ToolStripMenuItem getCheckedPackageFilterToolStripItem()
{
- switch (currentPackageFilter) {
- case PackageFilterIndex.NotInstalled:
+ switch (packageListView.FilteringType) {
+ case PackageListViewPkgTypeFilter.NotInstalled:
return notInstalledPackageFilterToolStripMenuItem;
- case PackageFilterIndex.InstalledAS:
+ case PackageListViewPkgTypeFilter.InstalledAS:
return installedASPackageFilterToolStripMenuItem;
- case PackageFilterIndex.InstalledSys:
+ case PackageListViewPkgTypeFilter.InstalledSys:
return installedSysPackageFilterToolStripMenuItem;
default:
return allPackageFilterToolStripMenuItem;
@@ -243,72 +198,21 @@ namespace AppliStation
void AnyPackageFilterToolStripMenuItemClicked(object sender, EventArgs e)
{
if (sender == notInstalledPackageFilterToolStripMenuItem) {
- currentPackageFilter = PackageFilterIndex.NotInstalled;
+ packageListView.FilteringType = PackageListViewPkgTypeFilter.NotInstalled;
} else if (sender == installedASPackageFilterToolStripMenuItem) {
- currentPackageFilter = PackageFilterIndex.InstalledAS;
+ packageListView.FilteringType = PackageListViewPkgTypeFilter.InstalledAS;
} else if (sender == installedSysPackageFilterToolStripMenuItem) {
- currentPackageFilter = PackageFilterIndex.InstalledSys;
+ packageListView.FilteringType = PackageListViewPkgTypeFilter.InstalledSys;
} else {
- currentPackageFilter = PackageFilterIndex.All;
+ packageListView.FilteringType = PackageListViewPkgTypeFilter.All;
}
updatePackageFilterToolStripMenuItemCheckState();
searchTextBox.FireTextChangedTrigger();
- PackageListViewUpdate();
}
#endregion
- void PackageListViewUpdate()
- {
- this.packageListView.Items.Clear();
-
- if (currentPackageFilter == PackageFilterIndex.All || currentPackageFilter == PackageFilterIndex.NotInstalled) {
- foreach (Package pkg in pkgListsMan.AvailablePkgList.Search(searchTextBox.Text)) {
- if (Installation.GetPreferInstallerIndex(pkg) >= 0) { // ã¤ã³ã¹ãã¼ã«å¯è½
- if (currentPackageFilter == PackageFilterIndex.NotInstalled &&
- (pkgListsMan.InstalledPkgList.GetPackageForName(pkg.Name) != null||
- pkgListsMan.SystemInstalledPkgList.GetPackageForName(pkg.Name) != null) ) {
- continue; // ã¤ã³ã¹ãã¼ã«æ¸ã¿ã¯æ¬¡ã®ã«ã¼ãã¸(æªã¤ã³ã¹ãã¼ã«ã½ããæ½åºæ)
- }
-
- ListViewItem item = new ListViewItem(new string[]{pkg.Name, pkg.Version, pkg.Summary});
- item.Tag = pkg;
- item.ToolTipText = pkg.Summary;
-
- this.packageListView.Items.Add(item);
- }
- }
- }
-
- if (currentPackageFilter == PackageFilterIndex.All || currentPackageFilter == PackageFilterIndex.InstalledAS) {
- foreach (Package pkg in pkgListsMan.InstalledPkgList.Search(searchTextBox.Text)) {
- ListViewItem item = new ListViewItem(new string[]{pkg.Name, pkg.Version, pkg.Summary});
- item.Tag = pkg;
- item.ToolTipText = pkg.Summary;
- item.ImageKey = "installed";
-
- this.packageListView.Items.Add(item);
- }
- }
-
- if (currentPackageFilter == PackageFilterIndex.All || currentPackageFilter == PackageFilterIndex.InstalledSys) {
- foreach (Package pkg in pkgListsMan.SystemInstalledPkgList.Search(searchTextBox.Text)) {
- ListViewItem item = new ListViewItem(new string[]{pkg.Name, pkg.Version, pkg.Summary});
- item.Tag = pkg;
- item.ToolTipText = pkg.Summary;
- item.ImageKey = "sys";
-
- this.packageListView.Items.Add(item);
- }
- }
-
- PackageListViewSelectedIndexChanged(packageListView, null);
- detailBox.Refresh();
-
- //this.packageListView.AutoResizeColumns(ColumnHeaderAutoResizeStyle.ColumnContent);
- }
-
void DetailBoxLinkClicked(object sender, LinkClickedEventArgs e)
{
if (System.Text.RegularExpressions.Regex.IsMatch(e.LinkText, "^https?://")){
@@ -328,7 +232,7 @@ namespace AppliStation
{
AppliStation.Util.ExecutionProgressViewer prog = new AppliStation.Util.ExecutionProgressViewer();
prog.Shown += delegate(object sender2, EventArgs e2) {
- NaGet.SubCommands.NaGetUpdate tasks = new NaGet.SubCommands.NaGetUpdate(pkgListsMan, downloadPackageListsFlag);
+ NaGet.SubCommands.NaGetUpdate2 tasks = new NaGet.SubCommands.NaGetUpdate2(pkgListsMan, downloadPackageListsFlag);
prog.SetTaskSet(tasks);
prog.Refresh();
prog.StartTaskSet();
@@ -337,7 +241,7 @@ namespace AppliStation
prog.ShowDialog(this);
}
- void UpdateToolStripButtonClick(object sender, EventArgs e)
+ void UpdateToolStripMenuItemClick(object sender, EventArgs e)
{
updateActionInvoke(true);
@@ -351,6 +255,142 @@ namespace AppliStation
UpdatePackageList();
}
+ void SoftCollectionFileImportToolStripMenuItemClick(object sender, EventArgs e)
+ {
+ string pwd = Directory.GetCurrentDirectory();
+
+ OpenFileDialog fd = new OpenFileDialog();
+ fd.Filter = "ã½ããã³ã¬ã¯ã·ã§ã³ãã¡ã¤ã« (*.txt)|*.txt";
+ fd.DefaultExt = "txt";
+ fd.CheckFileExists = true;
+ fd.CheckPathExists = true;
+ fd.Multiselect = false;
+ fd.ShowDialog();
+ if (fd.FileNames.Length > 0) {
+ string filepath = Path.GetFullPath(fd.FileName);
+ Directory.SetCurrentDirectory(pwd); // ãã¡ã¤ã«ãã¤ã¢ãã°ã§å¤ãã£ãã«ã¬ã³ããã£ã¬ã¯ããªãæ»ã
+
+ IList pkgs;
+ IList invalid;
+
+ try {
+ PackageCollectionFileData collectionData = new PackageCollectionFileData();
+ collectionData.load(filepath);
+ collectionData.generatePackages(pkgListsMan, out pkgs, out invalid);
+
+ if (invalid.Count > 0) {
+ DialogResult result = MessageBox.Show("ä¸é¨èªã¿è¾¼ã¿ã®å¤±æããããã±ã¼ã¸ãããã¾ããç¶è¡ãã¾ãã?", "ã¤ã³ãã¼ã", MessageBoxButtons.OKCancel, MessageBoxIcon.Error);
+ if (result != DialogResult.OK) {
+ return;
+ }
+ }
+ } catch (IOException) {
+ MessageBox.Show("ãã¡ã¤ã«ã®èªã¿è¾¼ã¿ã«å¤±æãã¾ãã", "ã¤ã³ãã¼ã", MessageBoxButtons.OK, MessageBoxIcon.Error);
+ return;
+ }
+
+ {
+ InstallationConfirmForm confirm = new InstallationConfirmForm();
+ confirm.PkgListsManager = pkgListsMan;
+ confirm.Installations = Installation.ConvertInstallations( NaGet.Utils.IEnumerable2Array(pkgs) );
+ confirm.UseRunas = confirm.GetShouldUseRunas();
+ DialogResult result = confirm.ShowDialog(this);
+
+ if (result == DialogResult.OK) {
+ Installation[] insts = confirm.CheckedInstallations;
+
+ if (confirm.UseRunas) {
+ installRunasActionInvoke(insts);
+ } else {
+ installActionInvoke(insts);
+ }
+
+ UpdatePackageList();
+ }
+ }
+ } else {
+ Directory.SetCurrentDirectory(pwd); // ãã¡ã¤ã«ãã¤ã¢ãã°ã§å¤ãã£ãã«ã¬ã³ããã£ã¬ã¯ããªãæ»ã
+ }
+ }
+
+ void SoftCollectionFileExportToolStripMenuItemClick(object sender, EventArgs e)
+ {
+ string pwd = Directory.GetCurrentDirectory();
+ string[] softtargets = new string[]{
+ "PCã«ã¤ã³ã¹ãã¼ã«ãããã½ãã",
+ "AppliStationå
ã§ã¤ã³ã¹ãã¼ã«ãããã½ãã",
+ "ã¤ã³ã¹ãã¼ã«ãããã½ãããã¹ã¦;PCã¨AppliStationã«ã¤ã³ã¹ãã¼ã«ãããã½ããã®ä¸¡æ¹"
+ };
+ int softtargetid = softtargets.Length - 1;
+
+ {
+ AppliStation.Util.OptionDialog optdialog = AppliStation.Util.OptionDialog.createCommandSelectionDialog(
+ "ã½ããã³ã¬ã¯ã·ã§ã³ãã¡ã¤ã«ã«åºåããã½ããã®ç¨®é¡ãé¸æãã¦ãã ããã", "ã¨ã¯ã¹ãã¼ã", "ã¨ã¯ã¹ãã¼ãããã½ãã",
+ System.Drawing.SystemIcons.Question,
+ softtargets, softtargets.Length-1);
+ if (optdialog.ShowDialog(this) != DialogResult.OK) {
+ return; // canceled
+ } else if (optdialog.UserInputValue != null) {
+ softtargetid = (int) optdialog.UserInputValue;
+ }
+ }
+
+ SaveFileDialog fd = new SaveFileDialog();
+ fd.Filter = "ã½ããã³ã¬ã¯ã·ã§ã³ãã¡ã¤ã« (*.txt)|*.txt";
+ fd.DefaultExt = "txt";
+ fd.CheckPathExists = true;
+ fd.OverwritePrompt = true;
+ fd.ShowDialog();
+ if (fd.FileNames.Length > 0) {
+ string filepath = Path.GetFullPath(fd.FileName);
+ Directory.SetCurrentDirectory(pwd); // ãã¡ã¤ã«ãã¤ã¢ãã°ã§å¤ãã£ãã«ã¬ã³ããã£ã¬ã¯ããªãæ»ã
+
+ PackageCollectionFileData collectionData = new PackageCollectionFileData();
+
+ switch (softtargetid) {
+ case 0: // PCã«ã¤ã³ã¹ãã¼ã«
+ collectionData.loadPackages(pkgListsMan.SystemInstalledPkgList.GetEnumerator());
+ break;
+ case 1: // AppliStationå
ã«ã¤ã³ã¹ãã¼ã«
+ collectionData.loadPackages(pkgListsMan.InstalledPkgList.GetEnumerator());
+ break;
+ case 2: // ãã¹ã¦
+ default:
+ collectionData.loadPackages(pkgListsMan.GetAllInstalledPackages());
+ break;
+ }
+
+ try {
+ collectionData.saveAs(fd.FileName);
+ } catch (UnauthorizedAccessException) {
+ if ((File.GetAttributes(fd.FileName) & FileAttributes.ReadOnly) != 0) {
+ MessageBox.Show("èªã¿åãå°ç¨å±æ§ãè¨å®ããã¦ãã¾ãã\nå¥ã®ãã¡ã¤ã«ãæå®ãã¦ãã ããã", "ã¨ã¯ã¹ãã¼ã", MessageBoxButtons.OK, MessageBoxIcon.Error);
+ } else {
+ MessageBox.Show("ãã¡ã¤ã«ã¸ã®æ¸ãè¾¼ã¿ã許å¯ããã¦ãã¾ããã\nå¥ã®ãã¡ã¤ã«ãæå®ãã¦ãã ããã", "ã¨ã¯ã¹ãã¼ã", MessageBoxButtons.OK, MessageBoxIcon.Error);
+ }
+ return;
+ } catch (IOException) {
+ MessageBox.Show("ãã¡ã¤ã«ã®æ¸ãè¾¼ã¿ã«å¤±æãã¾ãã", "ã¨ã¯ã¹ãã¼ã", MessageBoxButtons.OK, MessageBoxIcon.Error);
+ return;
+ }
+ } else {
+ Directory.SetCurrentDirectory(pwd); // ãã¡ã¤ã«ãã¤ã¢ãã°ã§å¤ãã£ãã«ã¬ã³ããã£ã¬ã¯ããªãæ»ã
+ }
+ }
+
+ void OptionToolStripMenuItemClick(object sender, EventArgs e)
+ {
+ UserPrefForm userPrefForm = new UserPrefForm();
+ DialogResult result = userPrefForm.ShowDialog(this);
+
+ if (result == DialogResult.OK) {
+ if (userPrefForm.IsRepositoryListSettingChanged) {
+ updateActionInvoke(true);
+ UpdatePackageList();
+ }
+ }
+ }
+
#region searchTextBoxã¾ãã
void SearchTextBoxKeyPress(object sender, KeyPressEventArgs e)
@@ -367,7 +407,7 @@ namespace AppliStation
void SearchTextBoxTextChangedTriggerFired(object sender, EventArgs e)
{
- PackageListViewUpdate();
+ packageListView.FilteringKeyword = searchTextBox.Text;
}
#endregion
@@ -376,7 +416,7 @@ namespace AppliStation
{
AppliStation.Util.ExecutionProgressViewer prog = new AppliStation.Util.ExecutionProgressViewer();
prog.Shown += delegate(object sender2, EventArgs e2) {
- NaGet.SubCommands.NaGetInstall tasks = new NaGet.SubCommands.NaGetInstall(pkgListsMan, insts);
+ NaGet.SubCommands.NaGetInstall2 tasks = new NaGet.SubCommands.NaGetInstall2(pkgListsMan, insts);
prog.SetTaskSet(tasks);
prog.Refresh();
prog.StartTaskSet();
@@ -389,7 +429,7 @@ namespace AppliStation
{
InstallationConfirmForm confirm = new InstallationConfirmForm();
confirm.PkgListsManager = pkgListsMan;
- confirm.Installations = Installation.ConvertInstallations( NaGet.Utils.IEnumerable2Array(SelectedPackages()) );
+ confirm.Installations = Installation.ConvertInstallations( NaGet.Utils.IEnumerable2Array(packageListView.SelectedPackages) );
confirm.UseRunas = confirm.GetShouldUseRunas();
DialogResult result = confirm.ShowDialog(this);
@@ -438,8 +478,7 @@ namespace AppliStation
if (File.Exists(tmpfileName)) {
File.Delete(tmpfileName);
- }
- this.setWindowEnabled(true);
+ } this.setWindowEnabled(true);
}
}
@@ -447,7 +486,7 @@ namespace AppliStation
{
AppliStation.Util.ExecutionProgressViewer prog = new AppliStation.Util.ExecutionProgressViewer();
prog.Shown += delegate(object sender2, EventArgs e2) {
- NaGet.SubCommands.NaGetUninstall tasks = new NaGet.SubCommands.NaGetUninstall(pkgListsMan, pkgs);
+ NaGet.SubCommands.NaGetUninstall2 tasks = new NaGet.SubCommands.NaGetUninstall2(pkgListsMan, pkgs);
prog.SetTaskSet(tasks);
prog.Refresh();
prog.StartTaskSet();
@@ -496,10 +535,7 @@ namespace AppliStation
void UninstallToolStripButtonClick(object sender, EventArgs e)
{
PackageUninstallConfirmForm confirm = new PackageUninstallConfirmForm();
- foreach (InstalledPackage pkg in SelectedPackages()) {
- confirm.UninstallPackage = pkg;
- break;
- }
+ confirm.UninstallPackage = (InstalledPackage) packageListView.SelectedPackage;
confirm.UseRunas = confirm.GetShouldUseRunas();
DialogResult result = confirm.ShowDialog(this);
@@ -516,26 +552,48 @@ namespace AppliStation
}
}
+ internal void downloadActionInvoke(Installation[] pkgs)
+ {
+ AppliStation.Util.ExecutionProgressViewer prog = new AppliStation.Util.ExecutionProgressViewer();
+ prog.Shown += delegate(object sender2, EventArgs e2) {
+ NaGet.SubCommands.NaGetDownloadToCache2 tasks = new NaGet.SubCommands.NaGetDownloadToCache2(pkgListsMan, pkgs);
+ prog.SetTaskSet(tasks);
+ prog.Refresh();
+ prog.StartTaskSet();
+ };
+ prog.Text = string.Format("ãã£ãã·ã¥ã¸ã®ãã¦ã³ãã¼ã");
+ prog.ShowDialog(this);
+ }
- void WebOfficialToolStripMenuItemClick(object sender, EventArgs e)
+ void DownloadToolStripMenuItemClick(object sender, EventArgs e)
{
- foreach (Package pkg in SelectedPackages()) {
+ Installation[] insts = Installation.ConvertInstallations( NaGet.Utils.IEnumerable2Array(packageListView.SelectedPackages) );
+
+ downloadActionInvoke(insts);
+
+ UpdatePackageList();
+ }
+
+ void WebOfficialMenuItemClick(object sender, EventArgs e)
+ {
+ Package pkg = packageListView.SelectedPackage;
+ if (pkg != null) {
string linkURL = pkg.Url.Href;
- if (! (pkg == null || string.IsNullOrEmpty(linkURL))) {
+ if (! string.IsNullOrEmpty(linkURL)) {
try {
System.Diagnostics.Process.Start(linkURL);
} catch (System.ComponentModel.Win32Exception) {
MessageBox.Show(string.Format("{0}ãéãã®ã«å¤±æãã¾ããã", linkURL), "ãã©ã¦ã¶èµ·åã¨ã©ã¼", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
- break;
}
}
- void WebGoogleSearchToolStripMenuItemClick(object sender, EventArgs e)
+ void WebGoogleSearchMenuItemClick(object sender, EventArgs e)
{
- foreach (Package pkg in SelectedPackages()) {
+ Package pkg = packageListView.SelectedPackage;
+ if (pkg != null) {
string q = System.Web.HttpUtility.UrlEncode(pkg.Name, System.Text.Encoding.UTF8);
string googleURL = @"http://www.google.co.jp/search?q="+q;
@@ -544,102 +602,125 @@ namespace AppliStation
} catch (System.ComponentModel.Win32Exception) {
MessageBox.Show("Googleãéãã®ã«å¤±æãã¾ããã", "ãã©ã¦ã¶èµ·åã¨ã©ã¼", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
-
- break;
}
}
void OpenInstalledDirectoryStripMenuItemClick(object sender, EventArgs e)
{
- foreach (InstalledPackage pkg in SelectedPackages()) {
- if (pkg.Type == InstallerType.ARCHIVE) {
+ InstalledPackage pkg = (InstalledPackage) packageListView.SelectedPackage;
+ if (pkg != null) {
+ if (pkg.Type == InstallerType.ARCHIVE || pkg.Type == InstallerType.ITSELF) {
System.Diagnostics.Process.Start(Path.Combine(NaGet.Env.ArchiveProgramFiles, pkg.Name));
- } else if (Directory.Exists(pkg.discoverInstalledLocation())) {
- System.Diagnostics.Process.Start(pkg.discoverInstalledLocation());
+ } else if (Directory.Exists(pkg.DiscoverInstalledLocation())) {
+ System.Diagnostics.Process.Start(pkg.DiscoverInstalledLocation());
}
-
- break;
}
}
- void PropertiesToolStripMenuItemClick(object sender, EventArgs e)
+ void PropertiesCommonMenuItemClick(object sender, EventArgs e)
{
- foreach (Package pkg in SelectedPackages()) {
+ if (packageListView.SelectedItems.Count >= 5) {
+ string msg = string.Format("{0}åã®ããããã£ãã¤ã¢ãã°ãéããã¨ãã¦ãã¾ãã\nç¶ç¶ãã¾ãã?", packageListView.SelectedItems.Count);
+ if (MessageBox.Show(msg, "ããããã£", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) {
+ return;
+ }
+ }
+
+ foreach (Package pkg in packageListView.SelectedPackages) {
PackageInfoForm form = new PackageInfoForm();
form.SelectedObject = pkg;
form.Text = string.Format("{0}({1})ã®ããããã£", pkg.Name, pkg.Version);
- form.ShowDialog(this);
-
- break;
+ form.Show(this);
}
}
- void PackageListContextMenuStripOpening(object sender, System.ComponentModel.CancelEventArgs e)
+ private void updateLauncherMenuItem(AppliStation.Util.ToolStripPetitLauncherMenuItem launcherMenuItem)
{
- // ã³ã³ãã¯ã¹ãã¡ãã¥ã¼ããéãããªãã£ãå ´åã¯ã¤ã³ã¹ãã¼ã«/ã¢ã³ã¤ã³ã¹ãã¼ã«ã¯è¡¨ç¤ºããªã
- bool parentIsPkgListView = (packageListContextMenuStrip.SourceControl == packageListView);
- // ã¡ãã¥ã¼ã¢ã¤ãã ã®ã¤ã³ã¹ãã¼ã«/ã¢ã³ã¤ã³ã¹ãã¼ã«ã®è¡¨ç¤ºã¯ãã¼ã«ã¹ããªããã«åã
- installToolStripMenuItem.Visible = parentIsPkgListView && installToolStripButton.Visible;
- uninstallToolStripMenuItem.Visible = parentIsPkgListView && uninstallToolStripButton.Visible;
-
- // ã¤ã³ã¹ãã¼ã«ãã¢ã³ã¤ã³ã¹ãã¼ã«ãã§ããªãç¶æ
ãªãã°ãã¡ãã¥ã¼ã表示ããªã
- if (! (installToolStripButton.Visible || uninstallToolStripButton.Visible)) {
- e.Cancel = true;
- return;
- }
-
- // é¸æããã±ã¼ã¸ã1ã¤ã®ã¨ã
bool selectionIsOnlyOne = packageListView.SelectedItems.Count == 1;
+
if (selectionIsOnlyOne) {
- Package pkg = SelectedPackage();
- bool isInstalledPackage = pkg is InstalledPackage;
-
- webResourcesToolStripMenuItem.Text = string.Format(
- webResourcesToolStripMenuItem.Tag.ToString(),
- pkg.Name.Replace("&", "&&")); // pkg.Nameã«&ãå«ã¾ãã¦ããã¨ãã¯ã¨ã³ã³ã¼ã
- webOfficialToolStripMenuItem.Enabled = ! (pkg.Url == null || string.IsNullOrEmpty(pkg.Url.Href));
- // webGoogleSearchToolStripMenuItem always active.
+ Package pkg = packageListView.SelectedPackage;
+ InstalledPackage iPkg = pkg as InstalledPackage;
- bool installedDirectoryStripMenuItemVisible = isInstalledPackage &&
- ( (pkg.Type == InstallerType.ARCHIVE) || Directory.Exists(((InstalledPackage) pkg).discoverInstalledLocation()) );
- installedDirectoryStripMenuItem.Visible = installedDirectoryStripMenuItemVisible;
- if (installedDirectoryStripMenuItemVisible) {
- buildInstalledDirectoryMenuItemStripChildren((InstalledPackage) pkg);
+ // ã¤ã³ã¹ãã¼ã«æ¸ã¿ããã±ã¼ã¸ã®ã¨ã
+ if (iPkg != null) {
+ bool launcherMenuItemVisible =
+ (pkg.Type == InstallerType.ARCHIVE) ||
+ (pkg.Type == InstallerType.ITSELF) ||
+ Directory.Exists(iPkg.DiscoverInstalledLocation());
+
+ launcherMenuItem.Visible = launcherMenuItemVisible;
+ if (launcherMenuItemVisible) {
+ launcherMenuItem.BaseFolderPath = iPkg.DiscoverInstalledLocation();
+ }
+ } else {
+ launcherMenuItem.Visible = false;
}
+ } else {
+ launcherMenuItem.Visible = false;
}
-
- packageListContextMenuStripSeparator.Visible = parentIsPkgListView && selectionIsOnlyOne;
- webResourcesToolStripMenuItem.Visible = selectionIsOnlyOne;
- if (! selectionIsOnlyOne) installedDirectoryStripMenuItem.Visible = false;
- propertiesToolStripMenuItem.Visible = selectionIsOnlyOne;
}
- private IEnumerable getUpdatedPackages(PackageList installedPkgList, PackageList avaiablePkgList, IComparer verComp)
+ void PackageListContextMenuStripOpening(object sender, System.ComponentModel.CancelEventArgs e)
{
- foreach (InstalledPackage pkg in installedPkgList) {
- Package avaiablePkg = avaiablePkgList.GetPackageForName(pkg.Name);
-
- if (avaiablePkgList != null) {
- if (verComp.Compare(pkg.Version, avaiablePkg.Version) < 0 &&
- installedPkgList.GetPackageForPackage(pkg.Name, avaiablePkg.Version) == null) {
-
- yield return avaiablePkg;
- }
+ bool selectionIsOnlyOne = packageListView.SelectedItems.Count == 1;
+ bool hasSelection = packageListView.SelectedItems.Count > 0;
+
+ updateSelectedPackages();
+
+ // ã¤ã³ã¹ãã¼ã«å
ã®ãã©ã«ãã®è¨å®
+ updateLauncherMenuItem(installedDirectoryToolStripMenuItem);
+
+ if (packageListView.View == View.Details) {
+ // ãããé¨ãã¯ãªãã¯ãããã¨ããããã±ã¼ã¸ãé¸æããã¦ããªããã®ã¨ãã¦æ±ã£ã¦å¦çãããã
+ int headerHeight = AppliStation.Util.NativeMethods.ColumnHeader_GetSize(packageListView).Height;
+ if (packageListView.PointToClient(packageListContextMenuStrip.Location).Y < headerHeight) {
+ selectionIsOnlyOne = hasSelection = false;
+ installToolStripMenuItem.Visible = false;
+ uninstallToolStripMenuItem.Visible = false;
+ installedDirectoryToolStripMenuItem.Visible = false;
}
}
+
+ packageListContextMenuStripSeparator.Visible = selectionIsOnlyOne;
+ webResourceToolStripMenuItem.Visible = selectionIsOnlyOne;
+ propertiesToolStripMenuItem.Visible = hasSelection;
+ columnToolStripMenuItem.Visible = (! hasSelection) && (packageListView.View == View.Details);
}
- void UpgradeToolStripButtonClick(object sender, EventArgs e)
+ void InformationToolStripDropDownButtonDropDownOpening(object sender, EventArgs e)
{
- List pkgs;
- VersionComparetor verComp = new VersionComparetor();
- PackageList avaiablePackageList = pkgListsMan.AvailablePkgList;
+ bool selectionIsOnlyOne = packageListView.SelectedItems.Count == 1;
+ bool hasSelection = packageListView.SelectedItems.Count > 0;
+
+ // ã¤ã³ã¹ãã¼ã«å
ã®ãã©ã«ãã®è¨å®
+ updateLauncherMenuItem(installedDirectoryMenuItem);
- pkgs = NaGet.Utils.MeargeList(
- getUpdatedPackages(pkgListsMan.InstalledPkgList, avaiablePackageList, verComp),
- getUpdatedPackages(pkgListsMan.SystemInstalledPkgList, avaiablePackageList, verComp)
+ webResourceMenuItem.Visible = selectionIsOnlyOne;
+ propertiesMenuItem.Visible = hasSelection;
+ }
+
+ void WebResourceCommonContextMenuStripOpening(object sender, System.ComponentModel.CancelEventArgs e)
+ {
+ Package pkg = packageListView.SelectedPackage;
+
+ if (pkg != null && pkg.Url != null && !string.IsNullOrEmpty(pkg.Url.Href)) {
+ webOfficialMenuItem.Enabled = true;
+ webOfficialMenuItem.ToolTipText = pkg.Url.Href;
+ } else {
+ webOfficialMenuItem.Enabled = false;
+ webOfficialMenuItem.ToolTipText = null;
+ }
+
+ // webGoogleSearchMenuItem always active.
+ }
+
+ void UpgradeToolStripButtonClick(object sender, EventArgs e)
+ {
+ List pkgs = new List(
+ UpgradeFinder.GetUpgradePackages(pkgListsMan)
);
if (pkgs.Count <= 0) {
@@ -665,35 +746,22 @@ namespace AppliStation
}
}
- public void UpdatePackageList()
- {
- pkgListsMan.LoadPackageLists();
- this.PackageListViewUpdate();
- }
-
- ///
- /// ã¤ã³ã¹ãã¼ã«ããããé¸æãããããã±ã¼ã¸ã®é
å
- ///
- public IEnumerable SelectedPackages() where TPackage : Package
+ protected override bool ProcessCmdKey(ref Message msg, Keys keyData)
{
- List pkgs = new List();
- foreach (ListViewItem item in packageListView.SelectedItems) {
- pkgs.Add((TPackage) item.Tag);
+ if ((int)keyData == (int)Keys.Control + (int)Keys.E) {
+ searchTextBox.SelectAll();
+ searchTextBox.Focus();
+ return true;
}
- return pkgs;
+ return base.ProcessCmdKey(ref msg, keyData);
}
- ///
- /// ã¤ã³ã¹ãã¼ã«ããããé¸æãããããã±ã¼ã¸ãã²ã¨ã¤è¿ãã
- ///
- /// é¸æãããããã±ã¼ã¸(é¸æããã¦ããªãã¨ãã¯null)
- public TPackage SelectedPackage() where TPackage : Package
+ public void UpdatePackageList()
{
- foreach (ListViewItem item in packageListView.SelectedItems) {
- return (TPackage) item.Tag;
- }
- return null;
+ pkgListsMan.LoadPackageLists();
+ packageListView.UpdateItems();
+ updateSelectedPackages();
}
///
@@ -712,6 +780,47 @@ namespace AppliStation
process.Invoke();
}
}
+
+ void ColumnCommonToolStripMenuItemClick(object sender, EventArgs e)
+ {
+ packageListView.BeginUpdate();
+ ColumnHeader sortcolumn = packageListView.SortColumn;
+
+ // åã®è¿½å ã¨åé¤
+ foreach (ToolStripItem item in columnToolStripMenuItem.DropDownItems) {
+ ToolStripMenuItem menu = item as ToolStripMenuItem;
+ if (menu != null) {
+ bool exists = false;
+ // åãåå¨ãã¦ããããã§ãã¯ãå¤ãã¦ãããåé¤ããã
+ foreach (ColumnHeader header in packageListView.Columns) {
+ if (header.Tag == menu.Tag) {
+ exists = true;
+ if (sortcolumn == header) {
+ packageListView.SortColumn = sortcolumn = null;
+ }
+ if (menu.Checked == false) {
+ packageListView.Columns.Remove(header);
+ }
+ break;
+ }
+ }
+
+ // åãåå¨ãã¦ããªãããã§ãã¯ãããã¦ãããªã追å ããã
+ if (menu.Checked && !exists) {
+ ColumnHeader header = new ColumnHeader();
+ header.Text = menu.Text;
+ header.Tag = menu.Tag;
+ packageListView.Columns.Add(header);
+ }
+ }
+ }
+
+ AppliStation.Util.NativeMethods.ColumnHeader_SetSortState(packageListView, (sortcolumn != null)? sortcolumn.Index : -1, SortOrder.None);
+
+ packageListView.UpdateItems();
+
+ packageListView.EndUpdate();
+ }
}
}