/// <summary> /// Main entry point into the SQL Tools API Service Layer /// </summary> internal static void Main(string[] args) { try { // read command-line arguments ServiceLayerCommandOptions commandOptions = new ServiceLayerCommandOptions(args); if (commandOptions.ShouldExit) { return; } string logFilePath = commandOptions.LogFilePath; if (string.IsNullOrWhiteSpace(logFilePath)) { logFilePath = Logger.GenerateLogFilePath("sqltools"); } Logger.AutoFlush = commandOptions.AutoFlushLog; Logger.Initialize(tracingLevel: commandOptions.TracingLevel, logFilePath: logFilePath, traceSource: "sqltools"); // set up the host details and profile paths var hostDetails = new HostDetails(version: new Version(1, 0)); SqlToolsContext sqlToolsContext = new SqlToolsContext(hostDetails); ServiceHost serviceHost = HostLoader.CreateAndStartServiceHost(sqlToolsContext); serviceHost.WaitForExit(); } catch (Exception ex) { try { Logger.WriteWithCallstack(TraceEventType.Critical, $"An unhandled exception occurred: {ex}"); } catch (Exception loggerEx) { Console.WriteLine($"Error: Logger unavailable: {loggerEx}"); Console.WriteLine($"An unhandled exception occurred: {ex}"); } Environment.Exit(1); } finally { Logger.Close(); } }
/// <summary> /// Main entry point into the SQL Tools API Service Layer /// </summary> internal static void Main(string[] args) { try { // read command-line arguments ServiceLayerCommandOptions commandOptions = new ServiceLayerCommandOptions(args); if (commandOptions.ShouldExit) { return; } string logFilePath = commandOptions.LogFilePath; if (string.IsNullOrWhiteSpace(logFilePath)) { logFilePath = "sqltools"; } if (!string.IsNullOrWhiteSpace(commandOptions.LoggingDirectory)) { logFilePath = Path.Combine(commandOptions.LoggingDirectory, logFilePath); } // turn on Verbose logging during early development // we need to switch to Information when preparing for public preview Logger.Initialize(tracingLevel: commandOptions.TracingLevel, logFilePath: logFilePath, traceSource: "sqltools"); Logger.Write(TraceEventType.Information, "Starting SQL Tools Service Layer"); // set up the host details and profile paths var hostDetails = new HostDetails(version: new Version(1, 0)); SqlToolsContext sqlToolsContext = new SqlToolsContext(hostDetails); ServiceHost serviceHost = HostLoader.CreateAndStartServiceHost(sqlToolsContext); serviceHost.WaitForExit(); } catch (Exception e) { Logger.WriteWithCallstack(TraceEventType.Critical, $"An unhandled exception occurred: {e}"); Environment.Exit(1); } finally { Logger.Close(); } }
/// <summary> /// Main entry point into the SQL Tools API Service Host /// </summary> internal static void Main(string[] args) { // read command-line arguments CommandOptions commandOptions = new CommandOptions(args); if (commandOptions.ShouldExit) { return; } // turn on Verbose logging during early development // we need to switch to Normal when preparing for public preview Logger.Initialize(minimumLogLevel: LogLevel.Verbose, isEnabled: commandOptions.EnableLogging); Logger.Write(LogLevel.Normal, "Starting SQL Tools Service Host"); // set up the host details and profile paths var hostDetails = new HostDetails(version: new Version(1, 0)); SqlToolsContext sqlToolsContext = new SqlToolsContext(hostDetails); ServiceHost serviceHost = HostLoader.CreateAndStartServiceHost(sqlToolsContext); serviceHost.WaitForExit(); }
/// <summary> /// Main entry point into the SQL Tools API Service Host /// </summary> internal static void Main(string[] args) { try { // read command-line arguments CommandOptions commandOptions = new CommandOptions(args); if (commandOptions.ShouldExit) { return; } string logFilePath = "sqltools"; if (!string.IsNullOrWhiteSpace(commandOptions.LoggingDirectory)) { logFilePath = Path.Combine(commandOptions.LoggingDirectory, logFilePath); } // turn on Verbose logging during early development // we need to switch to Normal when preparing for public preview Logger.Initialize(logFilePath: logFilePath, minimumLogLevel: LogLevel.Verbose, isEnabled: commandOptions.EnableLogging); Logger.Write(LogLevel.Normal, "Starting CV SQL Tools Service Host"); // set up the host details and profile paths var hostDetails = new HostDetails(version: new Version(1, 0)); SqlToolsContext sqlToolsContext = new SqlToolsContext(hostDetails); ServiceHost serviceHost = HostLoader.CreateAndStartServiceHost(sqlToolsContext); ServiceHost.serviceClient = new ServiceClient(commandOptions.MSSqlToolsPath, commandOptions.MSSqlToolsArgs); serviceHost.WaitForExit(); } catch (Exception e) { Logger.Write(LogLevel.Error, string.Format("An unhandled exception occurred: {0}", e)); Environment.Exit(1); } }