#define _CRT_SECURE_NO_WARNINGS #include "epm_handler_common.h" int ML_ChangeStatus(EPM_action_message_t msg) { printf("=========================更改生命周期状态 Start===================\n"); auto startTime = std::chrono::high_resolution_clock::now(); int ifail = ITK_ok; int attachments_num = 0; tag_t rootTask = NULLTAG, *attachments = NULLTAG; //获取任务对象 EPM_ask_root_task(msg.task, &rootTask); //获取任务目标对象 EPM_ask_attachments(rootTask, EPM_target_attachment, &attachments_num, &attachments); char *argflag = NULL, *argvalue = NULL, *arg = NULL; char arg1value[1024] = "", arg2value[1024] = "", arg3value[1024] = "", arg4value[1024] = ""; //获取参数 int arg_cnt = TC_number_of_arguments(msg.arguments); printf("参数个数为:%d\n", arg_cnt); if (arg_cnt > 0) { for (int i = 0; i referencedItemTypes; if (strstr(arg4value, ",") != NULL) { int vectorValueCount = 0; char ** vectorValueChar = new char *[64]; split(arg4value, ",", vectorValueChar, &vectorValueCount); for (int i = 0; i < vectorValueCount; i++) { referencedItemTypes.push_back(vectorValueChar[i]); } } else { referencedItemTypes.push_back(arg4value); } POM_AM__set_application_bypass(true); for (int i = 0; i < attachments_num; i++) { char *itemType = NULL; AOM_ask_value_string(attachments[i], "object_type", &itemType); printf("type_class : %s \r\n", itemType); //过滤掉非版本的对象 if ((strcmp(itemType, arg3value) != NULL)) { DOFREE(itemType); continue; } int num = 0; tag_t * value = NULLTAG; AOM_ask_value_tags(attachments[i], arg1value, &num, &value); tag_t template_tag = NULLTAG; EPM_find_template2(arg2value, PROCESS_TEMPLATE, &template_tag); int size = 0; tag_t new_process = NULLTAG; int *tagType = (int *)MEM_alloc(1024 * sizeof(int));//EPM_reference_attachment tag_t * itemTag = (tag_t *)MEM_alloc(1024 * sizeof(tag_t)); for (int j = 0; j < num; j++) { char *objectType = NULL; AOM_ask_value_string(value[j], "object_type", &objectType); //过滤掉非版本的对象 if (!count(referencedItemTypes, objectType) && strcmp(arg4value, "") != 0) { DOFREE(objectType); continue; } tagType[size] = EPM_target_attachment; itemTag[size] = value[j]; size = size + 1; DOFREE(objectType); } printf("发起流程 Start===================\n"); EPM_create_process("更改生命周期状态", "", template_tag, size, itemTag, tagType, &new_process); printf("发起流程 End===================\n"); for (int j = 0; j < size; j++) { AOM_lock(itemTag[j]); AOM_save(itemTag[j]); AOM_unlock(itemTag[j]); AOM_refresh(itemTag[j], false); } printf("刷新对象 End===================\n"); DOFREE(value); DOFREE(itemType); printf("释放内存 End===================\n"); } POM_AM__set_application_bypass(false); DOFREE(attachments); auto stopTime = std::chrono::high_resolution_clock::now(); auto duration = std::chrono::duration_cast(stopTime - startTime); //std::cout << "ML_ChangeStatus用时:" << duration.count() / 1000 << std::endl; string usetime = "ML_ChangeStatus用时:"; usetime.append(std::to_string(duration.count() / 1000)); WriteLog(true, usetime.c_str()); printf("=========================更改生命周期状态 End===================\n"); return ifail; }