Commit 714519b0cef06c449e59600305c648dab729f997
1 parent
a85d5f96
Exists in
master
and in
5 other branches
Evoluindo chamada do interpretador para o formato do Rexx4
Showing
1 changed file
with
67 additions
and
73 deletions
Show diff stats
src/plugins/rx3270/pluginmain.cc
... | ... | @@ -219,76 +219,17 @@ |
219 | 219 | return lib3270_get_text(hSession,baddr,len); |
220 | 220 | } |
221 | 221 | |
222 | -extern "C" | |
223 | -{ | |
224 | - | |
225 | - static RXSTRING * build_args(const gchar **arg, size_t *argc) | |
226 | - { | |
227 | - size_t sz = g_strv_length((gchar **)arg); | |
228 | - size_t szText = 0; | |
229 | - gchar * ptr; | |
230 | - int f; | |
231 | - RXSTRING * rxArgs; | |
232 | - | |
233 | - for(f=0;f< (int) sz;f++) | |
234 | - szText += strlen(arg[f])+1; | |
235 | - | |
236 | - *argc = sz; | |
237 | - rxArgs = (RXSTRING *) g_malloc0((sizeof(RXSTRING) * (sz+1))+szText); | |
238 | - ptr = (gchar *) &(rxArgs[sz+1]); | |
239 | - | |
240 | - for(f=0;f< (int) sz;f++) | |
241 | - { | |
242 | - strcpy(ptr,arg[f]); | |
243 | - | |
244 | - rxArgs[f].strptr = ptr; | |
245 | - rxArgs[f].strlength = strlen(ptr); | |
246 | - ptr += ((size_t) rxArgs[f].strlength+1); | |
247 | - } | |
248 | - | |
249 | - return rxArgs; | |
250 | - } | |
251 | - | |
252 | 222 | static void call_rexx_script(GtkAction *action, GtkWidget *widget, const gchar *filename) |
253 | 223 | { |
254 | - gchar * args = (gchar *) g_object_get_data(G_OBJECT(action),"args"); | |
224 | + const gchar * args = (const gchar *) g_object_get_data(G_OBJECT(action),"args"); | |
255 | 225 | |
256 | - RXSTRING * rxArgs; | |
257 | - int ret; | |
258 | - short rc; | |
259 | - size_t argc = 0; | |
260 | - RXSTRING retstr; | |
261 | - unsigned char userArea[10]; | |
226 | + RexxInstance * instance; | |
227 | + RexxThreadContext * threadContext; | |
228 | + RexxOption options[25]; | |
262 | 229 | |
263 | - if(args) | |
264 | - { | |
265 | - gchar ** arg = g_strsplit(args,",",-1); | |
266 | - rxArgs = build_args((const gchar **)arg,&argc); | |
267 | - g_strfreev(arg); | |
268 | - } | |
269 | - else | |
270 | - { | |
271 | - static const gchar *arg[] = { "", NULL }; | |
272 | - rxArgs = build_args(arg,&argc); | |
273 | - } | |
274 | - | |
275 | - // set up default return | |
276 | - memset(&retstr,0,sizeof(retstr)); | |
277 | - | |
278 | - memset(userArea,' ',10); | |
279 | - userArea[9] = 0; | |
230 | + memset(options,0,sizeof(options)); | |
280 | 231 | |
281 | - ret = RexxStart( argc, // argument count | |
282 | - (PCONSTRXSTRING) rxArgs, // argument array | |
283 | - (char *) filename, // REXX procedure name | |
284 | - (PRXSTRING) 0, // no instore used | |
285 | - PACKAGE_NAME, // default address name | |
286 | - RXCOMMAND, // calling as a subcommand | |
287 | - NULL, // EXITs for this call | |
288 | - &rc, // converted return code | |
289 | - &retstr); // returned result | |
290 | - | |
291 | - if(ret) | |
232 | + if(!RexxCreateInterpreter(&instance, &threadContext, options)) | |
292 | 233 | { |
293 | 234 | GtkWidget *dialog = gtk_message_dialog_new( GTK_WINDOW(gtk_widget_get_toplevel(widget)), |
294 | 235 | GTK_DIALOG_DESTROY_WITH_PARENT, |
... | ... | @@ -296,25 +237,78 @@ extern "C" |
296 | 237 | GTK_BUTTONS_CANCEL, |
297 | 238 | "%s", _( "Can't start script" )); |
298 | 239 | |
299 | - gtk_window_set_title(GTK_WINDOW(dialog),_( "Startup error" )); | |
300 | - gtk_message_dialog_format_secondary_text(GTK_MESSAGE_DIALOG(dialog),_("Error %d starting rexx script"),ret); | |
240 | + gtk_window_set_title(GTK_WINDOW(dialog),_( "Rexx error" )); | |
241 | + gtk_message_dialog_format_secondary_text(GTK_MESSAGE_DIALOG(dialog),"%s",_( "Can't create rexx interpreter instance" )); | |
301 | 242 | |
302 | 243 | gtk_dialog_run(GTK_DIALOG (dialog)); |
303 | 244 | gtk_widget_destroy(dialog); |
304 | - | |
305 | 245 | } |
306 | 246 | else |
307 | 247 | { |
308 | - RexxWaitForTermination(); | |
309 | - } | |
248 | + RexxArrayObject rxArgs; | |
249 | + | |
250 | + if(args) | |
251 | + { | |
252 | + gchar **arg = g_strsplit(args,",",-1); | |
253 | + size_t sz = g_strv_length(arg); | |
254 | + | |
255 | + rxArgs = threadContext->NewArray(sz); | |
256 | + for(unsigned int i = 0; i<sz; i++) | |
257 | + threadContext->ArrayPut(rxArgs, threadContext->String(arg[i]), i + 1); | |
258 | + | |
259 | + g_strfreev(arg); | |
260 | + } | |
261 | + else | |
262 | + { | |
263 | + rxArgs = threadContext->NewArray(1); | |
264 | + threadContext->ArrayPut(rxArgs, threadContext->String(""),1); | |
265 | + } | |
266 | + | |
267 | + RexxObjectPtr result = threadContext->CallProgram(filename, rxArgs); | |
268 | + | |
269 | + if (threadContext->CheckCondition()) | |
270 | + { | |
271 | + RexxCondition condition; | |
310 | 272 | |
311 | - if(RXSTRPTR(retstr)) | |
312 | - RexxFreeMemory(RXSTRPTR(retstr)); | |
273 | + // retrieve the error information and get it into a decoded form | |
274 | + RexxDirectoryObject cond = threadContext->GetConditionInfo(); | |
275 | + threadContext->DecodeConditionInfo(cond, &condition); | |
276 | + // display the errors | |
277 | + GtkWidget *dialog = gtk_message_dialog_new( GTK_WINDOW(gtk_widget_get_toplevel(widget)), | |
278 | + GTK_DIALOG_DESTROY_WITH_PARENT, | |
279 | + GTK_MESSAGE_ERROR, | |
280 | + GTK_BUTTONS_CANCEL, | |
281 | + "%s", _( "Script error" )); | |
313 | 282 | |
314 | - g_free(rxArgs); | |
283 | + gtk_window_set_title(GTK_WINDOW(dialog),_( "System busy" )); | |
284 | + | |
285 | + gtk_message_dialog_format_secondary_text( | |
286 | + GTK_MESSAGE_DIALOG(dialog), | |
287 | + _( "Rexx error %d: %s\n%s" ), | |
288 | + (int) condition.code, | |
289 | + threadContext->CString(condition.errortext), | |
290 | + threadContext->CString(condition.message) | |
291 | + | |
292 | + ); | |
293 | + | |
294 | + gtk_dialog_run(GTK_DIALOG (dialog)); | |
295 | + gtk_widget_destroy(dialog); | |
296 | + | |
297 | + } | |
298 | + else if (result != NULLOBJECT) | |
299 | + { | |
300 | + CSTRING resultString = threadContext->CString(result); | |
301 | + lib3270_write_log(NULL,"REXX","%s exits with rc=%s",filename,resultString); | |
302 | + } | |
303 | + | |
304 | + instance->Terminate(); | |
305 | + } | |
315 | 306 | |
316 | 307 | } |
317 | 308 | |
309 | + | |
310 | +extern "C" | |
311 | +{ | |
318 | 312 | LIB3270_EXPORT void pw3270_action_rexx_activated(GtkAction *action, GtkWidget *widget) |
319 | 313 | { |
320 | 314 | gchar *filename = (gchar *) g_object_get_data(G_OBJECT(action),"src"); | ... | ... |