Adding decoding of multipart identifiers, default schema workaround (#295)

This change adds a couple things

_Multipart Identifier Decoding_
The ability to decode a multipart identifier (with or without escaping) has been added to the SqlScriptFormatter utility class. This code is utilized to split a table name provided to the edit/initialize request into schema and table name.

_Default Schema Workaround_
The code that retrieves the SMO metadata objects originally used the `[]` operator to access the objects. Due to a bug(?) in SMO, this results in problems when loading tables without a default schema (in our case if you're logged in as SA). Using the metadata object constructors gets around this issue, we are explicitly using them.

* Adding decoding of multipart identifiers
Adding code fix for default schema issue

* Adding some more localizable strings for errors when loading metadata

* Adding localization files... again?

* Changes as per pull request comments
This commit is contained in:
Benjamin Russell
2017-03-27 17:14:21 -07:00
committed by GitHub
parent 1909310a92
commit f7036f3f73
11 changed files with 235 additions and 17 deletions

View File

@@ -429,6 +429,22 @@ namespace Microsoft.SqlTools.ServiceLayer
}
}
public static string EditDataMetadataObjectNameRequired
{
get
{
return Keys.GetString(Keys.EditDataMetadataObjectNameRequired);
}
}
public static string EditDataMetadataTooManyIdentifiers
{
get
{
return Keys.GetString(Keys.EditDataMetadataTooManyIdentifiers);
}
}
public static string EditDataFilteringNegativeLimit
{
get
@@ -861,6 +877,14 @@ namespace Microsoft.SqlTools.ServiceLayer
}
}
public static string SqlScriptFormatterMultipartDecodeFail
{
get
{
return Keys.GetString(Keys.SqlScriptFormatterMultipartDecodeFail);
}
}
public static string ConnectionServiceListDbErrorNotConnected(string uri)
{
return Keys.GetString(Keys.ConnectionServiceListDbErrorNotConnected, uri);
@@ -1128,6 +1152,12 @@ namespace Microsoft.SqlTools.ServiceLayer
public const string EditDataMetadataNotExtended = "EditDataMetadataNotExtended";
public const string EditDataMetadataObjectNameRequired = "EditDataMetadataObjectNameRequired";
public const string EditDataMetadataTooManyIdentifiers = "EditDataMetadataTooManyIdentifiers";
public const string EditDataFilteringNegativeLimit = "EditDataFilteringNegativeLimit";
@@ -1293,6 +1323,9 @@ namespace Microsoft.SqlTools.ServiceLayer
public const string SqlScriptFormatterDecimalMissingPrecision = "SqlScriptFormatterDecimalMissingPrecision";
public const string SqlScriptFormatterMultipartDecodeFail = "SqlScriptFormatterMultipartDecodeFail";
private Keys()
{ }