/// <summary> /// Executes the geoprocessing function using the given array of parameter values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="trackCancel">The track cancel.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="messages">The messages that are reported to the user.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void Execute(Dictionary <string, IGPValue> parameters, ITrackCancel trackCancel, IGPEnvironmentManager environmentManager, IGPMessages messages, IGPUtilities2 utilities) { IGPValue field = parameters["in_field"]; IObjectClass table = utilities.OpenTable(parameters["in_table"]); IGPMultiValue modelNames = (IGPMultiValue)parameters["in_field_model_names"]; if (!field.IsEmpty() && modelNames.Count > 0) { var fieldName = field.GetAsText(); int index = table.FindField(fieldName); foreach (var modelName in modelNames.AsEnumerable().Select(o => o.GetAsText())) { messages.Add(esriGPMessageType.esriGPMessageTypeInformative, "Removing the {0} field model name from the {1} field.", modelName, fieldName); ModelNameManager.Instance.RemoveFieldModelName(table, table.Fields.Field[index], modelName); } // Success. parameters["out_results"].SetAsText("true"); } else { // Failure. parameters["out_results"].SetAsText("false"); } }
/// <summary> /// Executes the geoprocessing function using the given array of parameter values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="trackCancel">The track cancel.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="messages">The messages that are reported to the user.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void Execute(Dictionary <string, IGPValue> parameters, ITrackCancel trackCancel, IGPEnvironmentManager environmentManager, IGPMessages messages, IGPUtilities2 utilities) { IGPMultiValue tables = (IGPMultiValue)parameters["in_tables"]; IGPMultiValue modelNames = (IGPMultiValue)parameters["in_class_model_names"]; int addedCount = 0; if (tables.Count > 0 && modelNames.Count > 0) { foreach (var table in tables.AsEnumerable()) { IObjectClass dataElement = utilities.OpenTable(table); foreach (var modelName in modelNames.AsEnumerable().Select(o => o.GetAsText())) { messages.Add(esriGPMessageType.esriGPMessageTypeInformative, "Adding the {0} class model name to the {1} table.", modelName, dataElement.AliasName); ModelNameManager.Instance.AddClassModelName(dataElement, modelName); addedCount++; } } } if (addedCount == tables.Count) { // Success parameters["out_results"].SetAsText("true"); } else { // Failure. parameters["out_results"].SetAsText("false"); } }
/// <summary> /// Executes the geoprocessing function using the given array of parameter values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="trackCancel">The track cancel.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="messages">The messages that are reported to the user.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void Execute(Dictionary <string, IGPValue> parameters, ITrackCancel trackCancel, IGPEnvironmentManager environmentManager, IGPMessages messages, IGPUtilities2 utilities) { IGPValue value = parameters["in_table"]; IObjectClass table = utilities.OpenTable(value); if (table != null) { IMMConfigTopLevel configTopLevel = ConfigTopLevel.Instance; configTopLevel.Workspace = utilities.GetWorkspace(value); // Load all of the subtypes when the user specified "All" or "-1". int subtype = parameters["in_subtype"].Cast(-1); var subtypeCodes = new List <int>(new[] { subtype }); if (subtype == -1) { ISubtypes subtypes = (ISubtypes)table; subtypeCodes.AddRange(subtypes.Subtypes.AsEnumerable().Select(o => o.Key)); } IGPMultiValue onCreate = (IGPMultiValue)parameters["in_create"]; IGPMultiValue onUpdate = (IGPMultiValue)parameters["in_update"]; IGPMultiValue onDelete = (IGPMultiValue)parameters["in_delete"]; // Load the "Attribute" AUs. var uids = new Dictionary <mmEditEvent, IEnumerable <IUID> >(); uids.Add(mmEditEvent.mmEventFeatureCreate, onCreate.AsEnumerable().Cast <IGPAutoValue>().Select(o => o.UID)); uids.Add(mmEditEvent.mmEventFeatureUpdate, onUpdate.AsEnumerable().Cast <IGPAutoValue>().Select(o => o.UID)); uids.Add(mmEditEvent.mmEventFeatureDelete, onDelete.AsEnumerable().Cast <IGPAutoValue>().Select(o => o.UID)); IGPValue field = parameters["in_field"]; int index = table.FindField(field.GetAsText()); // Enumerate through all of the subtypes making changes. foreach (var subtypeCode in subtypeCodes) { // Load the configurations for the table and subtype. IMMSubtype mmsubtype = configTopLevel.GetSubtypeByID(table, subtypeCode, false); // Load the field configurations. IMMField mmfield = null; mmsubtype.GetField(index, ref mmfield); // Update the list to have these UIDs removed. ID8List list = (ID8List)mmfield; base.Remove(uids, list, messages); } // Commit the changes to the database. configTopLevel.SaveFeatureClassToDB(table); // Success. parameters["out_results"].SetAsText("true"); } else { // Failure. parameters["out_results"].SetAsText("false"); } }
/// <summary> /// Pre validates the given set of values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void UpdateParameters(Dictionary <string, IGPParameter> parameters, IGPEnvironmentManager environmentManager, IGPUtilities2 utilities) { IGPValue value = utilities.UnpackGPValue(parameters["in_table"]); if (!value.IsEmpty()) { IObjectClass table = utilities.OpenTable(value); if (table != null) { // Populate the subtype parameter with the subtypes from the table and ensure the it's editable. IGPParameterEdit3 subtypeParameter = (IGPParameterEdit3)parameters["in_subtype"]; subtypeParameter.Domain = this.GetSubtypes(table); // Populate the auto updater values for the object class for the specific subtype. IGPValue subtype = utilities.UnpackGPValue(subtypeParameter); if (!subtype.IsEmpty()) { var subtypeCode = subtype.Cast(-1); IMMConfigTopLevel configTopLevel = ConfigTopLevel.Instance; configTopLevel.Workspace = utilities.GetWorkspace(value); var values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventFeatureCreate); IGPParameterEdit3 parameter = (IGPParameterEdit3)parameters["in_create"]; parameter.Domain = base.CreateDomain <IMMSpecialAUStrategyEx>(values[subtypeCode]); values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventFeatureUpdate); parameter = (IGPParameterEdit3)parameters["in_update"]; parameter.Domain = base.CreateDomain <IMMSpecialAUStrategyEx>(values[subtypeCode]); values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventFeatureDelete); parameter = (IGPParameterEdit3)parameters["in_delete"]; parameter.Domain = base.CreateDomain <IMMSpecialAUStrategyEx>(values[subtypeCode]); values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventBeforeFeatureSplit); parameter = (IGPParameterEdit3)parameters["in_before"]; parameter.Domain = base.CreateDomain <IMMSpecialAUStrategyEx>(values[subtypeCode]); values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventFeatureSplit); parameter = (IGPParameterEdit3)parameters["in_split"]; parameter.Domain = base.CreateDomain <IMMSpecialAUStrategyEx>(values[subtypeCode]); values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventAfterFeatureSplit); parameter = (IGPParameterEdit3)parameters["in_after"]; parameter.Domain = base.CreateDomain <IMMSpecialAUStrategyEx>(values[subtypeCode]); } } } }
/// <summary> /// Pre validates the given set of values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void UpdateParameters(Dictionary <string, IGPParameter> parameters, IGPEnvironmentManager environmentManager, IGPUtilities2 utilities) { IGPValue value = utilities.UnpackGPValue(parameters["in_table"]); if (!value.IsEmpty()) { IObjectClass table = utilities.OpenTable(value); if (table != null) { IGPParameterEdit3 parameter = (IGPParameterEdit3)parameters["in_field"]; parameter.Domain = base.GetFields(table); parameter = (IGPParameterEdit3)parameters["in_subtype"]; parameter.Domain = base.GetSubtypes(table); } } }
/// <summary> /// Pre validates the given set of values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void UpdateParameters(Dictionary <string, IGPParameter> parameters, IGPEnvironmentManager environmentManager, IGPUtilities2 utilities) { IGPValue value = utilities.UnpackGPValue(parameters["in_table"]); if (!value.IsEmpty()) { IObjectClass table = utilities.OpenTable(value); if (table != null) { IGPParameterEdit3 parameter = (IGPParameterEdit3)parameters["in_field"]; parameter.Domain = base.GetFields(table); string fieldName = utilities.UnpackGPValue(parameter).GetAsText(); parameter = (IGPParameterEdit3)parameters["in_subtype"]; parameter.Domain = base.GetSubtypes(table); IGPValue subtype = utilities.UnpackGPValue(parameter); if (!subtype.IsEmpty()) { if (!string.IsNullOrEmpty(fieldName)) { var subtypeCode = subtype.Cast(-1); IMMConfigTopLevel configTopLevel = ConfigTopLevel.Instance; configTopLevel.Workspace = utilities.GetWorkspace(value); var values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventFeatureCreate, fieldName); parameter = (IGPParameterEdit3)parameters["in_create"]; parameter.Domain = base.CreateDomain <IMMAttrAUStrategy>(values[subtypeCode][fieldName]); values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventFeatureUpdate, fieldName); parameter = (IGPParameterEdit3)parameters["in_update"]; parameter.Domain = base.CreateDomain <IMMAttrAUStrategy>(values[subtypeCode][fieldName]); values = configTopLevel.GetAutoValues(table, mmEditEvent.mmEventFeatureDelete, fieldName); parameter = (IGPParameterEdit3)parameters["in_delete"]; parameter.Domain = base.CreateDomain <IMMAttrAUStrategy>(values[subtypeCode][fieldName]); } } } } }
/// <summary> /// Pre validates the given set of values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void UpdateParameters(Dictionary <string, IGPParameter> parameters, IGPEnvironmentManager environmentManager, IGPUtilities2 utilities) { // Retrieve the input parameter value. IGPValue table = utilities.UnpackGPValue(parameters["in_table"]); if (!table.IsEmpty()) { // Create the domain based on the fields on the table. IObjectClass oclass = utilities.OpenTable(table); if (oclass != null) { IFields fields = oclass.Fields; if (fields != null) { IGPCodedValueDomain codedValueDomain = new GPCodedValueDomainClass(); foreach (var o in fields.AsEnumerable()) { codedValueDomain.AddStringCode(o.Name, o.Name); } IGPParameterEdit3 derivedFields = (IGPParameterEdit3)parameters["in_field"]; derivedFields.Domain = (IGPDomain)codedValueDomain; } IGPValue field = utilities.UnpackGPValue(parameters["in_field"]); if (!field.IsEmpty()) { int index = oclass.FindField(field.GetAsText()); IGPCodedValueDomain codedValueDomain = new GPCodedValueDomainClass(); foreach (var o in oclass.GetFieldModelNames(oclass.Fields.Field[index])) { codedValueDomain.AddStringCode(o, o); } IGPParameterEdit3 derivedParameter = (IGPParameterEdit3)parameters["in_field_model_names"]; derivedParameter.Domain = (IGPDomain)codedValueDomain; } } } }
/// <summary> /// Pre validates the given set of values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void UpdateParameters(Dictionary <string, IGPParameter> parameters, IGPEnvironmentManager environmentManager, IGPUtilities2 utilities) { IGPValue value = utilities.UnpackGPValue(parameters["in_table"]); if (!value.IsEmpty()) { IObjectClass table = utilities.OpenTable(value); if (table != null) { IGPParameterEdit3 subtypeParameter = (IGPParameterEdit3)parameters["in_subtype"]; subtypeParameter.Domain = this.GetSubtypes(table); var components = this.LoadComponents <IMMSpecialAUStrategyEx>(SpecialAutoUpdateStrategy.CatID); IGPParameterEdit3 prameter = (IGPParameterEdit3)parameters["in_create"]; prameter.Domain = base.CreateDomain(components, o => o.Enabled[table, mmEditEvent.mmEventFeatureCreate]); // Load the "OnUpdate" components for table. prameter = (IGPParameterEdit3)parameters["in_update"]; prameter.Domain = base.CreateDomain(components, o => o.Enabled[table, mmEditEvent.mmEventFeatureUpdate]); // Load the "OnDelete" components for table. prameter = (IGPParameterEdit3)parameters["in_delete"]; prameter.Domain = base.CreateDomain(components, o => o.Enabled[table, mmEditEvent.mmEventFeatureDelete]); // Load the "OnBeforeSplit" components for table. prameter = (IGPParameterEdit3)parameters["in_before"]; prameter.Domain = base.CreateDomain(components, o => o.Enabled[table, mmEditEvent.mmEventBeforeFeatureSplit]); // Load the "OnSplit" components for table. prameter = (IGPParameterEdit3)parameters["in_split"]; prameter.Domain = base.CreateDomain(components, o => o.Enabled[table, mmEditEvent.mmEventFeatureSplit]); // Load the "OnAfterSplit" components for table. prameter = (IGPParameterEdit3)parameters["in_after"]; prameter.Domain = base.CreateDomain(components, o => o.Enabled[table, mmEditEvent.mmEventAfterFeatureSplit]); } } }
/// <summary> /// Executes the geoprocessing function using the given array of parameter values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="trackCancel">The track cancel.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="messages">The messages that are reported to the user.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void Execute(Dictionary <string, IGPValue> parameters, ITrackCancel trackCancel, IGPEnvironmentManager environmentManager, IGPMessages messages, IGPUtilities2 utilities) { IObjectClass table = utilities.OpenTable(parameters["in_table"]); IGPMultiValue modelNames = (IGPMultiValue)parameters["in_class_model_names"]; if (modelNames.Count > 0) { foreach (var modelName in modelNames.AsEnumerable().Select(o => o.GetAsText())) { messages.Add(esriGPMessageType.esriGPMessageTypeInformative, "Removing the {0} class model name.", modelName); ModelNameManager.Instance.RemoveClassModelName(table, modelName); } // Success. parameters["out_results"].SetAsText("true"); } else { // Failure. parameters["out_results"].SetAsText("false"); } }
/// <summary> /// Pre validates the given set of values. /// </summary> /// <param name="parameters">The parameters.</param> /// <param name="environmentManager">Provides access to all the current environments and settings of the current client.</param> /// <param name="utilities"> /// The utilities object that provides access to the properties and methods of a geoprocessing /// objects. /// </param> protected override void UpdateParameters(Dictionary <string, IGPParameter> parameters, IGPEnvironmentManager environmentManager, IGPUtilities2 utilities) { // Retrieve the input parameter value. IGPValue value = utilities.UnpackGPValue(parameters["in_table"]); if (!value.IsEmpty()) { // Create the domain based on the fields on the table. IObjectClass table = utilities.OpenTable(value); if (table != null) { IGPCodedValueDomain codedValueDomain = new GPCodedValueDomainClass(); foreach (var modelName in table.GetClassModelNames()) { codedValueDomain.AddStringCode(modelName, modelName); } IGPParameterEdit3 derivedFields = (IGPParameterEdit3)parameters["in_class_model_names"]; derivedFields.Domain = (IGPDomain)codedValueDomain; } } }