summaryrefslogtreecommitdiff
path: root/local/mib2c.access_functions.conf
diff options
context:
space:
mode:
Diffstat (limited to 'local/mib2c.access_functions.conf')
-rw-r--r--local/mib2c.access_functions.conf183
1 files changed, 183 insertions, 0 deletions
diff --git a/local/mib2c.access_functions.conf b/local/mib2c.access_functions.conf
new file mode 100644
index 0000000..9d54f14
--- /dev/null
+++ b/local/mib2c.access_functions.conf
@@ -0,0 +1,183 @@
+## -*- c -*-
+######################################################################
+## Do the .h file
+######################################################################
+@open ${name}_access.h@
+/*
+ * Note: this file originally auto-generated by mib2c using
+ * $Id$
+ */
+#ifndef $name.uc_ACCESS_H
+#define $name.uc_ACCESS_H
+
+@foreach $t table@
+/** User-defined data access functions for data in table $t */
+/** row level accessors */
+Netsnmp_First_Data_Point ${t}_get_first_data_point;
+Netsnmp_Next_Data_Point ${t}_get_next_data_point;
+int ${t}_commit_row(void **my_data_context, int new_or_del);
+void * ${t}_create_data_context(netsnmp_variable_list *index_data, int column);
+
+/** column accessors */
+ @foreach $c column@
+ @if $c.access =~ /(Read|Create)/@
+ $c.decl *get_$c(void *data_context, size_t *ret_len);
+ @end@
+ @if $c.access =~ /(Write|Create)/@
+ int set_$c(void *data_context, $c.decl *val, size_t val_len);
+ @end@
+ @end@
+@end@
+
+#endif /* $name.uc_ACCESS_H */
+######################################################################
+## Do the .c file
+######################################################################
+@open ${name}_access.c@
+
+/*
+ * Note: this file originally auto-generated by mib2c using
+ * $Id$
+ */
+
+#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}_access.h"
+#include "${name}_enums.h"
+
+@foreach $t table@
+
+/** returns the first data point within the $t table data.
+
+ Set the my_loop_context variable to the first data point structure
+ of your choice (from which you can find the next one). This could
+ be anything from the first node in a linked list, to an integer
+ pointer containing the beginning of an array variable.
+
+ Set the my_data_context variable to something to be returned to
+ you later that will provide you with the data to return in a given
+ row. This could be the same pointer as what my_loop_context is
+ set to, or something different.
+
+ The put_index_data variable contains a list of snmp variable
+ bindings, one for each index in your table. Set the values of
+ each appropriately according to the data matching the first row
+ and return the put_index_data variable at the end of the function.
+*/
+netsnmp_variable_list *
+${t}_get_first_data_point(void **my_loop_context, void **my_data_context,
+ netsnmp_variable_list *put_index_data,
+ netsnmp_iterator_info *mydata)
+{
+
+ netsnmp_variable_list *vptr;
+
+ *my_loop_context = /** XXX */;
+ *my_data_context = /** XXX */;
+
+ vptr = put_index_data;
+
+ @foreach $idx index@
+ snmp_set_var_value(vptr, /** XXX: $idx data */, /** XXX: length of $idx data */);
+ vptr = vptr->next_variable;
+ @end@
+
+ return put_index_data;
+}
+
+/** functionally the same as ${t}_get_first_data_point, but
+ my_loop_context has already been set to a previous value and should
+ be updated to the next in the list. For example, if it was a
+ linked list, you might want to cast it to your local data type and
+ then return my_loop_context->next. The my_data_context pointer
+ should be set to something you need later and the indexes in
+ put_index_data updated again. */
+netsnmp_variable_list *
+${t}_get_next_data_point(void **my_loop_context, void **my_data_context,
+ netsnmp_variable_list *put_index_data,
+ netsnmp_iterator_info *mydata)
+{
+
+ netsnmp_variable_list *vptr;
+
+ *my_loop_context = /** XXX */;
+ *my_data_context = /** XXX */;
+
+ vptr = put_index_data;
+
+ @foreach $idx index@
+ snmp_set_var_value(vptr, /** XXX: $idx data */, /** XXX: length of $idx data */);
+ vptr = vptr->next_variable;
+ @end@
+
+ return put_index_data;
+}
+
+/** Create a data_context for non-existent rows that SETs are performed on.
+ * return a void * pointer which will be passed to subsequent get_XXX
+ * and set_XXX functions for data retrieval and modification during
+ * this SET request.
+ *
+ * The indexes are encoded (in order) into the index_data pointer,
+ * and the column object which triggered the row creation is available
+ * via the column parameter, if it would be helpful to use that information.
+ */
+void *
+${t}_create_data_context(netsnmp_variable_list *index_data, int column) {
+ return NULL; /* XXX: you likely want to return a real pointer */
+}
+
+/** If the implemented set_* functions don't operate directly on the
+ real-live data (which is actually recommended), then this function
+ can be used to take a given my_data_context pointer and "commit" it
+ to whereever the modified data needs to be put back to. For
+ example, if this was a routing table you could publish the modified
+ routes back into the kernel at this point.
+
+ new_or_del will be set to 1 if new, or -1 if it should be deleted
+ or 0 if it is just a modification of an existing row.
+
+ If you free the data yourself, make sure to *my_data_context = NULL */
+int
+${t}_commit_row(void **my_data_context, int new_or_del)
+{
+ /** Add any necessary commit code here */
+ /* */
+
+ /* return no errors. And there shouldn't be any!!! Ever!!! You
+ should have checked the values long before this. */
+ return SNMP_ERR_NOERROR;
+}
+
+
+/* User-defined data access functions (per column) for data in table $t */
+/*
+ * NOTE:
+ * - these get_ routines MUST return data that will not be freed (ie,
+ * use static variables or persistent data). It will be copied, if
+ * needed, immediately after the get_ routine has been called.
+ * - these SET routines must copy the incoming data and can not take
+ * ownership of the memory passed in by the val pointer.
+ */
+ @foreach $c column@
+ @if $c.access =~ /(Read|Create)/@
+/** XXX: return a data pointer to the data for the $c column and set
+ ret_len to its proper size in bytes. */
+ $c.decl *get_$c(void *data_context, size_t *ret_len) {
+ return NULL; /** XXX: replace this with a pointer to a real value */
+ }
+ @end@
+ @if $c.access =~ /(Write|Create)/@
+/** XXX: Set the value of the $c column and return
+ SNMP_ERR_NOERROR on success
+ SNMP_ERR_XXX for SNMP deterministic error codes
+ SNMP_ERR_GENERR on generic failures (a last result response). */
+ int set_$c(void *data_context, $c.decl *val, size_t val_len) {
+ return SNMP_ERR_NOERROR; /** XXX: change if an error occurs */
+ }
+ @end@
+ @end@
+
+@end@
+