|
Packit |
022b05 |
/*
|
|
Packit |
022b05 |
* dump-perl.c --
|
|
Packit |
022b05 |
*
|
|
Packit |
022b05 |
* Operations to dump SMIng module information in Perl format.
|
|
Packit |
022b05 |
*
|
|
Packit |
022b05 |
* Copyright (c) 2000 Frank Strauss, Technical University of Braunschweig.
|
|
Packit |
022b05 |
* Copyright (c) 2000 J. Schoenwaelder, Technical University of Braunschweig.
|
|
Packit |
022b05 |
* Copyright (c) 2000 WideAwake Ltd.
|
|
Packit |
022b05 |
* Copyright (c) 2000 Martin Schulz martin.schulz@myrealbox.com
|
|
Packit |
022b05 |
*
|
|
Packit |
022b05 |
* See the file "COPYING" for information on usage and redistribution
|
|
Packit |
022b05 |
* of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
Packit |
022b05 |
*
|
|
Packit |
022b05 |
* @(#) $Id: dump-perl.c 8090 2008-04-18 12:56:29Z strauss $
|
|
Packit |
022b05 |
*/
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
/*
|
|
Packit |
022b05 |
* TODO:
|
|
Packit |
022b05 |
*
|
|
Packit |
022b05 |
*/
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
#include <config.h>
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
#include <stdlib.h>
|
|
Packit |
022b05 |
#include <stdio.h>
|
|
Packit |
022b05 |
#include <stdarg.h>
|
|
Packit |
022b05 |
#include <string.h>
|
|
Packit |
022b05 |
#include <ctype.h>
|
|
Packit |
022b05 |
#include <time.h>
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
#include "smi.h"
|
|
Packit |
022b05 |
#include "smidump.h"
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
#define INDENT 4 /* indent factor */
|
|
Packit |
022b05 |
#define INDENTVALUE 20 /* column to start values, except multiline */
|
|
Packit |
022b05 |
#define INDENTTEXTS 4 /* column to start multiline texts */
|
|
Packit |
022b05 |
#define INDENTMAX 64 /* max column to fill, break lines otherwise */
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
typedef struct PerlEscape {
|
|
Packit |
022b05 |
char character;
|
|
Packit |
022b05 |
char *escape;
|
|
Packit |
022b05 |
} PerlEscape;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static PerlEscape perlEscapes [] = {
|
|
Packit |
022b05 |
{ '\'', "\\'" },
|
|
Packit |
022b05 |
{ '\\', "\\\\" },
|
|
Packit |
022b05 |
{ 0, NULL }
|
|
Packit |
022b05 |
};
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static int current_column = 0;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static char* currentModuleName = NULL;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static char *getStringLanguage(SmiLanguage lang)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
return
|
|
Packit |
022b05 |
(lang == SMI_LANGUAGE_SMIV1) ? "SMIv1" :
|
|
Packit |
022b05 |
(lang == SMI_LANGUAGE_SMIV2) ? "SMIv2" :
|
|
Packit |
022b05 |
(lang == SMI_LANGUAGE_SMING) ? "SMIng" :
|
|
Packit |
022b05 |
NULL;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static char *getStringStatus(SmiStatus status)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
return
|
|
Packit |
022b05 |
(status == SMI_STATUS_CURRENT) ? "current" :
|
|
Packit |
022b05 |
(status == SMI_STATUS_DEPRECATED) ? "deprecated" :
|
|
Packit |
022b05 |
(status == SMI_STATUS_OBSOLETE) ? "obsolete" :
|
|
Packit |
022b05 |
(status == SMI_STATUS_MANDATORY) ? "current" :
|
|
Packit |
022b05 |
(status == SMI_STATUS_OPTIONAL) ? "current" :
|
|
Packit |
022b05 |
"<unknown>";
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static char *getAccessString(SmiAccess access)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
return
|
|
Packit |
022b05 |
(access == SMI_ACCESS_NOT_ACCESSIBLE) ? "noaccess" :
|
|
Packit |
022b05 |
(access == SMI_ACCESS_NOTIFY) ? "notifyonly" :
|
|
Packit |
022b05 |
(access == SMI_ACCESS_READ_ONLY) ? "readonly" :
|
|
Packit |
022b05 |
(access == SMI_ACCESS_READ_WRITE) ? "readwrite" :
|
|
Packit |
022b05 |
"<unknown>";
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static char *getStringBasetype(SmiBasetype basetype)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
return
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_UNKNOWN) ? "<UNKNOWN>" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_OCTETSTRING) ? "OctetString" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_OBJECTIDENTIFIER) ? "ObjectIdentifier" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_UNSIGNED32) ? "Unsigned32" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_INTEGER32) ? "Integer32" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_UNSIGNED64) ? "Unsigned64" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_INTEGER64) ? "Integer64" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_FLOAT32) ? "Float32" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_FLOAT64) ? "Float64" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_FLOAT128) ? "Float128" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_ENUM) ? "Enumeration" :
|
|
Packit |
022b05 |
(basetype == SMI_BASETYPE_BITS) ? "Bits" :
|
|
Packit |
022b05 |
"<unknown>";
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static char *getTimeString(time_t t)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
static char s[27];
|
|
Packit |
022b05 |
struct tm *tm;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
tm = gmtime(&t);
|
|
Packit |
022b05 |
sprintf(s, "%04d-%02d-%02d %02d:%02d",
|
|
Packit |
022b05 |
tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday,
|
|
Packit |
022b05 |
tm->tm_hour, tm->tm_min);
|
|
Packit |
022b05 |
return s;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprint(FILE *f, char *fmt, ...)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
va_list ap;
|
|
Packit |
022b05 |
char *s;
|
|
Packit |
022b05 |
char *p;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
va_start(ap, fmt);
|
|
Packit |
022b05 |
current_column += smiVasprintf(&s, fmt, ap);
|
|
Packit |
022b05 |
va_end(ap);
|
|
Packit |
022b05 |
fputs(s, f);
|
|
Packit |
022b05 |
if ((p = strrchr(s, '\n'))) {
|
|
Packit |
022b05 |
current_column = strlen(p) - 1;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
free(s);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintSegment(FILE *f, int column, char *string, int length)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
fprint(f, "%*c%s", column, ' ', string);
|
|
Packit |
022b05 |
if (length) {
|
|
Packit |
022b05 |
fprint(f, "%*c", length - strlen(string) - column, ' ');
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintMultilineString(FILE *f, int column, const char *s)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
int i, j, len;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
#ifdef INDENTTEXTS
|
|
Packit |
022b05 |
fprintSegment(f, column + INDENTTEXTS, "", 0);
|
|
Packit |
022b05 |
#endif
|
|
Packit |
022b05 |
if (s) {
|
|
Packit |
022b05 |
fputs ("'", f);
|
|
Packit |
022b05 |
current_column += 3;
|
|
Packit |
022b05 |
len = strlen(s);
|
|
Packit |
022b05 |
for (i=0; i < len; i++) {
|
|
Packit |
022b05 |
for (j = 0; perlEscapes[j].character; j++) {
|
|
Packit |
022b05 |
if (perlEscapes[j].character == s[i]) break;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (perlEscapes[j].character) {
|
|
Packit |
022b05 |
fputs(perlEscapes[j].escape, f);
|
|
Packit |
022b05 |
current_column += strlen(perlEscapes[j].escape);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
putc(s[i], f);
|
|
Packit |
022b05 |
current_column++;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (s[i] == '\n') {
|
|
Packit |
022b05 |
current_column = 0;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fputs ("'", f);
|
|
Packit |
022b05 |
current_column += 3;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
current_column++;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static char *getValueString(SmiValue *valuePtr, SmiType *typePtr)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
static char s[1024];
|
|
Packit |
022b05 |
char ss[9];
|
|
Packit |
022b05 |
int n;
|
|
Packit |
022b05 |
unsigned int i;
|
|
Packit |
022b05 |
SmiNamedNumber *nn;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
s[0] = 0;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
switch (valuePtr->basetype) {
|
|
Packit |
022b05 |
case SMI_BASETYPE_UNSIGNED32:
|
|
Packit |
022b05 |
sprintf(s, "%lu", valuePtr->value.unsigned32);
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_INTEGER32:
|
|
Packit |
022b05 |
sprintf(s, "%ld", valuePtr->value.integer32);
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_UNSIGNED64:
|
|
Packit |
022b05 |
sprintf(s, UINT64_FORMAT, valuePtr->value.unsigned64);
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_INTEGER64:
|
|
Packit |
022b05 |
sprintf(s, INT64_FORMAT, valuePtr->value.integer64);
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_FLOAT32:
|
|
Packit |
022b05 |
case SMI_BASETYPE_FLOAT64:
|
|
Packit |
022b05 |
case SMI_BASETYPE_FLOAT128:
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_ENUM:
|
|
Packit |
022b05 |
for (nn = smiGetFirstNamedNumber(typePtr); nn;
|
|
Packit |
022b05 |
nn = smiGetNextNamedNumber(nn)) {
|
|
Packit |
022b05 |
if (nn->value.value.unsigned32 == valuePtr->value.unsigned32)
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (nn) {
|
|
Packit |
022b05 |
sprintf(s, "%s", nn->name);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
sprintf(s, "%ld", valuePtr->value.integer32);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_OCTETSTRING:
|
|
Packit |
022b05 |
for (i = 0; i < valuePtr->len; i++) {
|
|
Packit |
022b05 |
if (!isprint((int)valuePtr->value.ptr[i])) break;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (i == valuePtr->len) {
|
|
Packit |
022b05 |
sprintf(s, "%s", valuePtr->value.ptr);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
sprintf(s, "0x%*s", 2 * valuePtr->len, "");
|
|
Packit |
022b05 |
for (i=0; i < valuePtr->len; i++) {
|
|
Packit |
022b05 |
sprintf(ss, "%02x", valuePtr->value.ptr[i]);
|
|
Packit |
022b05 |
strncpy(&s[2+2*i], ss, 2);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_BITS:
|
|
Packit |
022b05 |
sprintf(s, "(");
|
|
Packit |
022b05 |
for (i = 0, n = 0; i < valuePtr->len * 8; i++) {
|
|
Packit |
022b05 |
if (valuePtr->value.ptr[i/8] & (1 << (7-(i%8)))) {
|
|
Packit |
022b05 |
if (n)
|
|
Packit |
022b05 |
sprintf(&s[strlen(s)], ", ");
|
|
Packit |
022b05 |
n++;
|
|
Packit |
022b05 |
for (nn = smiGetFirstNamedNumber(typePtr); nn;
|
|
Packit |
022b05 |
nn = smiGetNextNamedNumber(nn)) {
|
|
Packit |
022b05 |
if (nn->value.value.unsigned32 == i)
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (nn) {
|
|
Packit |
022b05 |
sprintf(&s[strlen(s)], "%s", nn->name);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
sprintf(s, "%d", i);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
sprintf(&s[strlen(s)], ")");
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_UNKNOWN:
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_POINTER:
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_BASETYPE_OBJECTIDENTIFIER:
|
|
Packit |
022b05 |
for (i = 0; i < valuePtr->len; i++) {
|
|
Packit |
022b05 |
sprintf(&s[strlen(s)], i ? ".%u" : "%u", valuePtr->value.oid[i]);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
return s;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintNodeStartTag(FILE *f, int indent, const char *tag,
|
|
Packit |
022b05 |
SmiNode *smiNode)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
unsigned int i;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
fprint(f, "{\n", smiNode->name);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"name\" => \"%s\",\n", smiNode->name);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"type\" => \"%s\",\n", tag);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"module\" => \"%s\",\n", currentModuleName);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"oid\" => \"");
|
|
Packit |
022b05 |
for (i = 0; i < smiNode->oidlen; i++) {
|
|
Packit |
022b05 |
fprint(f, i ? ".%u" : "%u", smiNode->oid[i]);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprint(f, "\"");
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (smiNode->create) {
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "\"create\" => \"true\"", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (smiNode->status != SMI_STATUS_UNKNOWN) {
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"status\" => \"%s\"", getStringStatus(smiNode->status));
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (smiNode->implied) {
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "\"implied\" => \"true\"", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintNodeEndTag(FILE *f, int indent, const char *tag,
|
|
Packit |
022b05 |
const char *name)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
fprint(f, "}, # %s\n", name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintRanges(FILE *f, int indent, SmiType *smiType)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiRange *range;
|
|
Packit |
022b05 |
SmiValue min, max;
|
|
Packit |
022b05 |
int rc;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (! smiGetFirstRange(smiType)) {
|
|
Packit |
022b05 |
return;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"ranges\" => (\n", 0);
|
|
Packit |
022b05 |
for (range = smiGetFirstRange(smiType);
|
|
Packit |
022b05 |
range;
|
|
Packit |
022b05 |
range = smiGetNextRange(range)) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "{\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"min\" => \"%s\",\n",
|
|
Packit |
022b05 |
getValueString(&range->minValue, smiType));
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"max\" => \"%s\"\n",
|
|
Packit |
022b05 |
getValueString(&range->maxValue, smiType));
|
|
Packit |
022b05 |
fprintSegment(f, indent, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintSegment(f, indent, "),\n", 0);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
rc = smiGetMinMaxRange(smiType, &min, &max;;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (rc == 0
|
|
Packit |
022b05 |
&& min.basetype != SMI_BASETYPE_UNKNOWN
|
|
Packit |
022b05 |
&& max.basetype != SMI_BASETYPE_UNKNOWN) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"range\" => {\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"min\" => \"%s\",\n",
|
|
Packit |
022b05 |
getValueString(&min, smiType));
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"max\" => \"%s\"\n",
|
|
Packit |
022b05 |
getValueString(&max, smiType));
|
|
Packit |
022b05 |
fprintSegment(f, indent, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintNamedNumbers(FILE *f, int indent, SmiType *smiType)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiNamedNumber *nn;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if ((smiType->basetype != SMI_BASETYPE_ENUM) &&
|
|
Packit |
022b05 |
(smiType->basetype != SMI_BASETYPE_BITS)) {
|
|
Packit |
022b05 |
return;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for (nn = smiGetFirstNamedNumber(smiType);
|
|
Packit |
022b05 |
nn;
|
|
Packit |
022b05 |
nn = smiGetNextNamedNumber(nn)) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"", 0);
|
|
Packit |
022b05 |
fprint(f, "%s\" => ", nn->name);
|
|
Packit |
022b05 |
fprint(f, "\"%s\",\n", getValueString(&nn->value, smiType));
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintValue(FILE *f, int indent, SmiValue *smiValue,
|
|
Packit |
022b05 |
SmiType *smiType)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
if (smiType && smiValue && smiValue->basetype != SMI_BASETYPE_UNKNOWN) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"DEFVAL\" => ", 0);
|
|
Packit |
022b05 |
fprint(f, "\"%s\"", getValueString(smiValue, smiType));
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintDescription(FILE *f, int indent, const char *description)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
if (description) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"description\" =>\n", 0);
|
|
Packit |
022b05 |
fprintMultilineString(f, indent, description);
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintReference(FILE *f, int indent, const char *reference)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
if (reference) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"reference>\" =>\n", 0);
|
|
Packit |
022b05 |
fprintMultilineString(f, indent, reference);
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintFormat(FILE *f, int indent, const char *format)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
if (format) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"DISPLAY-HINT\" => \"%s\",\n", format);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintUnits(FILE *f, int indent, const char *units)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
if (units) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"UNITS\" => \"%s\",\n", units);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintAccess(FILE *f, int indent, SmiAccess smiAccess)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
if (smiAccess != SMI_ACCESS_UNKNOWN) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"access\" => \"%s\",\n", getAccessString(smiAccess));
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintElementList(FILE *f, int indent, const char *tag,
|
|
Packit |
022b05 |
SmiElement *smiElement, int asArray)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiModule *smiModule;
|
|
Packit |
022b05 |
SmiNode *smiNode;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for (; smiElement; smiElement = smiGetNextElement(smiElement)) {
|
|
Packit |
022b05 |
smiNode = smiGetElementNode(smiElement);
|
|
Packit |
022b05 |
smiModule = smiGetNodeModule(smiNode);
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
if (tag) {
|
|
Packit |
022b05 |
if (asArray) {
|
|
Packit |
022b05 |
fprint(f, "{\n");
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"name\" => \"%s\",\n", smiNode->name);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
fprint(f, "\"%s\" => {\n", smiNode->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"type\" => \"%s\",\n", tag);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"module\" => \"%s\"\n", smiModule->name);
|
|
Packit |
022b05 |
fprintSegment(f, indent, "},\n", 0);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
if (asArray) {
|
|
Packit |
022b05 |
fprint(f, "{ \"module\" => \"%s\", ", smiModule->name);
|
|
Packit |
022b05 |
fprint(f, "\"name\" => \"%s\" },\n", smiNode->name);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
fprint(f, "\"%s\" => \"%s\",\n", smiNode->name, smiModule->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintIndexModule(FILE *f, int indent, const char *modname,
|
|
Packit |
022b05 |
const char *nodename, const char *indexkind)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"%s\" => {\n", indexkind);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"module\" => \"%s\",\n", modname);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"name\" => \"%s\",\n", nodename);
|
|
Packit |
022b05 |
fprintSegment(f, indent, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintIndex(FILE *f, int indent, SmiNode *smiNode)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiNode *relatedNode;
|
|
Packit |
022b05 |
SmiModule *relatedModule = NULL;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (smiNode->implied) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"indeximplied\" => \"true\",\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
relatedNode = smiGetRelatedNode(smiNode);
|
|
Packit |
022b05 |
if (relatedNode) {
|
|
Packit |
022b05 |
relatedModule = smiGetNodeModule(relatedNode);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
switch (smiNode->indexkind) {
|
|
Packit |
022b05 |
case SMI_INDEX_INDEX:
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"index\" => [\n", 0);
|
|
Packit |
022b05 |
fprintElementList(f, indent + INDENT, NULL,
|
|
Packit |
022b05 |
smiGetFirstElement(smiNode), 1);
|
|
Packit |
022b05 |
fprintSegment(f, indent, "], #index\n", 0);
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_INDEX_AUGMENT:
|
|
Packit |
022b05 |
if (relatedNode && relatedModule) {
|
|
Packit |
022b05 |
fprintIndexModule(f, indent, relatedModule->name,
|
|
Packit |
022b05 |
relatedNode->name, "augments");
|
|
Packit |
022b05 |
} /* TODO: else print error */
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_INDEX_REORDER:
|
|
Packit |
022b05 |
if (relatedNode && relatedModule) {
|
|
Packit |
022b05 |
fprintIndexModule(f, indent, relatedModule->name,
|
|
Packit |
022b05 |
relatedNode->name, "reorders");
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"index\" => [\n", 0);
|
|
Packit |
022b05 |
fprintElementList(f, indent + INDENT, NULL,
|
|
Packit |
022b05 |
smiGetFirstElement(smiNode), 1);
|
|
Packit |
022b05 |
fprintSegment(f, indent, "], #index\n", 0);
|
|
Packit |
022b05 |
} /* TODO: else print error */
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_INDEX_SPARSE:
|
|
Packit |
022b05 |
if (relatedNode && relatedModule) {
|
|
Packit |
022b05 |
fprintIndexModule(f, indent, relatedModule->name,
|
|
Packit |
022b05 |
relatedNode->name, "sparse");
|
|
Packit |
022b05 |
} /* TODO: else print error */
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_INDEX_EXPAND:
|
|
Packit |
022b05 |
if (relatedNode && relatedModule) {
|
|
Packit |
022b05 |
fprintIndexModule(f, indent, relatedModule->name,
|
|
Packit |
022b05 |
relatedNode->name, "expands");
|
|
Packit |
022b05 |
} /* TODO: else print error */
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
case SMI_INDEX_UNKNOWN:
|
|
Packit |
022b05 |
break;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintModule(FILE *f, SmiModule *smiModule)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiRevision *smiRevision;
|
|
Packit |
022b05 |
SmiNode *smiNode;
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
int there_were_revisions = 0;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
currentModuleName = smiModule->name;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (smiModule->organization) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"organization\" =>", INDENTVALUE);
|
|
Packit |
022b05 |
fprint(f, "\n");
|
|
Packit |
022b05 |
fprintMultilineString(f, INDENT, smiModule->organization);
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (smiModule->contactinfo) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"contact\" =>", INDENTVALUE);
|
|
Packit |
022b05 |
fprint(f, "\n");
|
|
Packit |
022b05 |
fprintMultilineString(f, INDENT, smiModule->contactinfo);
|
|
Packit |
022b05 |
fprint(f, ",\n");
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintDescription(f, INDENT, smiModule->description);
|
|
Packit |
022b05 |
fprintReference(f, INDENT, smiModule->reference);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for(i = 0, smiRevision = smiGetFirstRevision(smiModule);
|
|
Packit |
022b05 |
smiRevision; smiRevision = smiGetNextRevision(smiRevision)) {
|
|
Packit |
022b05 |
if (i == 0) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"revisions\" => [\n", 0);
|
|
Packit |
022b05 |
there_were_revisions = 1;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintSegment(f, 2 * INDENT, "{\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, 3 * INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"date\" => \"%s\",\n",
|
|
Packit |
022b05 |
getTimeString(smiRevision->date));
|
|
Packit |
022b05 |
fprintDescription(f, 3 * INDENT, smiRevision->description);
|
|
Packit |
022b05 |
fprintSegment(f, 2 * INDENT, "},\n", 0);
|
|
Packit |
022b05 |
i++;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (there_were_revisions) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "],\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
smiNode = smiGetModuleIdentityNode(smiModule);
|
|
Packit |
022b05 |
if (smiNode) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"identity\" => \"%s\",\n", smiNode->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprint(f, "\n");
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintImports(FILE *f, SmiModule *smiModule)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiImport *smiImport;
|
|
Packit |
022b05 |
SmiIdentifier lastModule = NULL;
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for (i = 0, smiImport = smiGetFirstImport(smiModule);
|
|
Packit |
022b05 |
smiImport;
|
|
Packit |
022b05 |
i++,
|
|
Packit |
022b05 |
smiImport = smiGetNextImport(smiImport)) {
|
|
Packit |
022b05 |
if (i == 0) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"imports\" => [\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (smiImport->module == NULL)
|
|
Packit |
022b05 |
continue;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if ( lastModule == NULL || strcmp(lastModule, smiImport->module)) {
|
|
Packit |
022b05 |
if ( lastModule ) {
|
|
Packit |
022b05 |
fprintSegment(f, 3 * INDENT, "]\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, 2 * INDENT, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintSegment(f, 2 * INDENT, "{\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, 3 * INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"module\" => \"%s\",\n",
|
|
Packit |
022b05 |
smiImport->module);
|
|
Packit |
022b05 |
fprintSegment(f, 3 * INDENT, "\"names\" => [\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintSegment(f, 4 * INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"%s\",\n", smiImport->name);
|
|
Packit |
022b05 |
lastModule = smiImport->module;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (lastModule) {
|
|
Packit |
022b05 |
fprintSegment(f, 3 * INDENT, "],\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, 2 * INDENT, "}\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "], # imports\n\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintTypedef(FILE *f, int indent, SmiType *smiType)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiModule *parentModule;
|
|
Packit |
022b05 |
SmiType *parentType;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
if (smiType->name) {
|
|
Packit |
022b05 |
fprint(f, "\"%s\" => ", smiType->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprint(f, "{\n");
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"basetype\" => \"%s\",\n",
|
|
Packit |
022b05 |
getStringBasetype(smiType->basetype));
|
|
Packit |
022b05 |
if (smiType->name && smiType->status != SMI_STATUS_UNKNOWN) {
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"status\" => \"%s\",\n", getStringStatus(smiType->status));
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
parentType = smiGetParentType(smiType);
|
|
Packit |
022b05 |
parentModule = smiGetTypeModule(parentType);
|
|
Packit |
022b05 |
if (parentType && parentModule && strlen(parentModule->name)) {
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "\"parent\" => {\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, indent + (2 * INDENT), "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"module\" => \"%s\",\n", parentModule->name);
|
|
Packit |
022b05 |
fprintSegment(f, indent + (2 * INDENT), "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"name\" => \"%s\",\n", parentType->name);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintRanges(f, indent + INDENT, smiType);
|
|
Packit |
022b05 |
fprintNamedNumbers(f, indent + INDENT, smiType);
|
|
Packit |
022b05 |
fprintValue(f, indent + INDENT, &smiType->value, smiType);
|
|
Packit |
022b05 |
fprintFormat(f, indent + INDENT, smiType->format);
|
|
Packit |
022b05 |
fprintUnits(f, indent + INDENT, smiType->units);
|
|
Packit |
022b05 |
fprintDescription(f, indent + INDENT, smiType->description);
|
|
Packit |
022b05 |
fprintReference(f, indent + INDENT, smiType->reference);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent, "},", 0);
|
|
Packit |
022b05 |
if (smiType->name) {
|
|
Packit |
022b05 |
fprint(f, " # %s\n", smiType->name);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
fprint(f, "\n", smiType->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintTypedefs(FILE *f, SmiModule *smiModule)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
SmiType *smiType;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for(i = 0, smiType = smiGetFirstType(smiModule);
|
|
Packit |
022b05 |
smiType;
|
|
Packit |
022b05 |
i++, smiType = smiGetNextType(smiType)) {
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i == 0) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"typedefs\" => {\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintTypedef(f, 2 * INDENT, smiType);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "}, # typedefs\n\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintNode(FILE *f, int indent, SmiNode *smiNode,
|
|
Packit |
022b05 |
SmiNode *lastSmiNode)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiModule *smiModule;
|
|
Packit |
022b05 |
SmiType *smiType;
|
|
Packit |
022b05 |
char *tag = NULL;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (smiNode->nodekind == SMI_NODEKIND_NODE) {
|
|
Packit |
022b05 |
tag = "node";
|
|
Packit |
022b05 |
} else if (smiNode->nodekind == SMI_NODEKIND_CAPABILITIES) {
|
|
Packit |
022b05 |
tag = "capabilities";
|
|
Packit |
022b05 |
} else if (smiNode->nodekind == SMI_NODEKIND_TABLE) {
|
|
Packit |
022b05 |
tag = "table";
|
|
Packit |
022b05 |
} else if (smiNode->nodekind == SMI_NODEKIND_ROW) {
|
|
Packit |
022b05 |
/* indent += INDENT; */
|
|
Packit |
022b05 |
tag = "row";
|
|
Packit |
022b05 |
} else if (smiNode->nodekind == SMI_NODEKIND_COLUMN) {
|
|
Packit |
022b05 |
/* indent += 2 * INDENT; */
|
|
Packit |
022b05 |
tag = "column";
|
|
Packit |
022b05 |
} else if (smiNode->nodekind == SMI_NODEKIND_SCALAR) {
|
|
Packit |
022b05 |
tag = "scalar";
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
/* if (lastSmiNode */
|
|
Packit |
022b05 |
/* && lastSmiNode->nodekind == SMI_NODEKIND_COLUMN */
|
|
Packit |
022b05 |
/* && smiNode->nodekind != SMI_NODEKIND_COLUMN) { */
|
|
Packit |
022b05 |
/* printNodeEndTag(indent + INDENT, "row", smiNode->name); */
|
|
Packit |
022b05 |
/* printNodeEndTag(indent, "table", smiNode->name); */
|
|
Packit |
022b05 |
/* } */
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
smiType = smiGetNodeType(smiNode);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintNodeStartTag(f, indent, tag, smiNode);
|
|
Packit |
022b05 |
fprintDescription(f, indent + INDENT, smiNode->description);
|
|
Packit |
022b05 |
fprintReference(f, indent + INDENT, smiNode->reference);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (smiType && (smiType->basetype != SMI_BASETYPE_UNKNOWN)) {
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "\"syntax\" => {\n", 0);
|
|
Packit |
022b05 |
smiModule = smiGetTypeModule(smiType);
|
|
Packit |
022b05 |
fprintSegment(f, indent + 2 *INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"type\" => ");
|
|
Packit |
022b05 |
if (smiType->name && smiModule) {
|
|
Packit |
022b05 |
fprint(f, "{ \"module\" => \"%s\", \"name\" => \"%s\"},\n",
|
|
Packit |
022b05 |
smiModule->name, smiType->name);
|
|
Packit |
022b05 |
} else {
|
|
Packit |
022b05 |
fprint(f, "\n");
|
|
Packit |
022b05 |
fprintTypedef(f, indent + 2 * INDENT, smiType);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if ((smiNode->nodekind != SMI_NODEKIND_TABLE) &&
|
|
Packit |
022b05 |
(smiNode->nodekind != SMI_NODEKIND_ROW) &&
|
|
Packit |
022b05 |
(smiNode->nodekind != SMI_NODEKIND_CAPABILITIES) &&
|
|
Packit |
022b05 |
(smiNode->nodekind != SMI_NODEKIND_NODE)) {
|
|
Packit |
022b05 |
fprintAccess(f, indent + INDENT, smiNode->access);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
if (smiType) {
|
|
Packit |
022b05 |
fprintValue(f, indent + INDENT, &smiNode->value, smiType);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintFormat(f, indent + INDENT, smiNode->format);
|
|
Packit |
022b05 |
fprintUnits(f, indent + INDENT, smiNode->units);
|
|
Packit |
022b05 |
if (smiNode->nodekind == SMI_NODEKIND_ROW) {
|
|
Packit |
022b05 |
fprintIndex(f, indent + INDENT, smiNode);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintNodeEndTag(f, indent, tag, smiNode->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintNodes(FILE *f, SmiModule *smiModule)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
SmiNode *smiNode, *lastSmiNode;
|
|
Packit |
022b05 |
SmiNodekind nodekinds;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
nodekinds = SMI_NODEKIND_NODE | SMI_NODEKIND_TABLE |
|
|
Packit |
022b05 |
SMI_NODEKIND_ROW | SMI_NODEKIND_COLUMN | SMI_NODEKIND_SCALAR |
|
|
Packit |
022b05 |
SMI_NODEKIND_CAPABILITIES;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for (i = 0,
|
|
Packit |
022b05 |
lastSmiNode = NULL,
|
|
Packit |
022b05 |
smiNode = smiGetFirstNode(smiModule, nodekinds);
|
|
Packit |
022b05 |
smiNode;
|
|
Packit |
022b05 |
i++,
|
|
Packit |
022b05 |
lastSmiNode = smiNode,
|
|
Packit |
022b05 |
smiNode = smiGetNextNode(smiNode, nodekinds)) {
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i == 0) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"nodes\" => [\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintNode(f, 2 * INDENT, smiNode, lastSmiNode);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
/* if (lastSmiNode */
|
|
Packit |
022b05 |
/* && lastSmiNode->nodekind == SMI_NODEKIND_COLUMN) { */
|
|
Packit |
022b05 |
/* printNodeEndTag(3 * INDENT, "row", smiNode->name); */
|
|
Packit |
022b05 |
/* printNodeEndTag(2 * INDENT, "table", smiNode->name); */
|
|
Packit |
022b05 |
/* } */
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "], # nodes\n\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintNotification(FILE *f, int indent, SmiNode *smiNode)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
fprintNodeStartTag(f, indent, "notification", smiNode);
|
|
Packit |
022b05 |
fprintDescription(f, indent + INDENT, smiNode->description);
|
|
Packit |
022b05 |
fprintReference(f, indent + INDENT, smiNode->reference);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "\"objects\" => [\n", 0);
|
|
Packit |
022b05 |
fprintElementList(f, indent + 2 * INDENT, NULL,
|
|
Packit |
022b05 |
smiGetFirstElement(smiNode), 1);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "],\n", 0);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintNodeEndTag(f, indent, "notification", smiNode->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintNotifications(FILE *f, SmiModule *smiModule)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiNode *smiNode;
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for(i = 0, smiNode = smiGetFirstNode(smiModule, SMI_NODEKIND_NOTIFICATION);
|
|
Packit |
022b05 |
smiNode;
|
|
Packit |
022b05 |
i++, smiNode = smiGetNextNode(smiNode, SMI_NODEKIND_NOTIFICATION)) {
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i == 0) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"notifications\" => [\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintNotification(f, 2 * INDENT, smiNode);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "], # notifications\n\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintGroup(FILE *f, int indent, SmiNode *smiNode)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
fprintNodeStartTag(f, indent, "group", smiNode);
|
|
Packit |
022b05 |
fprintDescription(f, indent + INDENT, smiNode->description);
|
|
Packit |
022b05 |
fprintReference(f, indent + INDENT, smiNode->reference);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "\"members\" => [\n", 0);
|
|
Packit |
022b05 |
fprintElementList(f, indent + 2 * INDENT, NULL,
|
|
Packit |
022b05 |
smiGetFirstElement(smiNode), 1);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "], # members\n", 0);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintNodeEndTag(f, indent, "group", smiNode->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintGroups(FILE *f, SmiModule *smiModule)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiNode *smiNode;
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for(i = 0, smiNode = smiGetFirstNode(smiModule, SMI_NODEKIND_GROUP);
|
|
Packit |
022b05 |
smiNode;
|
|
Packit |
022b05 |
i++, smiNode = smiGetNextNode(smiNode, SMI_NODEKIND_GROUP)) {
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i == 0) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"groups\" => [\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintGroup(f, 2 * INDENT, smiNode);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "], # groups\n\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintComplGroups(FILE *f, int indent, SmiNode *smiNode)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiNode *optSmiNode;
|
|
Packit |
022b05 |
SmiModule *optSmiModule;
|
|
Packit |
022b05 |
SmiOption *smiOption;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (! smiGetFirstElement(smiNode) && !smiGetFirstOption(smiNode)) {
|
|
Packit |
022b05 |
return;
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"requires\" => [\n", 0);
|
|
Packit |
022b05 |
fprintElementList(f, indent + INDENT, "mandatory",
|
|
Packit |
022b05 |
smiGetFirstElement(smiNode), 1);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for(smiOption = smiGetFirstOption(smiNode);
|
|
Packit |
022b05 |
smiOption;
|
|
Packit |
022b05 |
smiOption = smiGetNextOption(smiOption)) {
|
|
Packit |
022b05 |
optSmiNode = smiGetOptionNode(smiOption);
|
|
Packit |
022b05 |
optSmiModule = smiGetNodeModule(optSmiNode);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"%s\" => {\n", optSmiNode->name);
|
|
Packit |
022b05 |
fprintSegment(f, indent + 2*INDENT, "\"type\" => \"optional\",\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, indent + 2*INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"module\" => \"%s\",\n", optSmiModule->name);
|
|
Packit |
022b05 |
fprintDescription(f, indent + 2 * INDENT, smiOption->description);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent, "], # requires\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintRefinement(FILE *f, int indent, SmiRefinement *smiRefinement)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiModule *smiModule;
|
|
Packit |
022b05 |
SmiNode *smiNode;
|
|
Packit |
022b05 |
SmiType *smiType;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
smiNode = smiGetRefinementNode(smiRefinement);
|
|
Packit |
022b05 |
smiModule = smiGetNodeModule(smiNode);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, indent, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"%s\" => {\n", smiNode->name);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"module\" => \"%s\",\n", smiModule->name);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
smiType = smiGetRefinementType(smiRefinement);
|
|
Packit |
022b05 |
if (smiType) {
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "\"syntax\" => {\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, indent + 2*INDENT, "\"type\" => ", 0);
|
|
Packit |
022b05 |
fprintTypedef(f, indent + 2 * INDENT, smiType);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
smiType = smiGetRefinementWriteType(smiRefinement);
|
|
Packit |
022b05 |
if (smiType) {
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "\"writesyntax\" => {\n", 0);
|
|
Packit |
022b05 |
fprintSegment(f, indent + 2*INDENT, "\"type\" => ", 0);
|
|
Packit |
022b05 |
fprintTypedef(f, indent + 2 * INDENT, smiType);
|
|
Packit |
022b05 |
fprintSegment(f, indent + INDENT, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (smiRefinement->access != SMI_ACCESS_UNKNOWN) {
|
|
Packit |
022b05 |
fprintAccess(f, indent + INDENT, smiRefinement->access);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
fprintDescription(f, indent + INDENT, smiRefinement->description);
|
|
Packit |
022b05 |
fprintSegment(f, indent, "},\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintRefinements(FILE *f, int indent, SmiNode *smiNode)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiRefinement *smiRefinement;
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for(i = 0, smiRefinement = smiGetFirstRefinement(smiNode);
|
|
Packit |
022b05 |
smiRefinement;
|
|
Packit |
022b05 |
i++, smiRefinement = smiGetNextRefinement(smiRefinement)) {
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (!i) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "\"refinements\" => {\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintRefinement(f, indent + INDENT, smiRefinement);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i) {
|
|
Packit |
022b05 |
fprintSegment(f, indent, "}, # refinements\n\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintCompliance(FILE *f, int indent, SmiNode *smiNode)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
fprintNodeStartTag(f, indent, "compliance", smiNode);
|
|
Packit |
022b05 |
fprintDescription(f, indent + INDENT, smiNode->description);
|
|
Packit |
022b05 |
fprintReference(f, indent + INDENT, smiNode->reference);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintComplGroups(f, indent + INDENT, smiNode);
|
|
Packit |
022b05 |
fprintRefinements(f, indent + INDENT, smiNode);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintNodeEndTag(f, indent, "compliance", smiNode->name);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void fprintCompliances(FILE *f, SmiModule *smiModule)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
SmiNode *smiNode;
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for(i = 0, smiNode = smiGetFirstNode(smiModule, SMI_NODEKIND_COMPLIANCE);
|
|
Packit |
022b05 |
smiNode;
|
|
Packit |
022b05 |
i++, smiNode = smiGetNextNode(smiNode, SMI_NODEKIND_COMPLIANCE)) {
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (!i) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "\"compliances\" => [\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintCompliance(f, 2 * INDENT, smiNode);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (i) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "], # compliances\n\n", 0);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void dumpPerlModule(FILE *f, SmiModule *smiModule)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
time_t now;
|
|
Packit |
022b05 |
char *lang;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
now = time(NULL);
|
|
Packit |
022b05 |
fprint(f, "# Perl version 5\t\t\t\t\t\tDO NOT EDIT\n#\n");
|
|
Packit |
022b05 |
fprint(f, "# Generated by smidump " SMI_VERSION_STRING ":\n#\n");
|
|
Packit |
022b05 |
fprintf(f, "# smidump -f perl %s\n\n", smiModule->name);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprint(f, "{\n");
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprint(f, "\"%s\" => {\n", smiModule->name);
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"name\" => \"%s\",\n\n", smiModule->name);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "# Compiler Info\n", 0);
|
|
Packit |
022b05 |
fprint(f, "");
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"path\" => \"%s\",\n", smiModule->path);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
lang = getStringLanguage(smiModule->language);
|
|
Packit |
022b05 |
if (lang) {
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "", 0);
|
|
Packit |
022b05 |
fprint(f, "\"language\" => \"%s\",\n", lang);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprint(f, "\n");
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "# Module Identity\n", 0);
|
|
Packit |
022b05 |
fprintModule(f, smiModule);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "# Imports\n", 0);
|
|
Packit |
022b05 |
fprintImports(f, smiModule);
|
|
Packit |
022b05 |
fprintSegment(f, INDENT, "# Module Body\n", 0);
|
|
Packit |
022b05 |
fprintTypedefs(f, smiModule);
|
|
Packit |
022b05 |
fprintNodes(f, smiModule);
|
|
Packit |
022b05 |
fprintNotifications(f, smiModule);
|
|
Packit |
022b05 |
fprintGroups(f, smiModule);
|
|
Packit |
022b05 |
fprintCompliances(f, smiModule);
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
fprint(f, " } # %s\n", smiModule->name);
|
|
Packit |
022b05 |
fprint(f, "};\n");
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
static void dumpPerl(int modc, SmiModule **modv, int flags, char *output)
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
int i;
|
|
Packit |
022b05 |
FILE *f = stdout;
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (output) {
|
|
Packit |
022b05 |
f = fopen(output, "w");
|
|
Packit |
022b05 |
if (!f) {
|
|
Packit |
022b05 |
fprintf(stderr, "smidump: cannot open %s for writing: ", output);
|
|
Packit |
022b05 |
perror(NULL);
|
|
Packit |
022b05 |
exit(1);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
for (i = 0; i < modc; i++) {
|
|
Packit |
022b05 |
dumpPerlModule(f, modv[i]);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (fflush(f) || ferror(f)) {
|
|
Packit |
022b05 |
perror("smidump: write error");
|
|
Packit |
022b05 |
exit(1);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
if (output) {
|
|
Packit |
022b05 |
fclose(f);
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
}
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
void initPerl()
|
|
Packit |
022b05 |
{
|
|
Packit |
022b05 |
static SmidumpDriver driver = {
|
|
Packit |
022b05 |
"perl",
|
|
Packit |
022b05 |
dumpPerl,
|
|
Packit |
022b05 |
0,
|
|
Packit |
022b05 |
SMIDUMP_DRIVER_CANT_UNITE,
|
|
Packit |
022b05 |
"Perl MIB dictionaries",
|
|
Packit |
022b05 |
NULL,
|
|
Packit |
022b05 |
NULL
|
|
Packit |
022b05 |
};
|
|
Packit |
022b05 |
|
|
Packit |
022b05 |
smidumpRegisterDriver(&driver);
|
|
Packit |
022b05 |
}
|