|
|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
& l. D4 e) H6 g& U" w! {Teamcenter二次开发源码分享:判断对象是否存在在数据库中
3 r; Q# ^- I" @$ ]/ V2 m& o; Z0 I+ Q8 S3 a( V& m- G1 A, M
#include <TC/tc_startup.h>
; J$ u, z3 o0 Q#include <pom/pom/pom.h>; D& c+ i2 F4 ~
#include <ITK/mem.h>
5 G0 k3 e& D# w# s#include <tccore/workspaceobject.h> U5 {1 s/ u# @' R+ ~( B9 G8 A2 V
3 M- N9 F* G& G: Jlogical is_instance_in_database(char *variable_name, tag_t object): A9 [$ E1 K1 R* s
{
. O' K8 r" Z4 b( r* r" ]& `3 D logical exists_in_db = FALSE;
- [! g2 ^2 q* i: y if(object == NULLTAG) ECHO("\t %s: NULLTAG \n", variable_name);; D9 a! d) Y& ]# [' K
else) \! V) E9 [/ d7 G
{
9 I, v. \( m+ X7 p6 M- ? char *uid = NULL;" _0 d% H" q9 z7 q& y: _
ITK__convert_tag_to_uid(object, &uid);
& J' L9 N0 ~! L! N$ ` POM_instance_exists(object, &exists_in_db);
3 l6 [! f. I/ ]- v4 K4 J- S8 A! Y/ m if(exists_in_db == TRUE)
3 K- ~% N3 i/ E' y, Y) t/ k {6 r+ q6 r9 D6 f0 Q+ i
if(is_WorkspaceObject(object) ): ?! O% r0 L8 E
{
1 Z3 f# ]" }. S, g char *object_id = NULL;
3 x* n; ?. k P7 W T& w. ~ IFERR_REPORT(WSOM_ask_object_id_string(object, &object_id));
4 R" l% g- P9 a( K& G7 K char *object_type = NULL;4 p$ }1 P# t6 y
IFERR_REPORT(WSOM_ask_object_type2(object, &object_type));2 b9 q6 K3 B0 M$ E, u- y
ECHO("\t %s: %s - POM_instance_exists: true %s (%s)\n", $ j2 m7 M! e; r. Y2 @, J" B, k( s. K
variable_name, uid, object_id, object_type);9 g4 n6 E" z5 y% x) f% x9 S
if(object_id) MEM_free(object_id);
3 @. ]9 V0 J) n( Z) E- T4 D if(object_type) MEM_free(object_type); n6 l! D9 p$ [% _4 i" q) E
}1 _# c0 G+ U( _
else ECHO("\t %s: %s - POM_instance_exists: true\n",
- K7 H. V2 Y8 |3 s) J! h variable_name, uid);5 R; f$ V, x- e
}* H; ^1 O0 Z0 m5 v9 H
else ECHO("\t %s - POM_instance_exists: false \n", variable_name);
9 j P8 t9 M1 W2 X6 M if(uid) MEM_free(uid);0 ?. \9 Z9 m% U3 A# u C4 |# i; [! u
}- C0 j! w4 L& F1 U, ?' p4 t! W) c) S# _
return (exists_in_db);& V( ^! K3 b( q& q# X# e/ R
}6 Q2 x2 a9 F3 x
|
|