1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 #include "pyuno_impl.hxx" 25 26 #include <osl/module.hxx> 27 #include <osl/thread.h> 28 #include <osl/file.hxx> 29 30 #include <typelib/typedescription.hxx> 31 32 #include <rtl/strbuf.hxx> 33 #include <rtl/ustrbuf.hxx> 34 #include <rtl/uuid.h> 35 #include <rtl/bootstrap.hxx> 36 37 #include <uno/current_context.hxx> 38 #include <cppuhelper/bootstrap.hxx> 39 40 #include <com/sun/star/reflection/XIdlReflection.hpp> 41 #include <com/sun/star/reflection/XIdlClass.hpp> 42 #include <com/sun/star/registry/InvalidRegistryException.hpp> 43 44 using osl::Module; 45 46 using rtl::OString; 47 using rtl::OUString; 48 using rtl::OUStringToOString; 49 using rtl::OUStringBuffer; 50 using rtl::OStringBuffer; 51 52 using com::sun::star::uno::Sequence; 53 using com::sun::star::uno::Reference; 54 using com::sun::star::uno::XInterface; 55 using com::sun::star::uno::Any; 56 using com::sun::star::uno::makeAny; 57 using com::sun::star::uno::UNO_QUERY; 58 using com::sun::star::uno::RuntimeException; 59 using com::sun::star::uno::TypeDescription; 60 using com::sun::star::uno::XComponentContext; 61 using com::sun::star::container::NoSuchElementException; 62 using com::sun::star::reflection::XIdlReflection; 63 using com::sun::star::reflection::XIdlClass; 64 using com::sun::star::script::XInvocation2; 65 66 using namespace pyuno; 67 68 namespace { 69 70 /** 71 @ index of the next to be used member in the initializer list ! 72 */ 73 sal_Int32 fillStructWithInitializer( 74 const Reference< XInvocation2 > &inv, 75 typelib_CompoundTypeDescription *pCompType, 76 PyObject *initializer, 77 const Runtime &runtime) throw ( RuntimeException ) 78 { 79 sal_Int32 nIndex = 0; 80 if( pCompType->pBaseTypeDescription ) 81 nIndex = fillStructWithInitializer( 82 inv, pCompType->pBaseTypeDescription, initializer, runtime ); 83 84 sal_Int32 nTupleSize = PyTuple_Size(initializer); 85 int i; 86 for( i = 0 ; i < pCompType->nMembers ; i ++ ) 87 { 88 if( i + nIndex >= nTupleSize ) 89 { 90 OUStringBuffer buf; 91 buf.appendAscii( "pyuno._createUnoStructHelper: too few elements in the initializer tuple,"); 92 buf.appendAscii( "expected at least " ).append( nIndex + pCompType->nMembers ); 93 buf.appendAscii( ", got " ).append( nTupleSize ); 94 throw RuntimeException(buf.makeStringAndClear(), Reference< XInterface > ()); 95 } 96 PyObject *element = PyTuple_GetItem( initializer, i + nIndex ); 97 Any a = runtime.pyObject2Any( element, ACCEPT_UNO_ANY ); 98 inv->setValue( pCompType->ppMemberNames[i], a ); 99 } 100 return i+nIndex; 101 } 102 103 OUString getLibDir() 104 { 105 static OUString *pLibDir; 106 if( !pLibDir ) 107 { 108 osl::MutexGuard guard( osl::Mutex::getGlobalMutex() ); 109 if( ! pLibDir ) 110 { 111 static OUString libDir; 112 113 // workarounds the $(ORIGIN) until it is available 114 if( Module::getUrlFromAddress( 115 reinterpret_cast< oslGenericFunction >(getLibDir), libDir ) ) 116 { 117 libDir = OUString( libDir.getStr(), libDir.lastIndexOf('/' ) ); 118 OUString name ( RTL_CONSTASCII_USTRINGPARAM( "PYUNOLIBDIR" ) ); 119 rtl_bootstrap_set( name.pData, libDir.pData ); 120 } 121 pLibDir = &libDir; 122 } 123 } 124 return *pLibDir; 125 } 126 127 void raisePySystemException( const char * exceptionType, const OUString & message ) 128 { 129 OStringBuffer buf; 130 buf.append( "Error during bootstrapping uno ("); 131 buf.append( exceptionType ); 132 buf.append( "):" ); 133 buf.append( OUStringToOString( message, osl_getThreadTextEncoding() ) ); 134 PyErr_SetString( PyExc_SystemError, buf.makeStringAndClear().getStr() ); 135 } 136 137 extern "C" { 138 139 static PyObject* getComponentContext (PyObject*, PyObject*) 140 { 141 PyRef ret; 142 try 143 { 144 Reference<XComponentContext> ctx; 145 146 // getLibDir() must be called in order to set bootstrap variables correctly ! 147 OUString path( getLibDir()); 148 if( Runtime::isInitialized() ) 149 { 150 Runtime runtime; 151 ctx = runtime.getImpl()->cargo->xContext; 152 } 153 else 154 { 155 OUString iniFile; 156 if( !path.getLength() ) 157 { 158 PyErr_SetString( 159 PyExc_RuntimeError, "osl_getUrlFromAddress fails, that's why I cannot find ini " 160 "file for bootstrapping python uno bridge\n" ); 161 return NULL; 162 } 163 164 OUStringBuffer iniFileName; 165 iniFileName.append( path ); 166 iniFileName.appendAscii( "/" ); 167 iniFileName.appendAscii( SAL_CONFIGFILE( "pyuno" ) ); 168 iniFile = iniFileName.makeStringAndClear(); 169 osl::DirectoryItem item; 170 if( osl::DirectoryItem::get( iniFile, item ) == item.E_None ) 171 { 172 // in case pyuno.ini exists, use this file for bootstrapping 173 PyThreadDetach antiguard; 174 ctx = cppu::defaultBootstrap_InitialComponentContext (iniFile); 175 } 176 else 177 { 178 // defaulting to the standard bootstrapping 179 PyThreadDetach antiguard; 180 ctx = cppu::defaultBootstrap_InitialComponentContext (); 181 } 182 183 } 184 185 if( ! Runtime::isInitialized() ) 186 { 187 Runtime::initialize( ctx ); 188 } 189 Runtime runtime; 190 ret = runtime.any2PyObject( makeAny( ctx ) ); 191 } 192 catch (com::sun::star::registry::InvalidRegistryException &e) 193 { 194 // can't use raisePyExceptionWithAny() here, because the function 195 // does any conversions, which will not work with a 196 // wrongly bootstrapped pyuno! 197 raisePySystemException( "InvalidRegistryException", e.Message ); 198 } 199 catch( com::sun::star::lang::IllegalArgumentException & e) 200 { 201 raisePySystemException( "IllegalArgumentException", e.Message ); 202 } 203 catch( com::sun::star::script::CannotConvertException & e) 204 { 205 raisePySystemException( "CannotConvertException", e.Message ); 206 } 207 catch (com::sun::star::uno::RuntimeException & e) 208 { 209 raisePySystemException( "RuntimeException", e.Message ); 210 } 211 catch (com::sun::star::uno::Exception & e) 212 { 213 raisePySystemException( "uno::Exception", e.Message ); 214 } 215 return ret.getAcquired(); 216 } 217 218 PyObject * extractOneStringArg( PyObject *args, char const *funcName ) 219 { 220 if( !PyTuple_Check( args ) || PyTuple_Size( args) != 1 ) 221 { 222 OStringBuffer buf; 223 buf.append( funcName ).append( ": expecting one string argument" ); 224 PyErr_SetString( PyExc_RuntimeError, buf.getStr() ); 225 return NULL; 226 } 227 PyObject *obj = PyTuple_GetItem( args, 0 ); 228 if( !PyString_Check( obj ) && ! PyUnicode_Check(obj)) 229 { 230 OStringBuffer buf; 231 buf.append( funcName ).append( ": expecting one string argument" ); 232 PyErr_SetString( PyExc_TypeError, buf.getStr()); 233 return NULL; 234 } 235 return obj; 236 } 237 238 static PyObject *createUnoStructHelper(PyObject *, PyObject* args ) 239 { 240 Any IdlStruct; 241 PyRef ret; 242 243 try 244 { 245 Runtime runtime; 246 if( PyTuple_Size( args ) == 2 ) 247 { 248 PyObject *structName = PyTuple_GetItem( args,0 ); 249 PyObject *initializer = PyTuple_GetItem( args ,1 ); 250 251 if( PyString_Check( structName ) ) 252 { 253 if( PyTuple_Check( initializer ) ) 254 { 255 OUString typeName( OUString::createFromAscii(PyString_AsString(structName))); 256 RuntimeCargo *c = runtime.getImpl()->cargo; 257 Reference<XIdlClass> idl_class ( c->xCoreReflection->forName (typeName),UNO_QUERY); 258 if (idl_class.is ()) 259 { 260 idl_class->createObject (IdlStruct); 261 PyUNO *me = (PyUNO*)PyUNO_new_UNCHECKED( IdlStruct, c->xInvocation ); 262 PyRef returnCandidate( (PyObject*)me, SAL_NO_ACQUIRE ); 263 if( PyTuple_Size( initializer ) > 0 ) 264 { 265 TypeDescription desc( typeName ); 266 OSL_ASSERT( desc.is() ); // could already instantiate an XInvocation2 ! 267 268 typelib_CompoundTypeDescription *pCompType = 269 ( typelib_CompoundTypeDescription * ) desc.get(); 270 sal_Int32 n = fillStructWithInitializer( 271 me->members->xInvocation, pCompType, initializer, runtime ); 272 if( n != PyTuple_Size(initializer) ) 273 { 274 OUStringBuffer buf; 275 buf.appendAscii( "pyuno._createUnoStructHelper: wrong number of "); 276 buf.appendAscii( "elements in the initializer list, expected " ); 277 buf.append( n ); 278 buf.appendAscii( ", got " ); 279 buf.append( (sal_Int32) PyTuple_Size(initializer) ); 280 throw RuntimeException( 281 buf.makeStringAndClear(), Reference< XInterface > ()); 282 } 283 } 284 ret = returnCandidate; 285 } 286 else 287 { 288 OStringBuffer buf; 289 buf.append( "UNO struct " ); 290 buf.append( PyString_AsString(structName) ); 291 buf.append( " is unkown" ); 292 PyErr_SetString (PyExc_RuntimeError, buf.getStr()); 293 } 294 } 295 else 296 { 297 PyErr_SetString( 298 PyExc_RuntimeError, 299 "pyuno._createUnoStructHelper: 2nd argument (initializer sequence) is no tuple" ); 300 } 301 } 302 else 303 { 304 PyErr_SetString (PyExc_AttributeError, "createUnoStruct: first argument wasn't a string"); 305 } 306 } 307 else 308 { 309 PyErr_SetString (PyExc_AttributeError, "1 Arguments: Structure Name"); 310 } 311 } 312 catch( com::sun::star::uno::RuntimeException & e ) 313 { 314 raisePyExceptionWithAny( makeAny( e ) ); 315 } 316 catch( com::sun::star::script::CannotConvertException & e ) 317 { 318 raisePyExceptionWithAny( makeAny( e ) ); 319 } 320 catch( com::sun::star::uno::Exception & e ) 321 { 322 raisePyExceptionWithAny( makeAny( e ) ); 323 } 324 return ret.getAcquired(); 325 } 326 327 static PyObject *getTypeByName( PyObject *, PyObject *args ) 328 { 329 PyObject * ret = NULL; 330 331 try 332 { 333 char *name; 334 335 if (PyArg_ParseTuple (args, const_cast< char * >("s"), &name)) 336 { 337 OUString typeName ( OUString::createFromAscii( name ) ); 338 TypeDescription typeDesc( typeName ); 339 if( typeDesc.is() ) 340 { 341 Runtime runtime; 342 ret = PyUNO_Type_new( 343 name, (com::sun::star::uno::TypeClass)typeDesc.get()->eTypeClass, runtime ); 344 } 345 else 346 { 347 OStringBuffer buf; 348 buf.append( "Type " ).append(name).append( " is unknown" ); 349 PyErr_SetString( PyExc_RuntimeError, buf.getStr() ); 350 } 351 } 352 } 353 catch ( RuntimeException & e ) 354 { 355 raisePyExceptionWithAny( makeAny( e ) ); 356 } 357 return ret; 358 } 359 360 static PyObject *getConstantByName( PyObject *, PyObject *args ) 361 { 362 PyObject *ret = 0; 363 try 364 { 365 char *name; 366 367 if (PyArg_ParseTuple (args, const_cast< char * >("s"), &name)) 368 { 369 OUString typeName ( OUString::createFromAscii( name ) ); 370 Runtime runtime; 371 Any a = runtime.getImpl()->cargo->xTdMgr->getByHierarchicalName(typeName); 372 if( a.getValueType().getTypeClass() == 373 com::sun::star::uno::TypeClass_INTERFACE ) 374 { 375 // a idl constant cannot be an instance of an uno-object, thus 376 // this cannot be a constant 377 OUStringBuffer buf; 378 buf.appendAscii( "pyuno.getConstantByName: " ).append( typeName ); 379 buf.appendAscii( "is not a constant" ); 380 throw RuntimeException(buf.makeStringAndClear(), Reference< XInterface > () ); 381 } 382 PyRef constant = runtime.any2PyObject( a ); 383 ret = constant.getAcquired(); 384 } 385 } 386 catch( NoSuchElementException & e ) 387 { 388 // to the python programmer, this is a runtime exception, 389 // do not support tweakings with the type system 390 RuntimeException runExc( e.Message, Reference< XInterface > () ); 391 raisePyExceptionWithAny( makeAny( runExc ) ); 392 } 393 catch( com::sun::star::script::CannotConvertException & e) 394 { 395 raisePyExceptionWithAny( makeAny( e ) ); 396 } 397 catch( com::sun::star::lang::IllegalArgumentException & e) 398 { 399 raisePyExceptionWithAny( makeAny( e ) ); 400 } 401 catch( RuntimeException & e ) 402 { 403 raisePyExceptionWithAny( makeAny(e) ); 404 } 405 return ret; 406 } 407 408 static PyObject *checkType( PyObject *, PyObject *args ) 409 { 410 if( !PyTuple_Check( args ) || PyTuple_Size( args) != 1 ) 411 { 412 OStringBuffer buf; 413 buf.append( "pyuno.checkType : expecting one uno.Type argument" ); 414 PyErr_SetString( PyExc_RuntimeError, buf.getStr() ); 415 return NULL; 416 } 417 PyObject *obj = PyTuple_GetItem( args, 0 ); 418 419 try 420 { 421 PyType2Type( obj ); 422 } 423 catch( RuntimeException & e) 424 { 425 raisePyExceptionWithAny( makeAny( e ) ); 426 return NULL; 427 } 428 Py_INCREF( Py_None ); 429 return Py_None; 430 } 431 432 static PyObject *checkEnum( PyObject *, PyObject *args ) 433 { 434 if( !PyTuple_Check( args ) || PyTuple_Size( args) != 1 ) 435 { 436 OStringBuffer buf; 437 buf.append( "pyuno.checkType : expecting one uno.Type argument" ); 438 PyErr_SetString( PyExc_RuntimeError, buf.getStr() ); 439 return NULL; 440 } 441 PyObject *obj = PyTuple_GetItem( args, 0 ); 442 443 try 444 { 445 PyEnum2Enum( obj ); 446 } 447 catch( RuntimeException & e) 448 { 449 raisePyExceptionWithAny( makeAny( e) ); 450 return NULL; 451 } 452 Py_INCREF( Py_None ); 453 return Py_None; 454 } 455 456 static PyObject *getClass( PyObject *, PyObject *args ) 457 { 458 PyObject *obj = extractOneStringArg( args, "pyuno.getClass"); 459 if( ! obj ) 460 return NULL; 461 462 try 463 { 464 Runtime runtime; 465 PyRef ret = getClass( 466 OUString( PyString_AsString( obj), strlen(PyString_AsString(obj)),RTL_TEXTENCODING_ASCII_US), 467 runtime ); 468 Py_XINCREF( ret.get() ); 469 return ret.get(); 470 } 471 catch( RuntimeException & e) 472 { 473 // NOOPT !!! 474 // gcc 3.2.3 crashes here in the regcomp test scenario 475 // only since migration to python 2.3.4 ???? strange thing 476 // optimization switched off for this module ! 477 raisePyExceptionWithAny( makeAny(e) ); 478 } 479 return NULL; 480 } 481 482 static PyObject *isInterface( PyObject *, PyObject *args ) 483 { 484 485 if( PyTuple_Check( args ) && PyTuple_Size( args ) == 1 ) 486 { 487 PyObject *obj = PyTuple_GetItem( args, 0 ); 488 Runtime r; 489 #if PY_MAJOR_VERSION >= 3 490 return PyLong_FromLong( isInterfaceClass( r, obj ) ); 491 #else 492 return PyInt_FromLong( isInterfaceClass( r, obj ) ); 493 494 #endif 495 } 496 #if PY_MAJOR_VERSION >= 3 497 return PyLong_FromLong( 0 ); 498 #else 499 return PyInt_FromLong( 0 ); 500 #endif 501 } 502 503 static PyObject * generateUuid( PyObject *, PyObject * ) 504 { 505 Sequence< sal_Int8 > seq( 16 ); 506 rtl_createUuid( (sal_uInt8*)seq.getArray() , 0 , sal_False ); 507 PyRef ret; 508 try 509 { 510 Runtime runtime; 511 ret = runtime.any2PyObject( makeAny( seq ) ); 512 } 513 catch( RuntimeException & e ) 514 { 515 raisePyExceptionWithAny( makeAny(e) ); 516 } 517 return ret.getAcquired(); 518 } 519 520 static PyObject *systemPathToFileUrl( PyObject *, PyObject * args ) 521 { 522 PyObject *obj = extractOneStringArg( args, "pyuno.systemPathToFileUrl" ); 523 if( ! obj ) 524 return NULL; 525 526 OUString sysPath = pyString2ustring( obj ); 527 OUString url; 528 osl::FileBase::RC e = osl::FileBase::getFileURLFromSystemPath( sysPath, url ); 529 530 if( e != osl::FileBase::E_None ) 531 { 532 OUStringBuffer buf; 533 buf.appendAscii( "Couldn't convert " ); 534 buf.append( sysPath ); 535 buf.appendAscii( " to a file url for reason (" ); 536 buf.append( (sal_Int32) e ); 537 buf.appendAscii( ")" ); 538 raisePyExceptionWithAny( 539 makeAny( RuntimeException( buf.makeStringAndClear(), Reference< XInterface > () ))); 540 return NULL; 541 } 542 return ustring2PyUnicode( url ).getAcquired(); 543 } 544 545 static PyObject * fileUrlToSystemPath( PyObject *, PyObject * args ) 546 { 547 PyObject *obj = extractOneStringArg( args, "pyuno.fileUrlToSystemPath" ); 548 if( ! obj ) 549 return NULL; 550 551 OUString url = pyString2ustring( obj ); 552 OUString sysPath; 553 osl::FileBase::RC e = osl::FileBase::getSystemPathFromFileURL( url, sysPath ); 554 555 if( e != osl::FileBase::E_None ) 556 { 557 OUStringBuffer buf; 558 buf.appendAscii( "Couldn't convert file url " ); 559 buf.append( sysPath ); 560 buf.appendAscii( " to a system path for reason (" ); 561 buf.append( (sal_Int32) e ); 562 buf.appendAscii( ")" ); 563 raisePyExceptionWithAny( 564 makeAny( RuntimeException( buf.makeStringAndClear(), Reference< XInterface > () ))); 565 return NULL; 566 } 567 return ustring2PyUnicode( sysPath ).getAcquired(); 568 } 569 570 static PyObject * absolutize( PyObject *, PyObject * args ) 571 { 572 if( PyTuple_Check( args ) && PyTuple_Size( args ) == 2 ) 573 { 574 OUString ouPath = pyString2ustring( PyTuple_GetItem( args , 0 ) ); 575 OUString ouRel = pyString2ustring( PyTuple_GetItem( args, 1 ) ); 576 OUString ret; 577 oslFileError e = osl_getAbsoluteFileURL( ouPath.pData, ouRel.pData, &(ret.pData) ); 578 if( e != osl_File_E_None ) 579 { 580 OUStringBuffer buf; 581 buf.appendAscii( "Couldn't absolutize " ); 582 buf.append( ouRel ); 583 buf.appendAscii( " using root " ); 584 buf.append( ouPath ); 585 buf.appendAscii( " for reason (" ); 586 buf.append( (sal_Int32) e ); 587 buf.appendAscii( ")" ); 588 589 PyErr_SetString( 590 PyExc_OSError, 591 OUStringToOString(buf.makeStringAndClear(),osl_getThreadTextEncoding())); 592 return 0; 593 } 594 return ustring2PyUnicode( ret ).getAcquired(); 595 } 596 return 0; 597 } 598 599 static PyObject * invoke ( PyObject *, PyObject * args ) 600 { 601 PyObject *ret = 0; 602 if( PyTuple_Check( args ) && PyTuple_Size( args ) == 3 ) 603 { 604 PyObject *object = PyTuple_GetItem( args, 0 ); 605 606 if( PyString_Check( PyTuple_GetItem( args, 1 ) ) ) 607 { 608 const char *name = PyString_AsString( PyTuple_GetItem( args, 1 ) ); 609 if( PyTuple_Check( PyTuple_GetItem( args , 2 ))) 610 { 611 ret = PyUNO_invoke( object, name , PyTuple_GetItem( args, 2 ) ); 612 } 613 else 614 { 615 OStringBuffer buf; 616 buf.append( "uno.invoke expects a tuple as 3rd argument, got " ); 617 buf.append( PyString_AsString( PyObject_Str( PyTuple_GetItem( args, 2) ) ) ); 618 PyErr_SetString( PyExc_RuntimeError, buf.makeStringAndClear() ); 619 } 620 } 621 else 622 { 623 OStringBuffer buf; 624 buf.append( "uno.invoke expected a string as 2nd argument, got " ); 625 buf.append( PyString_AsString( PyObject_Str( PyTuple_GetItem( args, 1) ) ) ); 626 PyErr_SetString( PyExc_RuntimeError, buf.makeStringAndClear() ); 627 } 628 } 629 else 630 { 631 OStringBuffer buf; 632 buf.append( "uno.invoke expects object, name, (arg1, arg2, ... )\n" ); 633 PyErr_SetString( PyExc_RuntimeError, buf.makeStringAndClear() ); 634 } 635 return ret; 636 } 637 638 static PyObject *getCurrentContext( PyObject *, PyObject * ) 639 { 640 PyRef ret; 641 try 642 { 643 Runtime runtime; 644 ret = runtime.any2PyObject( 645 makeAny( com::sun::star::uno::getCurrentContext() ) ); 646 } 647 catch( com::sun::star::uno::Exception & e ) 648 { 649 raisePyExceptionWithAny( makeAny( e ) ); 650 } 651 return ret.getAcquired(); 652 } 653 654 static PyObject *setCurrentContext( PyObject *, PyObject * args ) 655 { 656 PyRef ret; 657 try 658 { 659 if( PyTuple_Check( args ) && PyTuple_Size( args ) == 1 ) 660 { 661 662 Runtime runtime; 663 Any a = runtime.pyObject2Any( PyTuple_GetItem( args, 0 ) ); 664 665 Reference< com::sun::star::uno::XCurrentContext > context; 666 667 if( (a.hasValue() && (a >>= context)) || ! a.hasValue() ) 668 { 669 ret = com::sun::star::uno::setCurrentContext( context ) ? Py_True : Py_False; 670 } 671 else 672 { 673 OStringBuffer buf; 674 buf.append( "uno.setCurrentContext expects an XComponentContext implementation, got " ); 675 buf.append( PyString_AsString( PyObject_Str( PyTuple_GetItem( args, 0) ) ) ); 676 PyErr_SetString( PyExc_RuntimeError, buf.makeStringAndClear() ); 677 } 678 } 679 else 680 { 681 OStringBuffer buf; 682 buf.append( "uno.setCurrentContext expects exactly one argument (the current Context)\n" ); 683 PyErr_SetString( PyExc_RuntimeError, buf.makeStringAndClear() ); 684 } 685 } 686 catch( com::sun::star::uno::Exception & e ) 687 { 688 raisePyExceptionWithAny( makeAny( e ) ); 689 } 690 return ret.getAcquired(); 691 } 692 693 } 694 695 struct PyMethodDef PyUNOModule_methods [] = 696 { 697 {const_cast< char * >("getComponentContext"), getComponentContext, 1, NULL}, 698 {const_cast< char * >("_createUnoStructHelper"), createUnoStructHelper, 2, NULL}, 699 {const_cast< char * >("getTypeByName"), getTypeByName, 1, NULL}, 700 {const_cast< char * >("getConstantByName"), getConstantByName,1, NULL}, 701 {const_cast< char * >("getClass"), getClass,1, NULL}, 702 {const_cast< char * >("checkEnum"), checkEnum, 1, NULL}, 703 {const_cast< char * >("checkType"), checkType, 1, NULL}, 704 {const_cast< char * >("generateUuid"), generateUuid,0, NULL}, 705 {const_cast< char * >("systemPathToFileUrl"),systemPathToFileUrl,1, NULL}, 706 {const_cast< char * >("fileUrlToSystemPath"),fileUrlToSystemPath,1, NULL}, 707 {const_cast< char * >("absolutize"),absolutize,2, NULL}, 708 {const_cast< char * >("isInterface"),isInterface,1, NULL}, 709 {const_cast< char * >("invoke"),invoke, 2, NULL}, 710 {const_cast< char * >("setCurrentContext"),setCurrentContext,1, NULL}, 711 {const_cast< char * >("getCurrentContext"),getCurrentContext,1, NULL}, 712 {NULL, NULL, 0, NULL} 713 }; 714 715 } 716 717 extern "C" PY_DLLEXPORT void initpyuno() 718 { 719 // noop when called already, otherwise needed to allow multiple threads 720 PyEval_InitThreads(); 721 Py_InitModule (const_cast< char * >("pyuno"), PyUNOModule_methods); 722 } 723