PLM之家PLMHome-国产软件践行者

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

[复制链接]

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

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

admin 楼主

2014-1-15 19:30:29

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

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

x
2 S- v6 b" `. F4 F1 Q
Teamcenter ITK二次开发源码分享: 创建一个工作流, n" m4 z. {3 o

# f0 R# z+ n- {/ {
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    ' D3 L! y5 n3 w- H" }
  2. #include <stdlib.h>
    8 V6 z3 I7 Y* y0 u5 _! }! b
  3. #include <TCcore/aom.h>
    ) V5 B/ ^; |7 n+ g+ q: N
  4. #include <tc/emh.h># C, I: @2 L& z% l5 p, Y2 h
  5. #include <epm/epm.h>$ O  C& B9 Y3 G/ Z5 U( u! _
  6. #include <tc/tc.h>1 z/ S% p" O0 P. D( U1 O
  7. #include <sa/tcfile.h>9 E+ e2 Q; {! n+ M" h4 W
  8. #include <itk/mem.h>5 Y( c( G. e9 v5 c/ p0 b' F
  9. ! y$ d: J4 [2 j4 M+ }8 ]* H
  10. #define EXIT_FAILURE 1 . z7 p+ s9 `' S, d+ ?) w
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))9 Y$ ?- @$ ~$ }2 h* S; u$ ]9 Z
  12. static void report_error( char *file, int line, char *function, int return_code). b, K& H% m+ R9 [4 z8 Q
  13. {
    3 ], H5 N/ a3 G5 k6 _. x. c, u- f* h8 o
  14.     if (return_code != ITK_ok)
    " A0 r0 w: E3 p( t7 T
  15.     {. {  O& I$ ~6 V! f7 i/ X
  16.         char *error_message_string;( |2 S) b: w) Z
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);# }; f" n; W" J" {- m$ s
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    + t- b  u8 U* Z8 S5 D3 e
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);
    : n1 J: O/ n* F8 s* P+ Y
  20.         if(error_message_string) MEM_free(error_message_string);
    # j! D% |& E0 [. r" B  a: J
  21.         printf("\nExiting program!\n");. B4 R  _8 ]7 e+ B# A
  22.         exit (EXIT_FAILURE);   
    # r9 u" Z7 B+ B7 Y- R
  23.     }
    ; _5 c# q2 _9 M2 }: ~
  24. }. T; X5 h5 _- h# l' m4 s/ ^! H
  25. 0 {; K8 p4 O" s$ m; H
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X))). p# M# D$ b0 x3 s2 V. o
  27. static void check_value( char *function, int value )0 U$ ~8 V$ _, o3 a) x0 o$ b$ I
  28. {; Q; I/ W! x' }2 g3 J% c9 W
  29.     if (value == 0)
    9 n$ ^* r* g  g* d: t
  30.     {8 [! w: Q5 `9 s+ s8 R# E( x+ _, |8 |4 ^
  31.         printf ("\t%s is NULL\n", function);! h' ?, l% k" g! e, `  ^
  32.         printf("\nExiting program!\n");0 }7 s( V' c+ J, `
  33.         exit (EXIT_FAILURE);   
    8 u0 z1 A, O4 m  R
  34.     }  A; A% q) f1 \# M: b6 _
  35. }
    ( v+ f; y; S' `. p, K9 x, B( V

  36. . u3 T' o0 ?; g" G7 G* q) [
  37. : s0 D8 m7 E3 F! c( l& I
  38. static void do_it(void)
    * g* u; w4 H/ O5 ?& S+ i, \, c
  39. {
    0 [# I( J* H( r6 ^& C+ _- U5 \* E
  40.     int 4 ^* e6 p+ i, t& x& S! C
  41.         attach_types[1] = {1};
    , [7 m2 ]+ ~2 Z# k( z
  42.     tag_t 7 H, ?8 l' k- i6 U" Q
  43.         rev = NULLTAG, ) z6 r7 U5 b1 a
  44.         process_template = NULLTAG, 0 E2 Z( u3 V% D
  45.         process = NULLTAG;0 h% T* K6 q& F7 _
  46. . F1 n( W0 ], {) `/ d
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );2 x( ~6 F) Q9 u( W9 v+ ^
  48.     EXIT_IF_NULL( rev );, A( n* J$ q$ v0 W4 A/ Q
  49. & H  y/ M3 K$ m6 Y% [$ d2 U; c* \
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) ); . k; w3 @4 |0 F% P% ~' z# K1 h2 k
  51.     EXIT_IF_NULL( process_template );( n1 V2 r7 ^4 S* [$ F, o/ f
  52. 6 U, T- M. H! R. o2 q
  53. , X; `' `6 `. Y  y: ~
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
      ?# a) S$ f5 E5 m
  55.         attach_types, &process) );
    9 U  C( H7 z2 z
  56. . [; i8 K3 l  D
  57.     EXIT_IF_NULL( process );* T- m" O! J2 X, r% a; h+ d
  58. }/ D2 K+ Y6 t& w+ B

  59. , ]5 O+ I- `+ o+ d. `' m# A5 l
  60. int ITK_user_main(int argc, char* argv[]); A7 S0 h  h2 f) o5 Y) R
  61. {2 t) @9 B2 M( `# L; C$ g
  62.     int/ s9 g2 }3 V, U  W; g! h
  63.         status = 0;
    6 F! m; ^% M8 a7 G! {$ b
  64.    9 ]. D* R, m% l3 D
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    ! @9 F6 ]6 Q& A0 j
  66.     status = ITK_auto_login();
    , G( _5 p. G- f8 E% {6 o) D- K
  67.    
    ! V* F8 ^+ T, e8 h. `$ H
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");
    9 r5 t/ j) U3 S2 p
  69.     else* }' d# Z6 L* ^. Q- s  k0 W
  70.     {6 i8 h" N" R* u/ J& q
  71.         printf("\nLogin successful!\n\n");( g" v* |5 A0 x
  72.         ITK_set_journalling(TRUE);; U  o2 r- Q/ @& z
  73.         do_it();2 g9 l' i! f% x! ^1 _
  74.     }* Z9 @" u; Q: J1 _+ B- }
  75.     ITK_exit_module(TRUE);
    % n& C3 e  t" z1 C
  76.     return status;- z. a3 V: f( Q8 `3 g* }/ Q: K  ?0 w  `
  77. }
复制代码
; [: v) V" F  N2 a
; b& A8 B* t. O# Y, s  q: ?' Q6 N5 E
4 b3 S7 _  e; Z' V! W3 ?1 f% R$ m
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了