![]() |
|
|||
0001 /** 0002 * @brief Tuxedo to Enduro/X migration tools - server 0003 * 0004 * @file atmisv90.c 0005 */ 0006 /* ----------------------------------------------------------------------------- 0007 * Enduro/X Middleware Platform for Distributed Transaction Processing 0008 * Copyright (C) 2009-2016, ATR Baltic, Ltd. All Rights Reserved. 0009 * Copyright (C) 2017-2023, Mavimax, Ltd. All Rights Reserved. 0010 * This software is released under one of the following licenses: 0011 * AGPL (with Java and Go exceptions) or Mavimax's license for commercial use. 0012 * See LICENSE file for full text. 0013 * ----------------------------------------------------------------------------- 0014 * AGPL license: 0015 * 0016 * This program is free software; you can redistribute it and/or modify it under 0017 * the terms of the GNU Affero General Public License, version 3 as published 0018 * by the Free Software Foundation; 0019 * 0020 * This program is distributed in the hope that it will be useful, but WITHOUT ANY 0021 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A 0022 * PARTICULAR PURPOSE. See the GNU Affero General Public License, version 3 0023 * for more details. 0024 * 0025 * You should have received a copy of the GNU Affero General Public License along 0026 * with this program; if not, write to the Free Software Foundation, Inc., 0027 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 0028 * 0029 * ----------------------------------------------------------------------------- 0030 * A commercial use license is available from Mavimax, Ltd 0031 * contact@mavimax.com 0032 * ----------------------------------------------------------------------------- 0033 */ 0034 #include <stdio.h> 0035 #include <stdlib.h> 0036 #include <ndebug.h> 0037 #include <atmi.h> 0038 #include <ndrstandard.h> 0039 #include <ubf.h> 0040 #include <test.fd.h> 0041 #include <string.h> 0042 #include <unistd.h> 0043 #include "test90.h" 0044 0045 /*---------------------------Externs------------------------------------*/ 0046 /*---------------------------Macros-------------------------------------*/ 0047 /*---------------------------Enums--------------------------------------*/ 0048 /*---------------------------Typedefs-----------------------------------*/ 0049 /*---------------------------Globals------------------------------------*/ 0050 /*---------------------------Statics------------------------------------*/ 0051 /*---------------------------Prototypes---------------------------------*/ 0052 0053 /** 0054 * Standard service entry 0055 */ 0056 void TESTSV (TPSVCINFO *p_svc) 0057 { 0058 int ret=EXSUCCEED; 0059 char testbuf[1024]; 0060 UBFH *p_ub = (UBFH *)p_svc->data; 0061 0062 NDRX_LOG(log_debug, "%s got call", __func__); 0063 0064 /* Just print the buffer */ 0065 Bprint(p_ub); 0066 0067 if (EXFAIL==Bget(p_ub, T_STRING_FLD, 0, testbuf, 0)) 0068 { 0069 NDRX_LOG(log_error, "TESTERROR: Failed to get T_STRING_FLD: %s", 0070 Bstrerror(Berror)); 0071 ret=EXFAIL; 0072 goto out; 0073 } 0074 0075 if (0!=strcmp(testbuf, VALUE_EXPECTED)) 0076 { 0077 NDRX_LOG(log_error, "TESTERROR: Expected: [%s] got [%s]", 0078 VALUE_EXPECTED, testbuf); 0079 ret=EXFAIL; 0080 goto out; 0081 } 0082 0083 0084 out: 0085 tpreturn( ret==EXSUCCEED?TPSUCCESS:TPFAIL, 0086 0L, 0087 (char *)p_ub, 0088 0L, 0089 0L); 0090 } 0091 0092 /** 0093 * Do initialisation 0094 */ 0095 int tpsvrinit(int argc, char **argv) 0096 { 0097 int ret = EXSUCCEED; 0098 /* Check arguments */ 0099 int c; 0100 NDRX_LOG(log_debug, "tpsvrinit called"); 0101 0102 /* Parse command line */ 0103 while ((c = getopt(argc, argv, "c:")) != -1) 0104 { 0105 switch (c) 0106 { 0107 case 'c': 0108 if (0==strcmp(optarg, "HELLO \"WORLD")) 0109 { 0110 /* default debug generated is at level 3: */ 0111 NDRX_LOG(log_error, "Arg c OK"); 0112 } 0113 else 0114 { 0115 NDRX_LOG(log_error, "TESTERROR: Expected [HELLO \"WORLD] got [%s])", 0116 optarg); 0117 EXFAIL_OUT(ret); 0118 } 0119 break; 0120 } 0121 } 0122 0123 /* moved to service tables 0124 if (EXSUCCEED!=tpadvertise("TESTSV", TESTSV)) 0125 { 0126 NDRX_LOG(log_error, "Failed to initialise TESTSV!"); 0127 EXFAIL_OUT(ret); 0128 } 0129 */ 0130 out: 0131 return ret; 0132 } 0133 0134 /** 0135 * Do de-initialisation 0136 */ 0137 void tpsvrdone(void) 0138 { 0139 NDRX_LOG(log_debug, "tpsvrdone called"); 0140 } 0141 0142 0143 /* Auto generated system advertise table */ 0144 expublic struct tmdsptchtbl_t ndrx_G_tmdsptchtbl[] = { 0145 { "TESTSV", "TESTSV", TESTSV, 0, 0 } 0146 , { NULL, NULL, NULL, 0, 0 } 0147 }; 0148 0149 /** 0150 * Server program main entry, multi-threaded support 0151 * @param argc argument count 0152 * @param argv argument values 0153 * @return SUCCEED/FAIL 0154 */ 0155 int main( int argc, char** argv ) 0156 { 0157 _tmbuilt_with_thread_option=EXFALSE; 0158 struct tmsvrargs_t tmsvrargs = 0159 { 0160 &tmnull_switch, 0161 &ndrx_G_tmdsptchtbl[0], 0162 0, 0163 tpsvrinit, 0164 tpsvrdone, 0165 NULL, 0166 NULL, 0167 NULL, 0168 NULL, 0169 NULL, 0170 NULL, 0171 NULL 0172 }; 0173 0174 return( _tmstartserver( argc, argv, &tmsvrargs )); 0175 0176 } 0177 0178 /* vim: set ts=4 sw=4 et smartindent: */
[ Source navigation ] | [ Diff markup ] | [ Identifier search ] | [ general search ] |
This page was automatically generated by the 2.1.0 LXR engine. The LXR team |
![]() ![]() |