Skip to content

Commit

Permalink
Merge pull request #373 from LLNL/bug_mcm86_26apr24_dir_dbtoc
Browse files Browse the repository at this point in the history
Fix dir on dbtoc
  • Loading branch information
markcmiller86 authored Apr 29, 2024
2 parents 085a68a + 959b533 commit c9f584c
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 49 deletions.
1 change: 1 addition & 0 deletions src/silo/silo_ns.c
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ reflect those of the United States Government or Lawrence Livermore
National Security, LLC, and shall not be used for advertising or
product endorsement purposes.
*/
#include <ctype.h>
#include <stdarg.h>
#include <stdlib.h>
#include <errno.h>
Expand Down
103 changes: 54 additions & 49 deletions tools/python/pydbtoc.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,8 @@

#include "pydbtoc.h"
#include "pysilo.h"
#include <stdlib.h>
#include <string.h>

// ****************************************************************************
// Method: DBtoc_dealloc
Expand Down Expand Up @@ -240,8 +242,14 @@ GET_FUNC_DEFS(mrgvar);
GET_FUNC_DEFS(groupelmap);
GET_FUNC_DEFS(obj);

#define GET_FUNC_N(nm) if (!strcmp(name, "n" #nm)) return DBtoc_GetN ## nm(self, NULL);
#define GET_FUNC_NAMES(nm) if (!strcmp(name, #nm "_names")) return DBtoc_Get ## nm ## names(self, NULL);
#define HANDLE_ENTRY(nm) \
if (!strcmp(name, "n" #nm)) return DBtoc_GetN ## nm(self, NULL); \
else if (!strcmp(name, #nm "_names")) return DBtoc_Get ## nm ## names(self, NULL); \
else if (!strcmp(name, "__dict__")) \
{ \
PyDict_SetItem(__dict__result, PyString_FromString("n" #nm), DBtoc_GetN ## nm(self, NULL)); \
PyDict_SetItem(__dict__result, PyString_FromString(#nm "_names"), DBtoc_Get ## nm ## names(self, NULL)); \
}

// ****************************************************************************
// Method: DBtoc_getattr
Expand All @@ -261,57 +269,54 @@ GET_FUNC_DEFS(obj);
// ****************************************************************************
static PyObject *DBtoc_getattr(PyObject *self, char *name)
{
GET_FUNC_N(var);
GET_FUNC_N(dir);
GET_FUNC_N(curve);
GET_FUNC_N(multimesh);
GET_FUNC_N(multivar);
GET_FUNC_N(multimat);
GET_FUNC_N(multimatspecies);
GET_FUNC_N(csgmesh);
GET_FUNC_N(csgvar);
GET_FUNC_N(defvars);
GET_FUNC_N(qmesh);
GET_FUNC_N(qvar);
GET_FUNC_N(ucdmesh);
GET_FUNC_N(ucdvar);
GET_FUNC_N(ptmesh);
GET_FUNC_N(ptvar);
GET_FUNC_N(mat);
GET_FUNC_N(matspecies);
GET_FUNC_N(array);
GET_FUNC_N(mrgtree);
GET_FUNC_N(mrgvar);
GET_FUNC_N(groupelmap);
GET_FUNC_N(obj);
PyObject *__dict__result = strcmp(name, "__dict__") ? 0 : PyDict_New();

HANDLE_ENTRY(var);
HANDLE_ENTRY(dir);
HANDLE_ENTRY(curve);
HANDLE_ENTRY(multimesh);
HANDLE_ENTRY(multivar);
HANDLE_ENTRY(multimat);
HANDLE_ENTRY(multimatspecies);
HANDLE_ENTRY(csgmesh);
HANDLE_ENTRY(csgvar);
HANDLE_ENTRY(defvars);
HANDLE_ENTRY(qmesh);
HANDLE_ENTRY(qvar);
HANDLE_ENTRY(ucdmesh);
HANDLE_ENTRY(ucdvar);
HANDLE_ENTRY(ptmesh);
HANDLE_ENTRY(ptvar);
HANDLE_ENTRY(mat);
HANDLE_ENTRY(matspecies);
HANDLE_ENTRY(array);
HANDLE_ENTRY(mrgtree);
HANDLE_ENTRY(mrgvar);
HANDLE_ENTRY(groupelmap);
HANDLE_ENTRY(obj);

GET_FUNC_NAMES(var);
GET_FUNC_NAMES(dir);
GET_FUNC_NAMES(curve);
GET_FUNC_NAMES(multimesh);
GET_FUNC_NAMES(multivar);
GET_FUNC_NAMES(multimat);
GET_FUNC_NAMES(multimatspecies);
GET_FUNC_NAMES(csgmesh);
GET_FUNC_NAMES(csgvar);
GET_FUNC_NAMES(defvars);
GET_FUNC_NAMES(qmesh);
GET_FUNC_NAMES(qvar);
GET_FUNC_NAMES(ucdmesh);
GET_FUNC_NAMES(ucdvar);
GET_FUNC_NAMES(ptmesh);
GET_FUNC_NAMES(ptvar);
GET_FUNC_NAMES(mat);
GET_FUNC_NAMES(matspecies);
GET_FUNC_NAMES(array);
GET_FUNC_NAMES(mrgtree);
GET_FUNC_NAMES(mrgvar);
GET_FUNC_NAMES(groupelmap);
GET_FUNC_NAMES(obj);
if (!strcmp(name, "__dict__"))
return __dict__result;

PyErr_SetString(PyExc_AttributeError, "attribute not found");
return 0;
}

static PyObject *DBtoc_getattro(PyObject *self, PyObject *o)
{
PyObject *retval;
char *dupname;
char const *name = PyString_AsString(o);
if (!name) {
PyErr_SetString(PyExc_TypeError, "Could not convert argument C string");
return NULL;
}
dupname = strdup(name);
retval = DBtoc_getattr(self, dupname);
free(dupname);
return retval;
}

// ****************************************************************************
// DBtoc Python Type Object
//
Expand Down Expand Up @@ -352,7 +357,7 @@ PyTypeObject DBtocType =
0, // tp_hash
0, // tp_call
(reprfunc)DBtoc_str, // tp_str
0, // tp_getattro
(getattrofunc)DBtoc_getattro, // tp_getattro
0, // tp_setattro
0, // tp_as_buffer
0, // tp_flags
Expand Down

0 comments on commit c9f584c

Please sign in to comment.