|
|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
$ Q) E# K4 C8 a( ~Teamcenter二次开发源码分享:判断对象是否存在在数据库中 u/ x s- K; o U
( j8 M! E* e& B! K#include <TC/tc_startup.h>
3 z; l+ R I4 P# o# B1 _# r#include <pom/pom/pom.h>
% X) [! a! H+ u, D+ d. \* w/ f#include <ITK/mem.h>) p5 ?9 m6 E. k8 a, Y
#include <tccore/workspaceobject.h>2 h& S. _0 q( K9 O4 H$ Y
1 h3 A- x: o# B4 ~3 C9 llogical is_instance_in_database(char *variable_name, tag_t object)
: E3 R9 G6 P' B- i8 e{
" T, \4 a. \; f- j7 y, m logical exists_in_db = FALSE;/ n' Y, {9 N4 {! F; I5 d4 H
if(object == NULLTAG) ECHO("\t %s: NULLTAG \n", variable_name);
. v% F: N, r8 F else' N/ }2 p1 P! V5 `
{ V" n, j" i7 k9 t3 P- a
char *uid = NULL;
- g1 A! o4 D$ n6 }" T ITK__convert_tag_to_uid(object, &uid);
% @. S" X( I1 U7 S7 t& ~$ D POM_instance_exists(object, &exists_in_db);# a4 v, s6 {4 @$ J
if(exists_in_db == TRUE)0 d# L& l7 C; k: u) @
{2 _ ?3 J+ `+ m: F& q
if(is_WorkspaceObject(object) )
' z+ s/ W0 J; j" L. Q- R( ] {
; @4 [1 I' I6 v5 Q8 k2 p3 ^ char *object_id = NULL;" m: V3 Z, P% H, e6 i) R
IFERR_REPORT(WSOM_ask_object_id_string(object, &object_id));
4 _2 R1 j! `) d- h d4 u char *object_type = NULL;( l l& N3 |& p8 a$ r
IFERR_REPORT(WSOM_ask_object_type2(object, &object_type));
- A' U/ A; o' ]# L$ u) \7 V: h; i ECHO("\t %s: %s - POM_instance_exists: true %s (%s)\n", % `8 I7 N7 x; X! Y9 U" t1 d
variable_name, uid, object_id, object_type);
$ T" N& r8 s, U {$ p if(object_id) MEM_free(object_id);
! L& _ [- P5 |7 X. a: n$ k& a/ F; e, U if(object_type) MEM_free(object_type);% w; A: ?; M9 n! y0 X
}' }8 j6 `( h- R5 {5 x
else ECHO("\t %s: %s - POM_instance_exists: true\n",
) l( C) D+ }" R variable_name, uid);" e3 q$ E) Q/ k/ D; m+ Y* D
}
7 q$ J$ }2 d8 K7 u: K) B* a$ a else ECHO("\t %s - POM_instance_exists: false \n", variable_name);
$ X+ @1 B5 i$ e2 a7 U' G if(uid) MEM_free(uid);
6 f4 g( T! _. h- Y* U% q }% O/ A% T' p1 t1 G
return (exists_in_db);. T, f& t0 |$ P
}8 T" A* {3 M6 S* X/ x. g
|
|