/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* db_dictlog_c.x
*
* Copyright 2005 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
%#pragma ident "%Z%%M% %I% %E% SMI"
#if RPC_HDR
%#ifndef _DB_DICTLOG_H
%#define _DB_DICTLOG_H
%
%/* A log entry that describes an action to be performed and its parameters. */
%
#endif /* RPC_HDR */
#ifdef USINGC
%#include "db_vers_c.h"
#else
%#include "db_vers.h"
%#include "db_pickle.h"
#endif /* USINGC */
#endif /* RPC_HDR */
%
%#include "nisdb_rw.h"
%
%#define DB_ADD_TABLE 1
%#define DB_REMOVE_TABLE 2
#ifdef USINGC
struct db_dictlog_entry {
int action; /* action to be invoked */
};
typedef struct db_dictlog_entry* db_dictlog_entry_p;
#endif /* USINGC */
#endif /* RPC_HDR */
#ifdef USINGC
#if RPC_HDR
%bool_t xdr_table_obj();
#endif
#endif /* USINGC */
#ifndef USINGC
#ifdef RPC_HDR
% int action; /* action to be invoked */
% char *table_name; /* table_name supplied with action (if any) */
% public:
%
%/*Constructor: Create an empty log entry, with no table_name and not object */
%
%/*Constructor: Create a log entry using the given parameters. Note that
% pointers to table_name and table_object are simply assigned, not copied. */
%
% ~db_dictlog_entry();
%
%/* Print this log entry to stdout */
% void print();
%
%/* Accessor: return version of log entry */
%
%/* Accessor: return pointer to action of log entry */
% int get_action() { return( action ); }
%
%/* Accessor: return pointer to table_name part of log entry */
% char* get_table_name() { return( table_name ); }
%
%/* Predicate: return whether log entry is complete and not truncated */
%
%/* Accessor: return pointer to copy of object in log entry */
%
%/* Accessor: return pointer to to next log entry */
%
%/* Accessor: return pointer to copy of object in log entry */
%};
%#ifdef __cplusplus
%#endif
#endif /* RPC_HDR */
#endif /* USINGC */
struct db_dictlog_list {
};
#ifndef USINGC
#ifdef RPC_HDR
% STRUCTRWLOCK(dictlog);
% public:
%
%/* Constructor: create log file; default is PICKLE_READ mode. */
% }
%
% ~db_dictlog(void) {
% }
%
%/* Execute given function 'func' on log.
% function takes as arguments: pointer to log entry, character pointer to
% another argument, and pointer to an integer, which is used as a counter.
% 'func' should increment this value for each successful application.
% The log is traversed until either 'func' returns FALSE, or when the log
% is exhausted. The second argument to 'execute_on_log' is passed as the
% second argument to 'func'. The third argument, 'clean' determines whether
% the log entry is deleted after the function has been applied.
% Returns the number of times that 'func' incremented its third argument. */
%
%/* Print contents of log file to stdout */
% int print();
%
%/*Append given log entry to log. */
% int append( db_dictlog_entry * );
%
%/* Return the next element in current log; return NULL if end of log or error.
% Log must have been opened for READ. */
% db_dictlog_entry *get();
%
%/*
% * Locking methods. Protect the db_dictlog as well as db_dictlog_entries
% * hanging off of it.
% */
% int acqexcl(void) {
% }
%
% int relexcl(void) {
% }
%
% int acqnonexcl(void) {
% }
%
% int relnonexcl(void) {
% }
%
%};
#endif /* RPC_HDR */
#endif /* USINGC */
#if RPC_HDR
%#endif /* _DB_DICTLOG_H */
#endif /* RPC_HDR */