--- /dev/null
+## -*- c -*-
+######################################################################
+## Do the .h file
+######################################################################
+@open ${name}.h@
+/*
+ * Note: this file originally auto-generated by mib2c using
+ * $Id: mib2c.scalar.conf,v 1.5 2002/07/18 14:18:52 dts12 Exp $
+ */
+#ifndef $name.uc_H
+#define $name.uc_H
+
+/* function declarations */
+void init_$name(void);
+@foreach $i scalar@
+@if $i.settable@
+Netsnmp_Node_Handler do_${i};
+@end@
+@if !$i.settable@
+Netsnmp_Node_Handler get_${i};
+@end@
+@end@
+
+#endif /* $name.uc_H */
+######################################################################
+## Do the .c file
+######################################################################
+@open ${name}.c@
+/*
+ * Note: this file originally auto-generated by mib2c using
+ * $Id: mib2c.scalar.conf,v 1.5 2002/07/18 14:18:52 dts12 Exp $
+ */
+
+#include <net-snmp/net-snmp-config.h>
+#include <net-snmp/net-snmp-includes.h>
+#include <net-snmp/agent/net-snmp-agent-includes.h>
+#include "${name}.h"
+
+/** Initializes the $name module */
+void
+init_$name(void)
+{
+ @foreach $i scalar@
+ static oid ${i}_oid[] = { $i.commaoid, 0 };
+ @end@
+
+ DEBUGMSGTL(("$name", "Initializing\n"));
+
+ @foreach $i scalar@
+ @if !$i.settable@
+ netsnmp_register_read_only_instance(netsnmp_create_handler_registration
+ ("$i",
+ get_$i,
+ ${i}_oid,
+ OID_LENGTH(${i}_oid),
+ HANDLER_CAN_RONLY));
+ @end@
+ @if $i.settable@
+ netsnmp_register_instance(netsnmp_create_handler_registration
+ ("$i",
+ do_$i,
+ ${i}_oid,
+ OID_LENGTH(${i}_oid),
+ HANDLER_CAN_RWRITE));
+ @end@
+ @end@
+}
+
+@foreach $i scalar@
+int
+@if !$i.settable@
+get_$i(netsnmp_mib_handler *handler,
+@end@
+@if $i.settable@
+do_$i(netsnmp_mib_handler *handler,
+@end@
+ netsnmp_handler_registration *reginfo,
+ netsnmp_agent_request_info *reqinfo,
+ netsnmp_request_info *requests)
+{
+ /* We are never called for a GETNEXT if it's registered as a
+ "instance", as it's "magically" handled for us. */
+
+ /* a instance handler also only hands us one request at a time, so
+ we don't need to loop over a list of requests; we'll only get one. */
+
+ switch(reqinfo->mode) {
+
+ case MODE_GET:
+ snmp_set_var_typed_value(requests->requestvb, $i.type, (u_char *) /* XXX: a pointer to the scalar's data */, /* XXX: the length of the data in bytes */);
+ break;
+
+ @if $i.settable@
+ /*
+ * SET REQUEST
+ *
+ * multiple states in the transaction. See:
+ * http://www.net-snmp.org/tutorial-5/toolkit/mib_module/set-actions.jpg
+ */
+ case MODE_SET_RESERVE1:
+ if (/* XXX: check incoming data in requests->requestvb->val.XXX for failures, like an incorrect type or an illegal value or ... */) {
+ netsnmp_set_request_error(reqinfo, requests, /* XXX: set error code depending on problem (like SNMP_ERR_WRONGTYPE or SNMP_ERR_WRONGVALUE or ... */);
+ }
+ break;
+
+ case MODE_SET_RESERVE2:
+ /* XXX malloc "undo" storage buffer */
+ if (/* XXX if malloc, or whatever, failed: */) {
+ netsnmp_set_request_error(reqinfo, requests, SNMP_ERR_RESOURCESUNAVAILABLE);
+ }
+ break;
+
+ case MODE_SET_FREE:
+ /* XXX: free resources allocated in RESERVE1 and/or
+ RESERVE2. Something failed somewhere, and the states
+ below won't be called. */
+ break;
+
+ case MODE_SET_ACTION:
+ /* XXX: perform the value change here */
+ if (/* XXX: error? */) {
+ netsnmp_set_request_error(reqinfo, requests, /* some error */);
+ }
+ break;
+
+ case MODE_SET_COMMIT:
+ /* XXX: delete temporary storage */
+ if (/* XXX: error? */) {
+ /* try _really_really_ hard to never get to this point */
+ netsnmp_set_request_error(reqinfo, requests, SNMP_ERR_COMMITFAILED);
+ }
+ break;
+
+ case MODE_SET_UNDO:
+ /* XXX: UNDO and return to previous value for the object */
+ if (/* XXX: error? */) {
+ /* try _really_really_ hard to never get to this point */
+ netsnmp_set_request_error(reqinfo, requests, SNMP_ERR_UNDOFAILED);
+ }
+ break;
+ @end@
+
+ default:
+ /* we should never get here, so this is a really bad error */
+ return SNMP_ERR_GENERR;
+ }
+
+ return SNMP_ERR_NOERROR;
+}
+@end@