1af0996ceSBarry Smith #include <petsc/private/petscimpl.h> /*I "petscsys.h" I*/ 2c4aff060SBarry Smith 3c4aff060SBarry Smith /* ---------------------------------------------------------------- */ 4c4aff060SBarry Smith 5c4aff060SBarry Smith #if !defined(PETSC_PYTHON_EXE) 6c4aff060SBarry Smith #define PETSC_PYTHON_EXE "python" 7c4aff060SBarry Smith #endif 8c4aff060SBarry Smith 9c4aff060SBarry Smith static PetscErrorCode PetscPythonFindExecutable(char pythonexe[PETSC_MAX_PATH_LEN]) 10c4aff060SBarry Smith { 11ace3abfcSBarry Smith PetscBool flag; 12c4aff060SBarry Smith PetscErrorCode ierr; 136e111a19SKarl Rupp 14c4aff060SBarry Smith PetscFunctionBegin; 15c4aff060SBarry Smith /* get the path for the Python interpreter executable */ 16c4aff060SBarry Smith ierr = PetscStrncpy(pythonexe,PETSC_PYTHON_EXE,PETSC_MAX_PATH_LEN);CHKERRQ(ierr); 17c5929fdfSBarry Smith ierr = PetscOptionsGetString(NULL,NULL,"-python",pythonexe,PETSC_MAX_PATH_LEN,&flag);CHKERRQ(ierr); 18c4aff060SBarry Smith if (!flag || pythonexe[0]==0) { 19c4aff060SBarry Smith ierr = PetscStrncpy(pythonexe,PETSC_PYTHON_EXE,PETSC_MAX_PATH_LEN);CHKERRQ(ierr); 20c4aff060SBarry Smith } 21c4aff060SBarry Smith PetscFunctionReturn(0); 22c4aff060SBarry Smith } 23c4aff060SBarry Smith 240dfec4cbSBarry Smith /* 250dfec4cbSBarry Smith Python does not appear to have a universal way to indicate the location of Python dynamic library so try several possibilities 260dfec4cbSBarry Smith */ 270dfec4cbSBarry Smith static PetscErrorCode PetscPythonFindLibraryName(const char pythonexe[PETSC_MAX_PATH_LEN],const char attempt[PETSC_MAX_PATH_LEN],char pythonlib[PETSC_MAX_PATH_LEN],PetscBool *found) 28c4aff060SBarry Smith { 290dfec4cbSBarry Smith char command[2*PETSC_MAX_PATH_LEN]; 30c4aff060SBarry Smith FILE *fp = NULL; 310dfec4cbSBarry Smith char *eol; 320dfec4cbSBarry Smith PetscErrorCode ierr; 330dfec4cbSBarry Smith 340dfec4cbSBarry Smith PetscFunctionBegin; 350dfec4cbSBarry Smith /* call Python to find out the name of the Python dynamic library */ 360dfec4cbSBarry Smith ierr = PetscStrncpy(command,pythonexe,PETSC_MAX_PATH_LEN);CHKERRQ(ierr); 370dfec4cbSBarry Smith ierr = PetscStrcat(command," ");CHKERRQ(ierr); 380dfec4cbSBarry Smith ierr = PetscStrcat(command,attempt);CHKERRQ(ierr); 390dfec4cbSBarry Smith #if defined(PETSC_HAVE_POPEN) 400dfec4cbSBarry Smith ierr = PetscPOpen(PETSC_COMM_SELF,NULL,command,"r",&fp);CHKERRQ(ierr); 410dfec4cbSBarry Smith if (!fgets(pythonlib,PETSC_MAX_PATH_LEN,fp)) SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_PLIB,"Python: bad output from executable: %s",pythonexe); 420dfec4cbSBarry Smith ierr = PetscPClose(PETSC_COMM_SELF,fp);CHKERRQ(ierr); 430dfec4cbSBarry Smith #else 440dfec4cbSBarry Smith SETERRQ(PETSC_COMM_SELF,1,"Python: Aborted due to missing popen()"); 450dfec4cbSBarry Smith #endif 460dfec4cbSBarry Smith /* remove newlines */ 470dfec4cbSBarry Smith ierr = PetscStrchr(pythonlib,'\n',&eol);CHKERRQ(ierr); 480dfec4cbSBarry Smith if (eol) eol[0] = 0; 490dfec4cbSBarry Smith ierr = PetscTestFile(pythonlib,'r',found);CHKERRQ(ierr); 500dfec4cbSBarry Smith PetscFunctionReturn(0); 510dfec4cbSBarry Smith } 520dfec4cbSBarry Smith 530dfec4cbSBarry Smith 54412d63f8SBarry Smith static PetscErrorCode PetscPythonFindLibrary(const char pythonexe[PETSC_MAX_PATH_LEN],char pythonlib[PETSC_MAX_PATH_LEN]) 55c4aff060SBarry Smith { 5684b215baSBarry Smith const char cmdline1[] = "-c 'from distutils import sysconfig; print(sysconfig.get_config_var(\"LIBPYTHON\"))'"; 5784b215baSBarry Smith const char cmdline2[] = "-c 'import os;from distutils import sysconfig; print(os.path.join(sysconfig.get_config_var(\"LIBPL\"),sysconfig.get_config_var(\"LDLIBRARY\")))'"; 58*49a6f2e5SLisandro Dalcin const char cmdline3[] = "-c 'import os;from distutils import sysconfig; print(os.path.join(sysconfig.get_config_var(\"LIBDIR\"),sysconfig.get_config_var(\"LDLIBRARY\")))'"; 59ace3abfcSBarry Smith PetscBool found = PETSC_FALSE; 60c4aff060SBarry Smith PetscErrorCode ierr; 61c4aff060SBarry Smith 626e111a19SKarl Rupp PetscFunctionBegin; 63c4aff060SBarry Smith #if defined(PETSC_PYTHON_LIB) 64c4aff060SBarry Smith ierr = PetscStrcpy(pythonlib,PETSC_PYTHON_LIB);CHKERRQ(ierr); 65c4aff060SBarry Smith PetscFunctionReturn(0); 66c4aff060SBarry Smith #endif 67c4aff060SBarry Smith 680dfec4cbSBarry Smith ierr = PetscPythonFindLibraryName(pythonexe,cmdline1,pythonlib,&found);CHKERRQ(ierr); 6984b215baSBarry Smith if (!found) { 700dfec4cbSBarry Smith ierr = PetscPythonFindLibraryName(pythonexe,cmdline2,pythonlib,&found);CHKERRQ(ierr); 71c4aff060SBarry Smith } 72*49a6f2e5SLisandro Dalcin if (!found) { 73*49a6f2e5SLisandro Dalcin ierr = PetscPythonFindLibraryName(pythonexe,cmdline3,pythonlib,&found);CHKERRQ(ierr); 74*49a6f2e5SLisandro Dalcin } 75412d63f8SBarry Smith ierr = PetscInfo2(0,"Python library %s found %d\n",pythonlib,found);CHKERRQ(ierr); 76c4aff060SBarry Smith PetscFunctionReturn(0); 77c4aff060SBarry Smith } 78c4aff060SBarry Smith 79c4aff060SBarry Smith /* ---------------------------------------------------------------- */ 80c4aff060SBarry Smith 81c4aff060SBarry Smith typedef struct _Py_object_t PyObject; /* fake definition */ 82c4aff060SBarry Smith 83e0ab9aedSLisandro Dalcin static PyObject* Py_None = 0; 84e0ab9aedSLisandro Dalcin 859ac80d5eSLisandro Dalcin static const char* (*Py_GetVersion)(void); 869ac80d5eSLisandro Dalcin 87c4aff060SBarry Smith static int (*Py_IsInitialized)(void); 88c4aff060SBarry Smith static void (*Py_InitializeEx)(int); 89c4aff060SBarry Smith static void (*Py_Finalize)(void); 90c4aff060SBarry Smith 91*49a6f2e5SLisandro Dalcin static void (*PySys_SetArgv)(int,void*); 922f2e82b0SLisandro Dalcin static PyObject* (*PySys_GetObject)(const char*); 932f2e82b0SLisandro Dalcin static PyObject* (*PyObject_CallMethod)(PyObject*,const char*, const char*, ...); 94c4aff060SBarry Smith static PyObject* (*PyImport_ImportModule)(const char*); 95c4aff060SBarry Smith 96c4aff060SBarry Smith static void (*Py_IncRef)(PyObject*); 97c4aff060SBarry Smith static void (*Py_DecRef)(PyObject*); 98c4aff060SBarry Smith 99c4aff060SBarry Smith static void (*PyErr_Clear)(void); 100c4aff060SBarry Smith static PyObject* (*PyErr_Occurred)(void); 101e0ab9aedSLisandro Dalcin static void (*PyErr_Fetch)(PyObject**,PyObject**,PyObject**); 102e0ab9aedSLisandro Dalcin static void (*PyErr_NormalizeException)(PyObject**,PyObject**, PyObject**); 103e0ab9aedSLisandro Dalcin static void (*PyErr_Display)(PyObject*,PyObject*,PyObject*); 104e0ab9aedSLisandro Dalcin static void (*PyErr_Restore)(PyObject*,PyObject*,PyObject*); 105c4aff060SBarry Smith 106c4aff060SBarry Smith 107c4aff060SBarry Smith #define PetscDLPyLibOpen(libname) \ 108d44a1e48SBarry Smith PetscDLLibraryAppend(PETSC_COMM_SELF,&PetscDLLibrariesLoaded,libname) 109c4aff060SBarry Smith #define PetscDLPyLibSym(symbol, value) \ 1100298fd71SBarry Smith PetscDLLibrarySym(PETSC_COMM_SELF,&PetscDLLibrariesLoaded,NULL,symbol,(void**)value) 111c4aff060SBarry Smith #define PetscDLPyLibClose(comm) \ 112c4aff060SBarry Smith do { } while (0) 113c4aff060SBarry Smith 114c4aff060SBarry Smith static PetscErrorCode PetscPythonLoadLibrary(const char pythonlib[]) 115c4aff060SBarry Smith { 116c4aff060SBarry Smith PetscErrorCode ierr; 117c4aff060SBarry Smith 1186e111a19SKarl Rupp PetscFunctionBegin; 119c4aff060SBarry Smith /* open the Python dynamic library */ 120c4aff060SBarry Smith ierr = PetscDLPyLibOpen(pythonlib);CHKERRQ(ierr); 121c4aff060SBarry Smith ierr = PetscInfo1(0,"Python: loaded dynamic library %s\n", pythonlib);CHKERRQ(ierr); 122c4aff060SBarry Smith /* look required symbols from the Python C-API */ 123e0ab9aedSLisandro Dalcin ierr = PetscDLPyLibSym("_Py_NoneStruct" , &Py_None );CHKERRQ(ierr); 1249ac80d5eSLisandro Dalcin ierr = PetscDLPyLibSym("Py_GetVersion" , &Py_GetVersion );CHKERRQ(ierr); 125c4aff060SBarry Smith ierr = PetscDLPyLibSym("Py_IsInitialized" , &Py_IsInitialized );CHKERRQ(ierr); 126c4aff060SBarry Smith ierr = PetscDLPyLibSym("Py_InitializeEx" , &Py_InitializeEx );CHKERRQ(ierr); 127c4aff060SBarry Smith ierr = PetscDLPyLibSym("Py_Finalize" , &Py_Finalize );CHKERRQ(ierr); 1282f2e82b0SLisandro Dalcin ierr = PetscDLPyLibSym("PySys_GetObject" , &PySys_GetObject );CHKERRQ(ierr); 129c4aff060SBarry Smith ierr = PetscDLPyLibSym("PySys_SetArgv" , &PySys_SetArgv );CHKERRQ(ierr); 1302f2e82b0SLisandro Dalcin ierr = PetscDLPyLibSym("PyObject_CallMethod" , &PyObject_CallMethod );CHKERRQ(ierr); 131c4aff060SBarry Smith ierr = PetscDLPyLibSym("PyImport_ImportModule" , &PyImport_ImportModule );CHKERRQ(ierr); 132c4aff060SBarry Smith ierr = PetscDLPyLibSym("Py_IncRef" , &Py_IncRef );CHKERRQ(ierr); 133c4aff060SBarry Smith ierr = PetscDLPyLibSym("Py_DecRef" , &Py_DecRef );CHKERRQ(ierr); 134c4aff060SBarry Smith ierr = PetscDLPyLibSym("PyErr_Clear" , &PyErr_Clear );CHKERRQ(ierr); 135c4aff060SBarry Smith ierr = PetscDLPyLibSym("PyErr_Occurred" , &PyErr_Occurred );CHKERRQ(ierr); 136e0ab9aedSLisandro Dalcin ierr = PetscDLPyLibSym("PyErr_Fetch" , &PyErr_Fetch );CHKERRQ(ierr); 137e0ab9aedSLisandro Dalcin ierr = PetscDLPyLibSym("PyErr_NormalizeException", &PyErr_NormalizeException);CHKERRQ(ierr); 138e0ab9aedSLisandro Dalcin ierr = PetscDLPyLibSym("PyErr_Display", &PyErr_Display );CHKERRQ(ierr); 139e0ab9aedSLisandro Dalcin ierr = PetscDLPyLibSym("PyErr_Restore", &PyErr_Restore );CHKERRQ(ierr); 140c4aff060SBarry Smith /* XXX TODO: check that ALL symbols were there !!! */ 1415bc9b31fSBarry Smith if (!Py_None) SETERRQ1(PETSC_COMM_SELF,1,"Python: failed to load symbols from Python dynamic library %s",pythonlib); 1425bc9b31fSBarry Smith if (!Py_GetVersion) SETERRQ1(PETSC_COMM_SELF,1,"Python: failed to load symbols from Python dynamic library %s",pythonlib); 1435bc9b31fSBarry Smith if (!Py_IsInitialized) SETERRQ1(PETSC_COMM_SELF,1,"Python: failed to load symbols from Python dynamic library %s",pythonlib); 1445bc9b31fSBarry Smith if (!Py_InitializeEx) SETERRQ1(PETSC_COMM_SELF,1,"Python: failed to load symbols from Python dynamic library %s",pythonlib); 1455bc9b31fSBarry Smith if (!Py_Finalize) SETERRQ1(PETSC_COMM_SELF,1,"Python: failed to load symbols from Python dynamic library %s",pythonlib); 1465bc9b31fSBarry Smith ierr = PetscInfo1(0,"Python: all required symbols loaded from Python dynamic library %s\n",pythonlib);CHKERRQ(ierr); 147c4aff060SBarry Smith PetscFunctionReturn(0); 148c4aff060SBarry Smith } 149c4aff060SBarry Smith 150c4aff060SBarry Smith /* ---------------------------------------------------------------- */ 151c4aff060SBarry Smith 152c4aff060SBarry Smith static char PetscPythonExe[PETSC_MAX_PATH_LEN] = { 0 }; 153c4aff060SBarry Smith static char PetscPythonLib[PETSC_MAX_PATH_LEN] = { 0 }; 154ace3abfcSBarry Smith static PetscBool PetscBeganPython = PETSC_FALSE; 155c4aff060SBarry Smith 156c4aff060SBarry Smith /*@C 157c4aff060SBarry Smith PetscPythonFinalize - Finalize Python. 158c4aff060SBarry Smith 159c4aff060SBarry Smith Level: intermediate 160c4aff060SBarry Smith 161c4aff060SBarry Smith .keywords: Python 162c4aff060SBarry Smith @*/ 1637087cfbeSBarry Smith PetscErrorCode PetscPythonFinalize(void) 164c4aff060SBarry Smith { 165c4aff060SBarry Smith PetscFunctionBegin; 166c4aff060SBarry Smith if (PetscBeganPython) { if (Py_IsInitialized()) Py_Finalize(); } 167c4aff060SBarry Smith PetscBeganPython = PETSC_FALSE; 168c4aff060SBarry Smith PetscFunctionReturn(0); 169c4aff060SBarry Smith } 170c4aff060SBarry Smith 171c4aff060SBarry Smith /*@C 172c4aff060SBarry Smith PetscPythonInitialize - Initialize Python and import petsc4py. 173c4aff060SBarry Smith 174c4aff060SBarry Smith Input Parameter: 1750298fd71SBarry Smith + pyexe - path to the Python interpreter executable, or NULL. 1760298fd71SBarry Smith - pylib - full path to the Python dynamic library, or NULL. 177c4aff060SBarry Smith 178c4aff060SBarry Smith Level: intermediate 179c4aff060SBarry Smith 180c4aff060SBarry Smith .keywords: Python 181c4aff060SBarry Smith 182c4aff060SBarry Smith @*/ 1837087cfbeSBarry Smith PetscErrorCode PetscPythonInitialize(const char pyexe[],const char pylib[]) 184c4aff060SBarry Smith { 185c4aff060SBarry Smith PyObject *module = 0; 186c4aff060SBarry Smith PetscErrorCode ierr; 1876e111a19SKarl Rupp 188c4aff060SBarry Smith PetscFunctionBegin; 189c4aff060SBarry Smith if (PetscBeganPython) PetscFunctionReturn(0); 190c4aff060SBarry Smith /* Python executable */ 191c4aff060SBarry Smith if (pyexe && pyexe[0] != 0) { 192c4aff060SBarry Smith ierr = PetscStrncpy(PetscPythonExe,pyexe,sizeof(PetscPythonExe));CHKERRQ(ierr); 193c4aff060SBarry Smith } else { 194c4aff060SBarry Smith ierr = PetscPythonFindExecutable(PetscPythonExe);CHKERRQ(ierr); 195c4aff060SBarry Smith } 196c4aff060SBarry Smith /* Python dynamic library */ 197c4aff060SBarry Smith if (pylib && pylib[0] != 0) { 198c4aff060SBarry Smith ierr = PetscStrncpy(PetscPythonLib,pylib,sizeof(PetscPythonLib));CHKERRQ(ierr); 199c4aff060SBarry Smith } else { 200c4aff060SBarry Smith ierr = PetscPythonFindLibrary(PetscPythonExe,PetscPythonLib);CHKERRQ(ierr); 201c4aff060SBarry Smith } 202c4aff060SBarry Smith /* dynamically load Python library */ 203c4aff060SBarry Smith ierr = PetscPythonLoadLibrary(PetscPythonLib);CHKERRQ(ierr); 204c4aff060SBarry Smith /* initialize Python */ 205c4aff060SBarry Smith PetscBeganPython = PETSC_FALSE; 206c4aff060SBarry Smith if (!Py_IsInitialized()) { 2072f2e82b0SLisandro Dalcin static PetscBool registered = PETSC_FALSE; 2082f2e82b0SLisandro Dalcin const char *py_version; 2092f2e82b0SLisandro Dalcin PyObject *sys_path; 2102f2e82b0SLisandro Dalcin char path[PETSC_MAX_PATH_LEN] = { 0 }; 211a297a907SKarl Rupp 2122f2e82b0SLisandro Dalcin /* initialize Python */ 2132f2e82b0SLisandro Dalcin Py_InitializeEx(0); /* 0: do not install signal handlers */ 2142f2e82b0SLisandro Dalcin /* build 'sys.argv' list */ 2152f2e82b0SLisandro Dalcin py_version = Py_GetVersion(); 2169ac80d5eSLisandro Dalcin if (py_version[0] == '2') { 217*49a6f2e5SLisandro Dalcin int argc = 0; char *argv[1] = {NULL}; 2182f2e82b0SLisandro Dalcin PySys_SetArgv(argc,argv); 2192f2e82b0SLisandro Dalcin } 2202f2e82b0SLisandro Dalcin if (py_version[0] == '3') { 221*49a6f2e5SLisandro Dalcin int argc = 0; wchar_t *argv[1] = {NULL}; 222*49a6f2e5SLisandro Dalcin PySys_SetArgv(argc,argv); 2232f2e82b0SLisandro Dalcin } 2242f2e82b0SLisandro Dalcin /* add PETSC_LIB_DIR in front of 'sys.path' */ 2252f2e82b0SLisandro Dalcin sys_path = PySys_GetObject("path"); 2262f2e82b0SLisandro Dalcin if (sys_path) { 2272f2e82b0SLisandro Dalcin ierr = PetscStrreplace(PETSC_COMM_SELF,"${PETSC_LIB_DIR}",path,sizeof(path));CHKERRQ(ierr); 2282f2e82b0SLisandro Dalcin Py_DecRef(PyObject_CallMethod(sys_path,"insert","is",(int)0,(char*)path)); 2299ac80d5eSLisandro Dalcin } 230c4aff060SBarry Smith /* register finalizer */ 231c4aff060SBarry Smith if (!registered) { 232c4aff060SBarry Smith ierr = PetscRegisterFinalize(PetscPythonFinalize);CHKERRQ(ierr); 233c4aff060SBarry Smith registered = PETSC_TRUE; 234c4aff060SBarry Smith } 235c4aff060SBarry Smith PetscBeganPython = PETSC_TRUE; 236c4aff060SBarry Smith } 237c4aff060SBarry Smith /* import 'petsc4py.PETSc' module */ 238c4aff060SBarry Smith module = PyImport_ImportModule("petsc4py.PETSc"); 239c4aff060SBarry Smith if (module) { 240c4aff060SBarry Smith ierr = PetscInfo(0,"Python: successfully imported module 'petsc4py.PETSc'\n");CHKERRQ(ierr); 241a297a907SKarl Rupp 242c4aff060SBarry Smith Py_DecRef(module); module = 0; 243c4aff060SBarry Smith } else { 244e0ab9aedSLisandro Dalcin PetscPythonPrintError(); 245e32f2f54SBarry Smith SETERRQ(PETSC_COMM_SELF,PETSC_ERR_PLIB,"Python: could not import module 'petsc4py.PETSc', perhaps your PYTHONPATH does not contain it\n"); 246c4aff060SBarry Smith } 247c4aff060SBarry Smith PetscFunctionReturn(0); 248c4aff060SBarry Smith } 249c4aff060SBarry Smith 250e0ab9aedSLisandro Dalcin /*@C 251e0ab9aedSLisandro Dalcin PetscPythonPrintError - Print Python errors. 252e0ab9aedSLisandro Dalcin 253e0ab9aedSLisandro Dalcin Level: developer 254e0ab9aedSLisandro Dalcin 255e0ab9aedSLisandro Dalcin .keywords: Python 256e0ab9aedSLisandro Dalcin 257e0ab9aedSLisandro Dalcin @*/ 2587087cfbeSBarry Smith PetscErrorCode PetscPythonPrintError(void) 259e0ab9aedSLisandro Dalcin { 260e0ab9aedSLisandro Dalcin PyObject *exc=0, *val=0, *tb=0; 2616e111a19SKarl Rupp 262e0ab9aedSLisandro Dalcin PetscFunctionBegin; 263e0ab9aedSLisandro Dalcin if (!PetscBeganPython) PetscFunctionReturn(0); 264e0ab9aedSLisandro Dalcin if (!PyErr_Occurred()) PetscFunctionReturn(0); 265e0ab9aedSLisandro Dalcin PyErr_Fetch(&exc,&val,&tb); 266e0ab9aedSLisandro Dalcin PyErr_NormalizeException(&exc,&val,&tb); 267e0ab9aedSLisandro Dalcin PyErr_Display(exc ? exc : Py_None, 268e0ab9aedSLisandro Dalcin val ? val : Py_None, 269e0ab9aedSLisandro Dalcin tb ? tb : Py_None); 270e0ab9aedSLisandro Dalcin PyErr_Restore(exc,val,tb); 271e0ab9aedSLisandro Dalcin PetscFunctionReturn(0); 272e0ab9aedSLisandro Dalcin } 273e0ab9aedSLisandro Dalcin 274c4aff060SBarry Smith /* ---------------------------------------------------------------- */ 2755180491cSLisandro Dalcin 2768cc058d9SJed Brown PETSC_EXTERN PetscErrorCode (*PetscPythonMonitorSet_C)(PetscObject,const char[]); 2770298fd71SBarry Smith PetscErrorCode (*PetscPythonMonitorSet_C)(PetscObject,const char[]) = NULL; 2785180491cSLisandro Dalcin 2795180491cSLisandro Dalcin /*@C 2805180491cSLisandro Dalcin PetscPythonMonitorSet - Set Python monitor 2815180491cSLisandro Dalcin 2825180491cSLisandro Dalcin Level: developer 2835180491cSLisandro Dalcin 2845180491cSLisandro Dalcin .keywords: Python 2855180491cSLisandro Dalcin 2865180491cSLisandro Dalcin @*/ 2875180491cSLisandro Dalcin PetscErrorCode PetscPythonMonitorSet(PetscObject obj, const char url[]) 2885180491cSLisandro Dalcin { 2895180491cSLisandro Dalcin PetscErrorCode ierr; 2906e111a19SKarl Rupp 2915180491cSLisandro Dalcin PetscFunctionBegin; 2925180491cSLisandro Dalcin PetscValidHeader(obj,1); 2935180491cSLisandro Dalcin PetscValidCharPointer(url,2); 2946c4ed002SBarry Smith if (!PetscPythonMonitorSet_C) { 2950298fd71SBarry Smith ierr = PetscPythonInitialize(NULL,NULL);CHKERRQ(ierr); 2966c4ed002SBarry Smith if (!PetscPythonMonitorSet_C) SETERRQ(PETSC_COMM_SELF,PETSC_ERR_LIB,"Couldn't initialize Python support for monitors"); 2975180491cSLisandro Dalcin } 2985180491cSLisandro Dalcin ierr = PetscPythonMonitorSet_C(obj,url);CHKERRQ(ierr); 2995180491cSLisandro Dalcin PetscFunctionReturn(0); 3005180491cSLisandro Dalcin } 3015180491cSLisandro Dalcin 3025180491cSLisandro Dalcin /* ---------------------------------------------------------------- */ 303