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

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

[复制链接]

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

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

admin 楼主

2014-1-15 19:30:29

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

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

x
! F* M' P  u9 N
Teamcenter ITK二次开发源码分享: 创建一个工作流
" _4 f( [. d1 Y& Q8 N2 C5 T) x! o1 j6 s. ?7 W8 ]
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    * z8 e: [& t! p3 }) ?
  2. #include <stdlib.h>
    6 q+ g' J4 f& n1 V' E" Z7 T
  3. #include <TCcore/aom.h>$ }$ Q4 G# d0 `9 e
  4. #include <tc/emh.h>: U+ h3 ?( u& x: X
  5. #include <epm/epm.h>9 t8 ^! g& D' ^0 S! k8 D
  6. #include <tc/tc.h>$ ?# _) Y1 B& r) _' l5 v
  7. #include <sa/tcfile.h>
    4 y/ K8 H( v$ A; W" \# _* ^
  8. #include <itk/mem.h>
    $ O- ]) I% Z1 C$ T" e/ W

  9. ) E5 f3 K5 ?* \" N
  10. #define EXIT_FAILURE 1 , F/ E* V( u/ t; ~% @0 t/ s! I7 `
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))
    ' |. I; S2 N7 o6 e' S) B
  12. static void report_error( char *file, int line, char *function, int return_code)
    ) D' @1 F8 ]$ P& U3 |9 U6 v" d
  13. {$ _. g8 {4 i. o" _# L
  14.     if (return_code != ITK_ok)6 B* m0 i3 g7 y5 L4 E; {
  15.     {7 `6 j4 T# P2 @+ k! @( v
  16.         char *error_message_string;! S8 g+ t/ Q) G, I8 x  R
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);: U4 s3 P8 o3 v+ k
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);( R% _, l  R, E3 I6 W, c* d! Z8 g8 S
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);  R% A+ V0 T: D5 ~+ a. f- V: i
  20.         if(error_message_string) MEM_free(error_message_string);( i4 B& ^1 N1 f$ o; s( U
  21.         printf("\nExiting program!\n");
    " ^) u( w8 d3 u! s. j
  22.         exit (EXIT_FAILURE);   
      S  z; `" Z) {  _; v
  23.     }  c5 C) i. E7 t6 T
  24. }4 F& P) n- a0 Z! D1 P

  25. 3 {) v; _- i+ N* C3 x
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))
    ( n* Y( m9 @8 F1 H8 T' M5 X
  27. static void check_value( char *function, int value )$ K4 o+ [, d" _& e6 I- A
  28. {) {; e: ?6 y! o
  29.     if (value == 0)5 A+ D- ]# I( z1 i2 H2 z2 l( n7 e
  30.     {
    9 s* N* f- t! ~+ M3 o* z3 F
  31.         printf ("\t%s is NULL\n", function);
    # b- z5 Y/ c9 P
  32.         printf("\nExiting program!\n");( y8 q; g9 u3 Q% O2 R
  33.         exit (EXIT_FAILURE);    $ L) h' a& @8 n% c3 ?
  34.     }9 o9 S2 S+ F7 U- }, @  A8 @+ H8 }
  35. }
    $ W3 E. ]( n% i& o+ k+ U2 ~

  36. - q7 ~* l, a  ?3 |0 Z9 {
  37. 8 a0 r8 W2 A6 _
  38. static void do_it(void)
    & P9 Y" y6 h  U# M
  39. {( a  d! g5 v% C  Q6 u, X# ]9 Y
  40.     int
    , I& D. H, ?# ~. s. X
  41.         attach_types[1] = {1};2 D( \  _" L( E$ v$ e/ W" e; G$ w
  42.     tag_t
    ; P8 C% s6 q* k2 o8 d: \+ L
  43.         rev = NULLTAG, 0 e+ e* s9 U3 l" B& V6 z
  44.         process_template = NULLTAG, ) q$ T1 J) d% z& D5 j
  45.         process = NULLTAG;
    ' \: e  P6 m3 R) U: C) F) r3 B
  46. # @9 ^  l2 Z" k8 k. C# H4 L
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );
    ) D# p$ @9 J7 Z
  48.     EXIT_IF_NULL( rev );, f: L# v/ d2 E# A$ W6 R2 t7 M
  49. 7 h* A% y' F2 i% s! ], @$ O
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    # x( T: H+ G2 {! ^7 A, @2 v
  51.     EXIT_IF_NULL( process_template );
    2 h& _# h4 E- N$ |# Y! S0 A5 `+ X

  52. / o# M4 b' i  y; T
  53. , x% z, Q; _+ s
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev, : o2 \8 p( |3 U- r8 K: j" Z. G
  55.         attach_types, &process) );3 Q9 C) B/ b5 G& B1 G, z3 R* P

  56. 0 t+ {! J+ ]' _2 T
  57.     EXIT_IF_NULL( process );
    2 W/ H5 |- H3 T9 v) M' W* ]: z0 a
  58. }
    4 w; L9 y% z6 n2 K' m

  59. + M/ u* \/ f! V
  60. int ITK_user_main(int argc, char* argv[])5 x: k. C  D" Q8 v- o. N: ]
  61. {
    4 ]8 X* ~. Z. V* K2 L/ u1 n  g- a& J
  62.     int
    5 H% u; Y  M& O- O7 t3 [
  63.         status = 0;
    + Y' i- z. w- n+ U9 o% u! K+ j* @: r
  64.    
    6 G! z/ {8 ]- [  q# }
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );0 n5 ]. W# A9 y. r# Z! F% ?
  66.     status = ITK_auto_login();
    9 R% {6 h. E" h; G# ]  Z, G( ]' E
  67.    $ S5 P/ L7 l% B" N3 w8 x# P. c( i
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");
    & ]- g0 I9 u6 R. f! ]3 G! [* k
  69.     else
    7 e5 K# S) P5 A! |+ k8 V) `4 g( b" f/ `
  70.     {
    $ q+ y# ^( \, v& _
  71.         printf("\nLogin successful!\n\n");
    2 ^  D$ N, Z$ M* f2 ]9 X: ?0 @0 m
  72.         ITK_set_journalling(TRUE);% T2 K- H; \( R2 [8 q
  73.         do_it();, u' X7 `1 q) \! K' Y* p0 s% l3 K! c  L
  74.     }
    ; k$ R8 l8 h1 e+ Q, O
  75.     ITK_exit_module(TRUE);
    : _( A3 x7 [. e; }2 j
  76.     return status;) U4 {& p4 _0 ]
  77. }
复制代码

% U: X& c) H- l8 P! ?/ x
/ ]' A2 }, B$ s, {: j
$ g$ s9 D$ B- M0 }/ S; @4 ?. `
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了