PLM之家PLMHome-工业软件践行者

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

[复制链接]

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

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

admin 楼主

2014-1-15 19:30:29

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

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

x

, q4 y* _1 I& Z$ R9 A; JTeamcenter ITK二次开发源码分享: 创建一个工作流
! P6 I; L9 N  x, ]7 L, q- q1 `
. q1 q! N- N; u3 O- Q
  1. /*HEAD CREATE_A_PROCESS CCC ITK */9 X5 D5 a  i3 U8 ^
  2. #include <stdlib.h>! O, k- A" d5 S' X, c% _
  3. #include <TCcore/aom.h>. U- L( t$ I8 Q5 U
  4. #include <tc/emh.h>
    . g. m& H* I! c: a* W
  5. #include <epm/epm.h>9 u3 Y0 {% s2 k0 |6 a8 I; B  l
  6. #include <tc/tc.h>
    $ @7 a/ M$ m' J2 z" P' o
  7. #include <sa/tcfile.h>
    9 h" n7 u. i- a( h( e
  8. #include <itk/mem.h>
    . C6 A5 n2 E/ J9 c3 C# }+ p: \

  9. / S" J8 v4 q. Q1 W' C! l
  10. #define EXIT_FAILURE 1 , ?1 G# q; I2 ?0 i! Y* I; P$ m
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))
    ( ?8 p7 t/ x% S7 G" n4 U5 J
  12. static void report_error( char *file, int line, char *function, int return_code); r8 v1 m- t3 G
  13. {9 f- s! O( T. p4 u9 _" u
  14.     if (return_code != ITK_ok)
    ! a# L9 g( R0 n" m. G2 a
  15.     {
    $ X7 p: T# A  _+ h; y8 U
  16.         char *error_message_string;  H8 K; R8 q7 ~7 _9 ~% {
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);
    9 m3 t5 \3 k+ ?5 ]
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    . ~3 `" p$ F* f$ @+ r. Q3 C
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);( T' B+ q# w4 h# K) f: E& J8 G* o
  20.         if(error_message_string) MEM_free(error_message_string);
    8 D5 U" ], W5 `0 p
  21.         printf("\nExiting program!\n");; |! m1 `! \# g2 u0 m
  22.         exit (EXIT_FAILURE);    0 M/ y7 Y4 G7 X4 _- |
  23.     }
    - m" E) o2 N/ Z8 U6 G: Z
  24. }( f8 R+ S* S$ H1 l: }

  25. . p( A' F* u: N& L3 O
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))
    ' n" [+ @; g/ k* S# q* l2 D5 d
  27. static void check_value( char *function, int value ): ~4 ]; f8 e0 y: I) v# E! d# O
  28. {
    : \( A4 N; @' e8 l' X( E
  29.     if (value == 0)
    3 s6 p) @* M4 x& T& K/ o
  30.     {  ?# ?1 W7 v# g; q; \8 e" `, q
  31.         printf ("\t%s is NULL\n", function);
    5 T( m( s! ~3 s: o
  32.         printf("\nExiting program!\n");
    % n# b! k( V3 R, W
  33.         exit (EXIT_FAILURE);    3 W, }% H) c/ n
  34.     }/ e& c6 E& f" o
  35. }
    & {, a* p/ v8 K/ J
  36. # B+ j1 W# N+ V4 Z

  37. 8 @$ E  A+ X  g
  38. static void do_it(void)5 a+ k4 d# J# N& y, S* \& h
  39. {) K7 T6 r9 z/ q' H8 v( l: G
  40.     int 3 X8 Q( `1 X0 ]1 s. B" {+ f4 Y; k. U
  41.         attach_types[1] = {1};7 ~( ^7 z7 i& X$ ~6 v
  42.     tag_t ' x4 J; B% r/ x* G$ `0 K+ @& n" k
  43.         rev = NULLTAG, 2 W5 y* N3 U# j1 h0 O$ k
  44.         process_template = NULLTAG, 0 v% D% m+ d9 B- n1 W# n
  45.         process = NULLTAG;
    4 C. v! V' D0 \1 V/ v% z

  46. 1 g& w- ?% a. j- \! `3 h* {' z
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );
    5 d# b; {7 i- h: j0 z" S  j5 C
  48.     EXIT_IF_NULL( rev );; d/ Y7 m* y; b# p  p
  49. : ]6 M5 y  O! q
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    ' m7 H) w- n5 D( B0 g  P& @
  51.     EXIT_IF_NULL( process_template );  K2 j( g- R, y! i6 |' M
  52. 1 t# M# O9 T/ ^
  53. ; L8 U. G) j' X: c" J3 y8 F: F
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev, , K2 H( _$ G! p' r
  55.         attach_types, &process) );
    - x  R1 l5 L1 g
  56. ; z/ I2 N. K; ?+ E5 D! x$ p
  57.     EXIT_IF_NULL( process );' c, T0 v2 Y/ T
  58. }
    " h! j1 N& v3 Q0 L' x

  59. 9 a7 z5 N. J$ @( w$ D
  60. int ITK_user_main(int argc, char* argv[])- Z" y: x$ u0 Y4 |+ j! b1 y! v
  61. {
    + m1 r9 ^7 ]: U5 ?3 J
  62.     int$ {# M. u3 n0 E4 z$ b; ]
  63.         status = 0; ( z5 [- `  m8 G9 I$ |
  64.    * k7 B4 D* z5 C% p0 D( E9 @1 r
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );0 J. s( t; {  ]& [" v5 `* R3 X
  66.     status = ITK_auto_login();! n* C( {" \# b) _, b# m( X
  67.    
    0 w* M5 n0 R6 K. _. [9 M, F
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");
    & k; r$ G) a: l# n3 m
  69.     else
    5 y3 j% I8 @. d' Y0 R
  70.     {
    / e9 R# S1 @. _9 s" [5 N3 f
  71.         printf("\nLogin successful!\n\n");" |& P7 D- M: L4 `* m2 s, ]
  72.         ITK_set_journalling(TRUE);
    6 [1 b/ g' ^. J' |4 ~% h3 G
  73.         do_it();
    , k" ~4 }+ P) |/ n
  74.     }/ u, f7 E" w! s3 b3 E3 m" {6 Z
  75.     ITK_exit_module(TRUE);2 i. G6 Y5 F  R' g3 i
  76.     return status;7 h; O5 F. h$ j9 o2 c+ a
  77. }
复制代码
  n3 H  W( v* ~8 s) m

2 F9 h4 ^7 S2 D
- K4 K2 n7 M% Q
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了