PLM之家PLMHome-工业软件与AI结合践行者

teamcenter ITK二次开发源码分享: 创建一个工作流

[复制链接]

2014-1-15 19:30:29 5094 0

admin 发表于 2014-1-15 19:30:29 |阅读模式

admin 楼主

2014-1-15 19:30:29

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x

, G3 ]. a/ _( q; ^# [% E( O! eTeamcenter ITK二次开发源码分享: 创建一个工作流
1 }( h1 }% k3 x
1 e* V( k- X, [% {/ [' \
  1. /*HEAD CREATE_A_PROCESS CCC ITK */, N5 q+ Z. n) ]: b$ Z
  2. #include <stdlib.h>" y8 v) j, S$ t7 U/ m( O" H3 [: h) O" J
  3. #include <TCcore/aom.h>9 h- }7 J; w3 D/ A# J0 ]. P6 a
  4. #include <tc/emh.h>+ N. R# |+ \- g/ ^. |- Q( m
  5. #include <epm/epm.h>
    2 Q- f9 |# S1 d5 S: [# O/ b9 ]
  6. #include <tc/tc.h>
    3 P$ l8 @6 m% k& l7 R
  7. #include <sa/tcfile.h>) i; f. I1 y; L
  8. #include <itk/mem.h>  k$ T1 R8 z* x! l2 r5 T2 Y- ]

  9. 1 A) Y; m4 v- E' c; k( a
  10. #define EXIT_FAILURE 1 $ l9 f' m0 A1 K+ j: }  _
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))& Q5 @  N& ^8 U3 q7 m! h* B3 N
  12. static void report_error( char *file, int line, char *function, int return_code), o% q3 M' W' |; v. c" V  v
  13. {2 v$ }* a4 C3 F
  14.     if (return_code != ITK_ok)
    . {) W$ V' c1 b; o9 ~
  15.     {/ F; _8 ?  S5 ]1 N6 k! ~
  16.         char *error_message_string;' M7 S3 A9 z$ `6 f5 q2 @$ n6 ^
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);9 A4 v' W, A5 l1 B) Y; c
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    ! g/ n" j/ t$ i* ~" V4 s3 t0 h
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);5 g3 h1 x( g4 C& R
  20.         if(error_message_string) MEM_free(error_message_string);
    $ c6 d! X3 k2 m9 K3 r
  21.         printf("\nExiting program!\n");+ T. }4 L1 Q- ~) p1 M: ^: [
  22.         exit (EXIT_FAILURE);   
    # T: L; g# I8 E( C. \. ?8 q5 `3 C
  23.     }
      K, N$ T' V, Z; p. H) j* |
  24. }
    / T. z# N& |  m- ?, [

  25. 3 k4 i4 j7 X, W5 A, z' p! n" w
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))' n* A* f. M/ e/ [
  27. static void check_value( char *function, int value )5 t) D# z) K4 y  G* f
  28. {1 I' H+ o, Z& B$ }
  29.     if (value == 0)
    * h" c" M4 a9 G# Z' S4 M
  30.     {! H9 B9 _1 G/ H$ F, M
  31.         printf ("\t%s is NULL\n", function);
    8 u6 i  m8 ~! v7 l
  32.         printf("\nExiting program!\n");
    " v8 e8 y: E3 d1 C1 T
  33.         exit (EXIT_FAILURE);   
    ; K5 {, a; x; t7 N. Q5 F. N& _" D
  34.     }2 K8 }7 O; |* F3 v! Q, G' y
  35. }
    . L: O8 K8 i/ f% W0 o! a

  36. * _: w; @" e2 Q& U' I6 j6 ], i& E
  37. 4 J3 I; k! m, U
  38. static void do_it(void)$ P- u) o* o! O% ?$ }% W
  39. {
    . O* V6 I2 I* ]  |3 m5 T6 }4 b- P0 P
  40.     int + t! o8 o1 k! a; `0 l: B/ J- w
  41.         attach_types[1] = {1};
    - X4 p: k3 `# H- z8 r* C
  42.     tag_t 5 t5 h; R, j* p' \
  43.         rev = NULLTAG, ! @( G% v$ H# |' K$ \
  44.         process_template = NULLTAG,
    2 v/ R5 @0 U4 Q1 z
  45.         process = NULLTAG;/ x; i- L' m. {$ E

  46. $ B" q2 C2 O: U2 [( G, J
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );+ L5 D& u- ?, m8 i+ F0 ?! w
  48.     EXIT_IF_NULL( rev );
    % \- F( J8 t/ }! ~' d
  49. 7 H6 M, i0 e6 t  Z6 W3 `
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) ); + v3 X1 ~/ g8 a6 G! W! D; m
  51.     EXIT_IF_NULL( process_template );
    : H; t$ p- i( h: I' y
  52. ! Q* ?, x: d* f
  53. 0 ]6 T& I: p3 P6 b* Y
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev, 4 @1 h  J0 e, x8 E" H6 d7 ]( n  l+ G
  55.         attach_types, &process) );* l" M+ Y8 l/ |& A% [& S$ d0 P4 B

  56. + a) W- K2 {8 L6 Q- h( H6 @: h
  57.     EXIT_IF_NULL( process );
    8 J: c- _1 N, n2 R7 U6 u% B- ]
  58. }
    $ w& Z) |( T$ U# I' G

  59. " V% K' a9 z' F* j4 v' p6 h
  60. int ITK_user_main(int argc, char* argv[])
    & m# w  t2 i5 t6 U- w
  61. {% H* N* {$ |! b' a( e3 ^9 S$ Y* F  o" i
  62.     int
    + B% G4 M- O: \. Y) ]' ^2 [8 y2 y& `
  63.         status = 0;
    ! T5 E5 m& X9 [6 @+ F
  64.    6 i9 ?- u% z* p4 Q& g/ ^' Q' r
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    1 y# R/ m3 g  \- x' O
  66.     status = ITK_auto_login();* ^! }5 k2 C' \( c1 a& {* j4 ^
  67.    
    ; X0 T$ M7 V9 v6 D
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");& F. ^3 N7 f% H4 W( w
  69.     else
    8 ~2 m) h* w2 q4 X' F3 W
  70.     {
    4 ?9 P, r/ i3 C% E/ b+ S
  71.         printf("\nLogin successful!\n\n");) Y  @* \* ~6 B3 I* q
  72.         ITK_set_journalling(TRUE);
    ' e( K+ o  C! e# I+ e+ k3 S& c7 o; ~
  73.         do_it();
    8 \- a" Q6 D# ]" l9 s
  74.     }
    * n3 d- N6 f" k: _" @
  75.     ITK_exit_module(TRUE);
    0 M9 C" G6 z7 d; ^& q, F
  76.     return status;
    & k- C# {0 m2 S. H5 o2 K
  77. }
复制代码
" Q% c; p& t* b, ]2 s9 `

3 }, T7 y2 r6 c8 x$ D5 H& L- h# C, U6 A7 R6 l; c
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了