diff options
author | elie <elie> | 2015-05-31 21:39:01 +0000 |
---|---|---|
committer | elie <elie> | 2015-05-31 21:39:01 +0000 |
commit | 97ad72efc27f8bdc9f63aa2dc074a9de9f4122a6 (patch) | |
tree | ec4279bf884a562d15c81225ae551f0bae675995 | |
parent | ef7cd19afa50ea3bfdc7eb41bef1fb277de8760e (diff) | |
download | pysnmp-97ad72efc27f8bdc9f63aa2dc074a9de9f4122a6.tar.gz |
catch and report possible MIB compilation errors
-rw-r--r-- | pysnmp/smi/builder.py | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/pysnmp/smi/builder.py b/pysnmp/smi/builder.py index a019d03..4c0ce9c 100644 --- a/pysnmp/smi/builder.py +++ b/pysnmp/smi/builder.py @@ -320,8 +320,11 @@ class MibBuilder: except error.MibNotFoundError: if self.__mibCompiler: debug.logger & debug.flagBld and debug.logger('loadModules: calling MIB compiler for %s' % modName) - self.__mibCompiler.compile(modName) - # in case this missing MIB becomes available + status = self.__mibCompiler.compile(modName) + errs = '; '.join([str(x.error) for x in status.values() if x in ('failed', 'missing')]) + if errs: + raise error.MibNotFoundError('%s compilation error(s): %s' % (modName, errs)) + # compilation suceeded, MIB might load now self.loadModule(modName, **userCtx) return self |