HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //usr/lib/x86_64-linux-gnu/perl5/5.34/Prelude.pm
# This file was automatically generated by SWIG (http://www.swig.org).
# Version 4.0.1
#
# Do not make changes to this file unless you know what you are doing--modify
# the SWIG interface file instead.

package Prelude;
use base qw(Exporter);
use base qw(DynaLoader);
package Preludec;
bootstrap Prelude;
package Prelude;
@EXPORT = qw();

# ---------- BASE METHODS -------------

package Prelude;

sub TIEHASH {
    my ($classname,$obj) = @_;
    return bless $obj, $classname;
}

sub CLEAR { }

sub FIRSTKEY { }

sub NEXTKEY { }

sub FETCH {
    my ($self,$field) = @_;
    my $member_func = "swig_${field}_get";
    $self->$member_func();
}

sub STORE {
    my ($self,$field,$newval) = @_;
    my $member_func = "swig_${field}_set";
    $self->$member_func($newval);
}

sub this {
    my $ptr = shift;
    return tied(%$ptr);
}


# ------- FUNCTION WRAPPERS --------

package Prelude;

*checkVersion = *Preludec::checkVersion;

############# Class : Prelude::ClientProfile ##############

package Prelude::ClientProfile;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
sub new {
    my $pkg = shift;
    my $self = Preludec::new_ClientProfile(@_);
    bless $self, $pkg if defined($self);
}

sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_ClientProfile($self);
        delete $OWNER{$self};
    }
}

*getUid = *Preludec::ClientProfile_getUid;
*getGid = *Preludec::ClientProfile_getGid;
*getName = *Preludec::ClientProfile_getName;
*setName = *Preludec::ClientProfile_setName;
*getAnalyzerId = *Preludec::ClientProfile_getAnalyzerId;
*setAnalyzerId = *Preludec::ClientProfile_setAnalyzerId;
*getConfigFilename = *Preludec::ClientProfile_getConfigFilename;
*getAnalyzeridFilename = *Preludec::ClientProfile_getAnalyzeridFilename;
*getTlsKeyFilename = *Preludec::ClientProfile_getTlsKeyFilename;
*getTlsServerCaCertFilename = *Preludec::ClientProfile_getTlsServerCaCertFilename;
*getTlsServerKeyCertFilename = *Preludec::ClientProfile_getTlsServerKeyCertFilename;
*getTlsServerCrlFilename = *Preludec::ClientProfile_getTlsServerCrlFilename;
*getTlsClientKeyCertFilename = *Preludec::ClientProfile_getTlsClientKeyCertFilename;
*getTlsClientTrustedCertFilename = *Preludec::ClientProfile_getTlsClientTrustedCertFilename;
*getBackupDirname = *Preludec::ClientProfile_getBackupDirname;
*getProfileDirname = *Preludec::ClientProfile_getProfileDirname;
*setPrefix = *Preludec::ClientProfile_setPrefix;
*getPrefix = *Preludec::ClientProfile_getPrefix;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::Connection ##############

package Prelude::Connection;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_Connection($self);
        delete $OWNER{$self};
    }
}

sub new {
    my $pkg = shift;
    my $self = Preludec::new_Connection(@_);
    bless $self, $pkg if defined($self);
}

*getConnection = *Preludec::Connection_getConnection;
*close = *Preludec::Connection_close;
*connect = *Preludec::Connection_connect;
*setState = *Preludec::Connection_setState;
*getState = *Preludec::Connection_getState;
*setData = *Preludec::Connection_setData;
*getData = *Preludec::Connection_getData;
*getPermission = *Preludec::Connection_getPermission;
*setPeerAnalyzerid = *Preludec::Connection_setPeerAnalyzerid;
*getPeerAnalyzerid = *Preludec::Connection_getPeerAnalyzerid;
*getLocalAddr = *Preludec::Connection_getLocalAddr;
*getLocalPort = *Preludec::Connection_getLocalPort;
*getPeerAddr = *Preludec::Connection_getPeerAddr;
*getPeerPort = *Preludec::Connection_getPeerPort;
*isAlive = *Preludec::Connection_isAlive;
*getFd = *Preludec::Connection_getFd;
*recvIDMEF = *Preludec::Connection_recvIDMEF;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::ConnectionPool ##############

package Prelude::ConnectionPool;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_ConnectionPool($self);
        delete $OWNER{$self};
    }
}

sub new {
    my $pkg = shift;
    my $self = Preludec::new_ConnectionPool(@_);
    bless $self, $pkg if defined($self);
}

*init = *Preludec::ConnectionPool_init;
*setConnectionString = *Preludec::ConnectionPool_setConnectionString;
*getConnectionString = *Preludec::ConnectionPool_getConnectionString;
*getConnectionList = *Preludec::ConnectionPool_getConnectionList;
*setFlags = *Preludec::ConnectionPool_setFlags;
*getFlags = *Preludec::ConnectionPool_getFlags;
*setData = *Preludec::ConnectionPool_setData;
*getData = *Preludec::ConnectionPool_getData;
*addConnection = *Preludec::ConnectionPool_addConnection;
*delConnection = *Preludec::ConnectionPool_delConnection;
*setConnectionAlive = *Preludec::ConnectionPool_setConnectionAlive;
*setConnectionDead = *Preludec::ConnectionPool_setConnectionDead;
*setRequiredPermission = *Preludec::ConnectionPool_setRequiredPermission;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::Client ##############

package Prelude::Client;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude::ClientProfile Prelude );
%OWNER = ();
%ITERATORS = ();
*ASYNC_SEND = *Preludec::Client_ASYNC_SEND;
*FLAGS_ASYNC_SEND = *Preludec::Client_FLAGS_ASYNC_SEND;
*ASYNC_TIMER = *Preludec::Client_ASYNC_TIMER;
*FLAGS_ASYNC_TIMER = *Preludec::Client_FLAGS_ASYNC_TIMER;
*HEARTBEAT = *Preludec::Client_HEARTBEAT;
*FLAGS_HEARTBEAT = *Preludec::Client_FLAGS_HEARTBEAT;
*CONNECT = *Preludec::Client_CONNECT;
*FLAGS_CONNECT = *Preludec::Client_FLAGS_CONNECT;
*AUTOCONFIG = *Preludec::Client_AUTOCONFIG;
*FLAGS_AUTOCONFIG = *Preludec::Client_FLAGS_AUTOCONFIG;
*IDMEF_READ = *Preludec::Client_IDMEF_READ;
*PERMISSION_IDMEF_READ = *Preludec::Client_PERMISSION_IDMEF_READ;
*ADMIN_READ = *Preludec::Client_ADMIN_READ;
*PERMISSION_ADMIN_READ = *Preludec::Client_PERMISSION_ADMIN_READ;
*IDMEF_WRITE = *Preludec::Client_IDMEF_WRITE;
*PERMISSION_IDMEF_WRITE = *Preludec::Client_PERMISSION_IDMEF_WRITE;
*ADMIN_WRITE = *Preludec::Client_ADMIN_WRITE;
*PERMISSION_ADMIN_WRITE = *Preludec::Client_PERMISSION_ADMIN_WRITE;
sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_Client($self);
        delete $OWNER{$self};
    }
}

sub new {
    my $pkg = shift;
    my $self = Preludec::new_Client(@_);
    bless $self, $pkg if defined($self);
}

*start = *Preludec::Client_start;
*init = *Preludec::Client_init;
*getClient = *Preludec::Client_getClient;
*sendIDMEF = *Preludec::Client_sendIDMEF;
*recvIDMEF = *Preludec::Client_recvIDMEF;
*getFlags = *Preludec::Client_getFlags;
*setFlags = *Preludec::Client_setFlags;
*getRequiredPermission = *Preludec::Client_getRequiredPermission;
*setRequiredPermission = *Preludec::Client_setRequiredPermission;
*getConfigFilename = *Preludec::Client_getConfigFilename;
*setConfigFilename = *Preludec::Client_setConfigFilename;
*getConnectionPool = *Preludec::Client_getConnectionPool;
*setConnectionPool = *Preludec::Client_setConnectionPool;
*__lshift__ = *Preludec::Client___lshift__;
*__rshift__ = *Preludec::Client___rshift__;
*setRecvTimeout = *Preludec::Client_setRecvTimeout;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::PreludeLog ##############

package Prelude::PreludeLog;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
*DEBUG = *Preludec::PreludeLog_DEBUG;
*INFO = *Preludec::PreludeLog_INFO;
*WARNING = *Preludec::PreludeLog_WARNING;
*ERROR = *Preludec::PreludeLog_ERROR;
*CRITICAL = *Preludec::PreludeLog_CRITICAL;
*QUIET = *Preludec::PreludeLog_QUIET;
*SYSLOG = *Preludec::PreludeLog_SYSLOG;
*setLevel = *Preludec::PreludeLog_setLevel;
*setDebugLevel = *Preludec::PreludeLog_setDebugLevel;
*setFlags = *Preludec::PreludeLog_setFlags;
*getFlags = *Preludec::PreludeLog_getFlags;
*setLogfile = *Preludec::PreludeLog_setLogfile;
*setCallback = *Preludec::PreludeLog_setCallback;
sub new {
    my $pkg = shift;
    my $self = Preludec::new_PreludeLog(@_);
    bless $self, $pkg if defined($self);
}

sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_PreludeLog($self);
        delete $OWNER{$self};
    }
}

sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::PreludeError ##############

package Prelude::PreludeError;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_PreludeError($self);
        delete $OWNER{$self};
    }
}

sub new {
    my $pkg = shift;
    my $self = Preludec::new_PreludeError(@_);
    bless $self, $pkg if defined($self);
}

*getCode = *Preludec::PreludeError_getCode;
*what = *Preludec::PreludeError_what;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::ClientEasy ##############

package Prelude::ClientEasy;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude::Client Prelude );
%OWNER = ();
%ITERATORS = ();
sub new {
    my $pkg = shift;
    my $self = Preludec::new_ClientEasy(@_);
    bless $self, $pkg if defined($self);
}

sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_ClientEasy($self);
        delete $OWNER{$self};
    }
}

sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::IDMEFCriterion ##############

package Prelude::IDMEFCriterion;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
*OPERATOR_NOT = *Preludec::IDMEFCriterion_OPERATOR_NOT;
*OPERATOR_NOCASE = *Preludec::IDMEFCriterion_OPERATOR_NOCASE;
*OPERATOR_EQUAL = *Preludec::IDMEFCriterion_OPERATOR_EQUAL;
*OPERATOR_EQUAL_NOCASE = *Preludec::IDMEFCriterion_OPERATOR_EQUAL_NOCASE;
*OPERATOR_NOT_EQUAL = *Preludec::IDMEFCriterion_OPERATOR_NOT_EQUAL;
*OPERATOR_NOT_EQUAL_NOCASE = *Preludec::IDMEFCriterion_OPERATOR_NOT_EQUAL_NOCASE;
*OPERATOR_LESSER = *Preludec::IDMEFCriterion_OPERATOR_LESSER;
*OPERATOR_LESSER_OR_EQUAL = *Preludec::IDMEFCriterion_OPERATOR_LESSER_OR_EQUAL;
*OPERATOR_GREATER = *Preludec::IDMEFCriterion_OPERATOR_GREATER;
*OPERATOR_GREATER_OR_EQUAL = *Preludec::IDMEFCriterion_OPERATOR_GREATER_OR_EQUAL;
*OPERATOR_SUBSTR = *Preludec::IDMEFCriterion_OPERATOR_SUBSTR;
*OPERATOR_SUBSTR_NOCASE = *Preludec::IDMEFCriterion_OPERATOR_SUBSTR_NOCASE;
*OPERATOR_NOT_SUBSTR = *Preludec::IDMEFCriterion_OPERATOR_NOT_SUBSTR;
*OPERATOR_NOT_SUBSTR_NOCASE = *Preludec::IDMEFCriterion_OPERATOR_NOT_SUBSTR_NOCASE;
*OPERATOR_REGEX = *Preludec::IDMEFCriterion_OPERATOR_REGEX;
*OPERATOR_REGEX_NOCASE = *Preludec::IDMEFCriterion_OPERATOR_REGEX_NOCASE;
*OPERATOR_NOT_REGEX = *Preludec::IDMEFCriterion_OPERATOR_NOT_REGEX;
*OPERATOR_NOT_REGEX_NOCASE = *Preludec::IDMEFCriterion_OPERATOR_NOT_REGEX_NOCASE;
*OPERATOR_NULL = *Preludec::IDMEFCriterion_OPERATOR_NULL;
*OPERATOR_NOT_NULL = *Preludec::IDMEFCriterion_OPERATOR_NOT_NULL;
sub new {
    my $pkg = shift;
    my $self = Preludec::new_IDMEFCriterion(@_);
    bless $self, $pkg if defined($self);
}

sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_IDMEFCriterion($self);
        delete $OWNER{$self};
    }
}

sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::IDMEFCriteria ##############

package Prelude::IDMEFCriteria;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
*OPERATOR_NOT = *Preludec::IDMEFCriteria_OPERATOR_NOT;
*OPERATOR_AND = *Preludec::IDMEFCriteria_OPERATOR_AND;
*OPERATOR_OR = *Preludec::IDMEFCriteria_OPERATOR_OR;
sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_IDMEFCriteria($self);
        delete $OWNER{$self};
    }
}

sub new {
    my $pkg = shift;
    my $self = Preludec::new_IDMEFCriteria(@_);
    bless $self, $pkg if defined($self);
}

*match = *Preludec::IDMEFCriteria_match;
*clone = *Preludec::IDMEFCriteria_clone;
*andCriteria = *Preludec::IDMEFCriteria_andCriteria;
*orCriteria = *Preludec::IDMEFCriteria_orCriteria;
*toString = *Preludec::IDMEFCriteria_toString;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::IDMEFValue ##############

package Prelude::IDMEFValue;
use overload
    "<=" => sub { $_[0]->__le__($_[1])},
    ">=" => sub { $_[0]->__ge__($_[1])},
    "<" => sub { $_[0]->__lt__($_[1])},
    "!=" => sub { $_[0]->__ne__($_[1])},
    "==" => sub { $_[0]->__eq__($_[1])},
    ">" => sub { $_[0]->__gt__($_[1])},
    "=" => sub { my $class = ref($_[0]); $class->new($_[0]) },
    "fallback" => 1;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
*TYPE_UNKNOWN = *Preludec::IDMEFValue_TYPE_UNKNOWN;
*TYPE_INT8 = *Preludec::IDMEFValue_TYPE_INT8;
*TYPE_UINT8 = *Preludec::IDMEFValue_TYPE_UINT8;
*TYPE_INT16 = *Preludec::IDMEFValue_TYPE_INT16;
*TYPE_UINT16 = *Preludec::IDMEFValue_TYPE_UINT16;
*TYPE_INT32 = *Preludec::IDMEFValue_TYPE_INT32;
*TYPE_UINT32 = *Preludec::IDMEFValue_TYPE_UINT32;
*TYPE_INT64 = *Preludec::IDMEFValue_TYPE_INT64;
*TYPE_UINT64 = *Preludec::IDMEFValue_TYPE_UINT64;
*TYPE_FLOAT = *Preludec::IDMEFValue_TYPE_FLOAT;
*TYPE_DOUBLE = *Preludec::IDMEFValue_TYPE_DOUBLE;
*TYPE_STRING = *Preludec::IDMEFValue_TYPE_STRING;
*TYPE_TIME = *Preludec::IDMEFValue_TYPE_TIME;
*TYPE_DATA = *Preludec::IDMEFValue_TYPE_DATA;
*TYPE_ENUM = *Preludec::IDMEFValue_TYPE_ENUM;
*TYPE_LIST = *Preludec::IDMEFValue_TYPE_LIST;
*TYPE_CLASS = *Preludec::IDMEFValue_TYPE_CLASS;
*getType = *Preludec::IDMEFValue_getType;
*isNull = *Preludec::IDMEFValue_isNull;
sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_IDMEFValue($self);
        delete $OWNER{$self};
    }
}

sub new {
    my $pkg = shift;
    my $self = Preludec::new_IDMEFValue(@_);
    bless $self, $pkg if defined($self);
}

*match = *Preludec::IDMEFValue_match;
*clone = *Preludec::IDMEFValue_clone;
*toString = *Preludec::IDMEFValue_toString;
*__le__ = *Preludec::IDMEFValue___le__;
*__ge__ = *Preludec::IDMEFValue___ge__;
*__lt__ = *Preludec::IDMEFValue___lt__;
*__gt__ = *Preludec::IDMEFValue___gt__;
*__eq__ = *Preludec::IDMEFValue___eq__;
*__ne__ = *Preludec::IDMEFValue___ne__;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::IDMEFPath ##############

package Prelude::IDMEFPath;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
sub new {
    my $pkg = shift;
    my $self = Preludec::new_IDMEFPath(@_);
    bless $self, $pkg if defined($self);
}

sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_IDMEFPath($self);
        delete $OWNER{$self};
    }
}

*set = *Preludec::IDMEFPath_set;
*getClass = *Preludec::IDMEFPath_getClass;
*getValueType = *Preludec::IDMEFPath_getValueType;
*setIndex = *Preludec::IDMEFPath_setIndex;
*undefineIndex = *Preludec::IDMEFPath_undefineIndex;
*getIndex = *Preludec::IDMEFPath_getIndex;
*makeChild = *Preludec::IDMEFPath_makeChild;
*makeParent = *Preludec::IDMEFPath_makeParent;
*compare = *Preludec::IDMEFPath_compare;
*clone = *Preludec::IDMEFPath_clone;
*checkOperator = *Preludec::IDMEFPath_checkOperator;
*getApplicableOperators = *Preludec::IDMEFPath_getApplicableOperators;
*getName = *Preludec::IDMEFPath_getName;
*isAmbiguous = *Preludec::IDMEFPath_isAmbiguous;
*hasLists = *Preludec::IDMEFPath_hasLists;
*isList = *Preludec::IDMEFPath_isList;
*getDepth = *Preludec::IDMEFPath_getDepth;
*get = *Preludec::IDMEFPath_get;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::IDMEFTime ##############

package Prelude::IDMEFTime;
use overload
    "<=" => sub { $_[0]->__le__($_[1])},
    "!=" => sub { $_[0]->__ne__($_[1])},
    ">=" => sub { $_[0]->__ge__($_[1])},
    "<" => sub { $_[0]->__lt__($_[1])},
    "==" => sub { $_[0]->__eq__($_[1])},
    ">" => sub { $_[0]->__gt__($_[1])},
    "=" => sub { my $class = ref($_[0]); $class->new($_[0]) },
    "fallback" => 1;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
sub new {
    my $pkg = shift;
    my $self = Preludec::new_IDMEFTime(@_);
    bless $self, $pkg if defined($self);
}

sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_IDMEFTime($self);
        delete $OWNER{$self};
    }
}

*set = *Preludec::IDMEFTime_set;
*setSec = *Preludec::IDMEFTime_setSec;
*setUSec = *Preludec::IDMEFTime_setUSec;
*setGmtOffset = *Preludec::IDMEFTime_setGmtOffset;
*getSec = *Preludec::IDMEFTime_getSec;
*getUSec = *Preludec::IDMEFTime_getUSec;
*getGmtOffset = *Preludec::IDMEFTime_getGmtOffset;
*getTime = *Preludec::IDMEFTime_getTime;
*clone = *Preludec::IDMEFTime_clone;
*toString = *Preludec::IDMEFTime_toString;
*__ne__ = *Preludec::IDMEFTime___ne__;
*__ge__ = *Preludec::IDMEFTime___ge__;
*__le__ = *Preludec::IDMEFTime___le__;
*__eq__ = *Preludec::IDMEFTime___eq__;
*__gt__ = *Preludec::IDMEFTime___gt__;
*__lt__ = *Preludec::IDMEFTime___lt__;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::IDMEFClass ##############

package Prelude::IDMEFClass;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
sub new {
    my $pkg = shift;
    my $self = Preludec::new_IDMEFClass(@_);
    bless $self, $pkg if defined($self);
}

*getDepth = *Preludec::IDMEFClass_getDepth;
*get = *Preludec::IDMEFClass_get;
*getChildCount = *Preludec::IDMEFClass_getChildCount;
*isList = *Preludec::IDMEFClass_isList;
*isKeyedList = *Preludec::IDMEFClass_isKeyedList;
*getName = *Preludec::IDMEFClass_getName;
*toString = *Preludec::IDMEFClass_toString;
*getValueType = *Preludec::IDMEFClass_getValueType;
*getAttributes = *Preludec::IDMEFClass_getAttributes;
*getPath = *Preludec::IDMEFClass_getPath;
*getEnumValues = *Preludec::IDMEFClass_getEnumValues;
*getApplicableOperator = *Preludec::IDMEFClass_getApplicableOperator;
sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_IDMEFClass($self);
        delete $OWNER{$self};
    }
}

sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


############# Class : Prelude::IDMEF ##############

package Prelude::IDMEF;
use overload
    "==" => sub { $_[0]->__eq__($_[1])},
    "=" => sub { my $class = ref($_[0]); $class->new($_[0]) },
    "fallback" => 1;
use vars qw(@ISA %OWNER %ITERATORS %BLESSEDMEMBERS);
@ISA = qw( Prelude );
%OWNER = ();
%ITERATORS = ();
sub DESTROY {
    return unless $_[0]->isa('HASH');
    my $self = tied(%{$_[0]});
    return unless defined $self;
    delete $ITERATORS{$self};
    if (exists $OWNER{$self}) {
        Preludec::delete_IDMEF($self);
        delete $OWNER{$self};
    }
}

sub new {
    my $pkg = shift;
    my $self = Preludec::new_IDMEF(@_);
    bless $self, $pkg if defined($self);
}

*set = *Preludec::IDMEF_set;
*clone = *Preludec::IDMEF_clone;
*getId = *Preludec::IDMEF_getId;
*toString = *Preludec::IDMEF_toString;
*toJSON = *Preludec::IDMEF_toJSON;
*__eq__ = *Preludec::IDMEF___eq__;
*write = *Preludec::IDMEF_write;
*read = *Preludec::IDMEF_read;
*get = *Preludec::IDMEF_get;
sub DISOWN {
    my $self = shift;
    my $ptr = tied(%$self);
    delete $OWNER{$ptr};
}

sub ACQUIRE {
    my $self = shift;
    my $ptr = tied(%$self);
    $OWNER{$ptr} = 1;
}


# ------- VARIABLE STUBS --------

package Prelude;

1;