mirror of
				https://github.com/velopack/velopack.git
				synced 2025-10-25 15:19:22 +00:00 
			
		
		
		
	Remove logging in csq by default, add --csq-verbose param if it's needed.
This commit is contained in:
		
							
								
								
									
										1
									
								
								push.cmd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								push.cmd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | dotnet nuget push .\build\Release\*.nupkg -k %1 -s https://nuget.pkg.github.com/clowd/index.json --skip-duplicate | ||||||
| @@ -25,10 +25,8 @@ namespace Squirrel.CommandLine | |||||||
|                 { "verbose", "Print all diagnostic messages", _ => verbose = true }, |                 { "verbose", "Print all diagnostic messages", _ => verbose = true }, | ||||||
|             }; |             }; | ||||||
| 
 | 
 | ||||||
|             var exeName = Path.GetFileName(SquirrelRuntimeInfo.EntryExePath); |             string sqUsage = $"Squirrel {SquirrelRuntimeInfo.SquirrelDisplayVersion} for creating and distributing Squirrel releases."; | ||||||
|             string sqUsage = |             Console.WriteLine(sqUsage); | ||||||
|                 $"Squirrel {SquirrelRuntimeInfo.SquirrelDisplayVersion}, tool for creating Squirrel releases" + Environment.NewLine + |  | ||||||
|                 $"Usage: {exeName} [verb] [--option=value]"; |  | ||||||
| 
 | 
 | ||||||
|             try { |             try { | ||||||
|                 var restArgs = globalOptions.Parse(args); |                 var restArgs = globalOptions.Parse(args); | ||||||
| @@ -59,8 +57,6 @@ namespace Squirrel.CommandLine | |||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 var commands = new CommandSet { |                 var commands = new CommandSet { | ||||||
|                     "", |  | ||||||
|                     sqUsage, |  | ||||||
|                     "", |                     "", | ||||||
|                     "[ Global Options ]", |                     "[ Global Options ]", | ||||||
|                     globalOptions.GetHelpText().TrimEnd(), |                     globalOptions.GetHelpText().TrimEnd(), | ||||||
| @@ -102,7 +98,7 @@ namespace Squirrel.CommandLine | |||||||
|                 logger.Write(ex.ToString(), LogLevel.Error); |                 logger.Write(ex.ToString(), LogLevel.Error); | ||||||
|                 Console.WriteLine(); |                 Console.WriteLine(); | ||||||
|                 Console.WriteLine(sqUsage); |                 Console.WriteLine(sqUsage); | ||||||
|                 Console.WriteLine($" > '{exeName} -h' to see program help."); |                 Console.WriteLine($" > 'csq -h' to see program help."); | ||||||
|                 return -1; |                 return -1; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -8,94 +8,101 @@ using System.Xml.Linq; | |||||||
| using Microsoft.Build.Construction; | using Microsoft.Build.Construction; | ||||||
| using Mono.Options; | using Mono.Options; | ||||||
| using NuGet.Versioning; | using NuGet.Versioning; | ||||||
| using Squirrel.CommandLine; |  | ||||||
| 
 | 
 | ||||||
| namespace Squirrel.Tool | namespace Squirrel.Tool | ||||||
| { | { | ||||||
|     class Program |     class Program | ||||||
|     { |     { | ||||||
|         private const string EMBEDDED_FLAG = "--csq-embedded"; |         private static bool Verbose { get; set; } | ||||||
| 
 | 
 | ||||||
|         static int Main(string[] inargs) |         static int Main(string[] inargs) | ||||||
|         { |         { | ||||||
|             try { |             try { | ||||||
|                 bool useEmbedded = false; |                 return MainInner(inargs); | ||||||
|                 string explicitSquirrelPath = null; |  | ||||||
|                 string explicitSolutionPath = null; |  | ||||||
| 
 |  | ||||||
|                 var toolOptions = new OptionSet() { |  | ||||||
|                     { "csq-embedded", _ => useEmbedded = true }, |  | ||||||
|                     { "csq-path=", v => explicitSquirrelPath = v }, |  | ||||||
|                     { "csq-sln=", v => explicitSolutionPath = v }, |  | ||||||
|                 }; |  | ||||||
| 
 |  | ||||||
|                 var restArgs = toolOptions.Parse(inargs).ToArray(); |  | ||||||
| 
 |  | ||||||
|                 // explicitly told to execute embedded version |  | ||||||
|                 if (useEmbedded) { |  | ||||||
|                     return SquirrelHost.Main(restArgs); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 // explicitly told to use specific version at this directory |  | ||||||
|                 if (explicitSquirrelPath != null) { |  | ||||||
|                     return RunCsqFromPath(explicitSquirrelPath, restArgs); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 Console.WriteLine($"Squirrel Locator (csq) {SquirrelRuntimeInfo.SquirrelDisplayVersion}"); |  | ||||||
| 
 |  | ||||||
|                 // try to find the solution directory |  | ||||||
|                 string slnDir; |  | ||||||
|                 if (File.Exists(explicitSolutionPath) && explicitSolutionPath.EndsWith(".sln", StringComparison.InvariantCultureIgnoreCase)) { |  | ||||||
|                     slnDir = Path.GetDirectoryName(Path.GetFullPath(explicitSolutionPath)); |  | ||||||
|                 } else { |  | ||||||
|                     var cwd = Environment.CurrentDirectory; |  | ||||||
|                     var slnSearchDirs = new string[] { |  | ||||||
|                         cwd, |  | ||||||
|                         Path.Combine(cwd, ".."), |  | ||||||
|                         Path.Combine(cwd, "..", ".."), |  | ||||||
|                     }; |  | ||||||
|                      |  | ||||||
|                     slnDir = slnSearchDirs.FirstOrDefault(d => Directory.EnumerateFiles(d, "*.sln").Any()); |  | ||||||
|                     if (slnDir == null) { |  | ||||||
|                         throw new Exception("Could not find '.sln'. Specify solution file with '--csq-sln=' or provide " + |  | ||||||
|                                             "Squirrel tools path with '--csq-path='."); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|                  |  | ||||||
|                 slnDir = Path.GetFullPath(slnDir); |  | ||||||
| 
 |  | ||||||
|                 const string packageName = "Clowd.Squirrel"; |  | ||||||
|                 var dependencies = GetPackageVersionsFromDir(slnDir, packageName).Distinct().ToArray(); |  | ||||||
| 
 |  | ||||||
|                 if (dependencies.Length == 0) { |  | ||||||
|                     Console.WriteLine("Clowd.Squirrel is not installed in the current working dir/project. (Using bundled Squirrel)"); |  | ||||||
|                     return SquirrelHost.Main(restArgs); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 if (dependencies.Length > 1) { |  | ||||||
|                     throw new Exception("Found multiple versions of Clowd.Squirrel installed in current working dir/project. " + |  | ||||||
|                                         "Please consolidate to a single version: " + string.Join(", ", dependencies)); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 var targetVersion = dependencies.Single(); |  | ||||||
|                 var toolsDir = GetToolPathFromUserCache(targetVersion, packageName); |  | ||||||
| 
 |  | ||||||
|                 var localpath = Path.Combine(slnDir, "packages", packageName + "." + targetVersion, "tools"); |  | ||||||
|                 if (Directory.Exists(localpath)) |  | ||||||
|                     toolsDir = localpath; |  | ||||||
| 
 |  | ||||||
|                 if (!Directory.Exists(toolsDir)) { |  | ||||||
|                     throw new Exception($"Unable to find Squirrel tools for '{targetVersion}'. " + |  | ||||||
|                                         $"Please specify path to tools directory with '--csq-path' argument."); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 return RunCsqFromPath(toolsDir, restArgs); |  | ||||||
|             } catch (Exception ex) { |             } catch (Exception ex) { | ||||||
|                 Console.WriteLine(ex); |                 Console.WriteLine("csq error: " + ex.Message); | ||||||
|                 return -1; |                 return -1; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         static int MainInner(string[] inargs) | ||||||
|  |         { | ||||||
|  |             string explicitSquirrelPath = null; | ||||||
|  |             string explicitSolutionPath = null; | ||||||
|  |             bool useEmbedded = false; | ||||||
|  | 
 | ||||||
|  |             var toolOptions = new OptionSet() { | ||||||
|  |                 { "q|csq-embedded", _ => useEmbedded = true }, | ||||||
|  |                 { "csq-path=", v => explicitSquirrelPath = v }, | ||||||
|  |                 { "csq-sln=", v => explicitSolutionPath = v }, | ||||||
|  |                 { "csq-verbose", _ => Verbose = true }, | ||||||
|  |             }; | ||||||
|  | 
 | ||||||
|  |             var restArgs = toolOptions.Parse(inargs).ToArray(); | ||||||
|  | 
 | ||||||
|  |             Write(SquirrelRuntimeInfo.SquirrelDisplayVersion, true); | ||||||
|  | 
 | ||||||
|  |             // explicitly told to execute embedded version | ||||||
|  |             if (useEmbedded) { | ||||||
|  |                 Write("using embedded (--csq-embedded)", true); | ||||||
|  |                 return CommandLine.SquirrelHost.Main(restArgs); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             // explicitly told to use specific version at this directory | ||||||
|  |             if (explicitSquirrelPath != null) { | ||||||
|  |                 return RunCsqFromPath(explicitSquirrelPath, restArgs); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             // try to find the solution directory from cwd | ||||||
|  |             string slnDir; | ||||||
|  |             if (File.Exists(explicitSolutionPath) && explicitSolutionPath.EndsWith(".sln", StringComparison.InvariantCultureIgnoreCase)) { | ||||||
|  |                 slnDir = Path.GetDirectoryName(Path.GetFullPath(explicitSolutionPath)); | ||||||
|  |             } else { | ||||||
|  |                 var cwd = Environment.CurrentDirectory; | ||||||
|  |                 var slnSearchDirs = new string[] { | ||||||
|  |                     cwd, | ||||||
|  |                     Path.Combine(cwd, ".."), | ||||||
|  |                     Path.Combine(cwd, "..", ".."), | ||||||
|  |                 }; | ||||||
|  | 
 | ||||||
|  |                 slnDir = slnSearchDirs.FirstOrDefault(d => Directory.EnumerateFiles(d, "*.sln").Any()); | ||||||
|  |                 if (slnDir == null) { | ||||||
|  |                     throw new Exception("Could not find '.sln'. Specify solution file with '--csq-sln=', provide " + | ||||||
|  |                                         "Squirrel tools path with '--csq-path=' argument, or use embedded version with '--csq-embedded'."); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             slnDir = Path.GetFullPath(slnDir); | ||||||
|  |             Write("solution dir " + slnDir, true); | ||||||
|  | 
 | ||||||
|  |             const string packageName = "Clowd.Squirrel"; | ||||||
|  |             var dependencies = GetPackageVersionsFromDir(slnDir, packageName).Distinct().ToArray(); | ||||||
|  | 
 | ||||||
|  |             if (dependencies.Length == 0) { | ||||||
|  |                 throw new Exception("Clowd.Squirrel nuget package was not found in solution."); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (dependencies.Length > 1) { | ||||||
|  |                 throw new Exception("Found multiple versions of Clowd.Squirrel installed in solution. " + | ||||||
|  |                                     "Please consolidate the following to a single version: " + string.Join(", ", dependencies)); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             var targetVersion = dependencies.Single(); | ||||||
|  |             var toolsDir = GetToolPathFromUserCache(targetVersion, packageName); | ||||||
|  | 
 | ||||||
|  |             var localpath = Path.Combine(slnDir, "packages", packageName + "." + targetVersion, "tools"); | ||||||
|  |             if (Directory.Exists(localpath)) | ||||||
|  |                 toolsDir = localpath; | ||||||
|  | 
 | ||||||
|  |             if (!Directory.Exists(toolsDir)) { | ||||||
|  |                 throw new Exception($"Unable to find Squirrel tools for '{targetVersion}'. " + | ||||||
|  |                                     $"Please specify path to tools directory with '--csq-path=' argument, " + | ||||||
|  |                                     $"or use embedded version with '--csq-embedded'."); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return RunCsqFromPath(toolsDir, restArgs); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         static string GetToolPathFromUserCache(string targetVersion, string packageName) |         static string GetToolPathFromUserCache(string targetVersion, string packageName) | ||||||
|         { |         { | ||||||
|             var packages = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".nuget", "packages"); |             var packages = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".nuget", "packages"); | ||||||
| @@ -106,7 +113,7 @@ namespace Squirrel.Tool | |||||||
|             // resolve wildcards. we should probably rely on the dotnet tooling for this in the future |             // resolve wildcards. we should probably rely on the dotnet tooling for this in the future | ||||||
|             // so we can be more certain we are using precisely the same version as dotnet. |             // so we can be more certain we are using precisely the same version as dotnet. | ||||||
|             if (targetVersion.Contains("*")) { |             if (targetVersion.Contains("*")) { | ||||||
|                 Console.WriteLine($"Project version is '{targetVersion}'. Attempting to resolve wildcard..."); |                 Write($"Project version is '{targetVersion}'. Attempting to resolve wildcard...", false); | ||||||
|                 var packageDir = Path.Combine(packages, packageName.ToLower()); |                 var packageDir = Path.Combine(packages, packageName.ToLower()); | ||||||
|                 var vdir = Directory.EnumerateDirectories(packageDir, targetVersion, SearchOption.TopDirectoryOnly) |                 var vdir = Directory.EnumerateDirectories(packageDir, targetVersion, SearchOption.TopDirectoryOnly) | ||||||
|                     .Select(d => new DirectoryInfo(d).Name) |                     .Select(d => new DirectoryInfo(d).Name) | ||||||
| @@ -131,15 +138,14 @@ namespace Squirrel.Tool | |||||||
|             Process p; |             Process p; | ||||||
| 
 | 
 | ||||||
|             if (File.Exists(toolDllPath)) { |             if (File.Exists(toolDllPath)) { | ||||||
|                 var dnargs = new[] { toolDllPath, EMBEDDED_FLAG }.Concat(args); |                 var dnargs = new[] { toolDllPath, "--csq-embedded" }.Concat(args).ToArray(); | ||||||
|                 Console.WriteLine("Running: dotnet " + String.Join(" ", dnargs)); |                 Write("running dotnet " + String.Join(" ", dnargs), true); | ||||||
|                 Console.WriteLine(); |  | ||||||
|                 p = Process.Start("dotnet", dnargs); |                 p = Process.Start("dotnet", dnargs); | ||||||
|             } else if (File.Exists(toolExePath)) { |             } else if (File.Exists(toolExePath)) { | ||||||
|                 if (!SquirrelRuntimeInfo.IsWindows) |                 if (!OperatingSystem.IsWindows()) | ||||||
|                     throw new NotSupportedException($"Squirrel at '{toolRootPath}' does not support this operating system. Please update the package."); |                     throw new NotSupportedException( | ||||||
|                 Console.WriteLine("Running: " + toolExePath + " " + String.Join(" ", args)); |                         $"Squirrel at '{toolRootPath}' does not support this operating system. Please update the package version to >= 3.0"); | ||||||
|                 Console.WriteLine(); |                 Write("running " + toolExePath + " " + String.Join(" ", args), true); | ||||||
|                 p = Process.Start(toolExePath, args); |                 p = Process.Start(toolExePath, args); | ||||||
|             } else { |             } else { | ||||||
|                 throw new Exception("Unable to locate Squirrel at: " + toolRootPath); |                 throw new Exception("Unable to locate Squirrel at: " + toolRootPath); | ||||||
| @@ -158,13 +164,14 @@ namespace Squirrel.Tool | |||||||
|                 var xdoc = XDocument.Load(xmlReader); |                 var xdoc = XDocument.Load(xmlReader); | ||||||
| 
 | 
 | ||||||
|                 var sqel = xdoc.Root?.Elements().FirstOrDefault(e => e.Attribute("id")?.Value == packageName); |                 var sqel = xdoc.Root?.Elements().FirstOrDefault(e => e.Attribute("id")?.Value == packageName); | ||||||
|                 if (sqel == null) continue; |                 var ver = sqel?.Attribute("version"); | ||||||
| 
 |  | ||||||
|                 var ver = sqel.Attribute("version"); |  | ||||||
|                 if (ver == null) continue; |                 if (ver == null) continue; | ||||||
| 
 | 
 | ||||||
|  |                 Write($"{packageName} {ver.Value} referenced in {packagesFile}", true); | ||||||
|  | 
 | ||||||
|                 if (ver.Value.Contains("*")) |                 if (ver.Value.Contains("*")) | ||||||
|                     throw new Exception("Wildcard versions are not supported in packages.config"); |                     throw new Exception( | ||||||
|  |                         "Wildcard versions are not supported in packages.config. Remove wildcard or upgrade csproj format to use PackageReference."); | ||||||
| 
 | 
 | ||||||
|                 yield return ver.Value; |                 yield return ver.Value; | ||||||
|             } |             } | ||||||
| @@ -178,7 +185,9 @@ namespace Squirrel.Tool | |||||||
|                 if (item == null) continue; |                 if (item == null) continue; | ||||||
| 
 | 
 | ||||||
|                 var version = item.Children.FirstOrDefault(x => x.ElementName == "Version") as ProjectMetadataElement; |                 var version = item.Children.FirstOrDefault(x => x.ElementName == "Version") as ProjectMetadataElement; | ||||||
|                 if (version == null) continue; |                 if (version?.Value == null) continue; | ||||||
|  | 
 | ||||||
|  |                 Write($"{packageName} {version.Value} referenced in {projFile}", true); | ||||||
| 
 | 
 | ||||||
|                 yield return version.Value; |                 yield return version.Value; | ||||||
|             } |             } | ||||||
| @@ -199,5 +208,11 @@ namespace Squirrel.Tool | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         static void Write(string message, bool isDebugMessage) | ||||||
|  |         { | ||||||
|  |             if (Verbose || !isDebugMessage) | ||||||
|  |                 Console.WriteLine("csq: " + message); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
		Reference in New Issue
	
	Block a user