Kryptostack
Classes | Public Member Functions | Protected Member Functions | Private Attributes | List of all members
SOA Class Reference

Semantic Object Array. More...

#include <socomp.h>

+ Inheritance diagram for SOA:
+ Collaboration diagram for SOA:

Classes

struct  SOAArray
 Semantic Object Array - array member class. More...
 

Public Member Functions

 SOA (size_t p_len=0, bool p_exec=false)
 Ctor.
 
void setSO (size_t p_index, SOp p_sop)
 Setter for an array object. More...
 
SOp at (size_t p_pos) const
 Returns a copy of the SOp at the given position. More...
 
SOAdup () const override
 Creates a new instance as copy following the red book definition. More...
 
SOAclone () const override
 Creates a new instance as copy with deep cloning. More...
 
std::string opequalequal () const override
 For operators '==' and 'pstack'. More...
 
OTCode ot () const override
 Returns an OTCode. More...
 
std::string type () const override
 Returns a type name. More...
 
bool equal (const SO *p_other) const override
 Equality. More...
 
size_t getSize () const override
 Getter for the number of characters or number of objects. More...
 
void reduce ()
 Reduces the array by one SO at the end. More...
 
void unfold2exec (Context &k) const
 Unfolds duplicates of the array-content to the execution stack.
 
SOp front_pop ()
 Returns a copy of the SOp at position 0 and removes this first position from the array. More...
 
void bind (Context &k)
 Replaces executable names with operator objects recursively into elements that are SOA.
 
- Public Member Functions inherited from SOcomp
std::string opequal () const override
 For operators '=', 'cvs' and 'stack'. More...
 
 SO (bool p_exec=false)
 Ctor.
 
- Public Member Functions inherited from SO
 SO (bool p_exec=false)
 Ctor.
 
virtual ~SO ()=default
 Virtual dtor. More...
 
bool getExec () const
 Getter for exec_.
 
void setExec (bool p_exec)
 Setter for exec_.
 
virtual size_t getSize () const
 Getter for the number of characters or number of objects. More...
 
virtual SOdup () const =0
 Creates a new instance as copy following the red book definition. More...
 
virtual SOclone () const
 Creates a new instance as copy with deep cloning. More...
 
virtual std::string opequal () const =0
 For operators '=', 'cvs' and 'stack'. More...
 
virtual std::string opequalequal () const
 For operators '==' and 'pstack'. More...
 
virtual OTCode ot () const =0
 Returns an OTCode. More...
 
virtual std::string type () const =0
 Returns a type name. More...
 
virtual bool equal (const SO *) const =0
 Equality. More...
 
virtual bool gt (const SO *) const
 Greater than. More...
 
virtual bool ge (const SO *) const
 Greater or equal. More...
 
- Public Member Functions inherited from Counter< SO >
 Counter (Counter< SO > &&)=delete
 
Counter< SO > & operator= (const Counter< SO > &)=delete
 
Counter< SO > & operator= (Counter< SO > &&)=delete
 

Protected Member Functions

bool invariant () const noexcept override
 Checks class invariants. More...
 
- Protected Member Functions inherited from Counter< SO >
 Counter ()
 Ctor.
 
 Counter (const Counter< SO > &)
 Copy ctor.
 
 ~Counter ()
 Dtor.
 
virtual bool invariant () const noexcept
 Checks the invariants of the class in which it is defined. More...
 

Private Attributes

std::shared_ptr< SOAArrayvec_
 The shared array.
 

Additional Inherited Members

- Static Public Member Functions inherited from Counter< SO >
static int getTotalCounter ()
 Static getter for totaly created objects.
 
static int getAliveCounter ()
 Static getter for objects alive.
 
static int getWatermarkCounter ()
 Static getter for the object counter watermark.
 

Detailed Description

Semantic Object Array.

SOA owns its objects.

Invariant
vec_ never is null
vec_.stlvec_ elements are never null

Member Function Documentation

◆ at()

SOp SOA::at ( size_t  p_pos) const
inline

Returns a copy of the SOp at the given position.

The arrays keeps ownership of the element.

Parameters
[in]p_posposition, which is not checked.
Precondition
p_pos < vectorsize

◆ clone()

SOA * SOA::clone ( ) const
overridevirtual

Creates a new instance as copy with deep cloning.

Postcondition
return value != nullptr
return value maintains invariants

Reimplemented from SO.

◆ dup()

SOA * SOA::dup ( ) const
inlineoverridevirtual

Creates a new instance as copy following the red book definition.

Implements SO.

◆ equal()

bool SOA::equal ( const SO ) const
inlineoverridevirtual

Equality.

Equality means: SOL und SOM are always equal.
For SOD and SOK, share_ptr<> points to the same object.
For SOA, share_ptr<> points to the same object, but empty arrays are equal nonetheless.
For SOO and SOo the function pointer must be the same.
Otherwise the value must be the same, even for SOS with shared_ptr<>.

Returns
bool ... true if the SO's are of the same type and equal
See also
Will be used directly and unchanged as operator eq

Implements SO.

◆ front_pop()

SOp SOA::front_pop ( )
inline

Returns a copy of the SOp at position 0 and removes this first position from the array.

Has an undefined result if size of vector is 0.

Precondition
vectorsize > 0

◆ getSize()

size_t SOA::getSize ( ) const
inlineoverridevirtual

Getter for the number of characters or number of objects.

Reimplemented from SO.

◆ invariant()

bool SOA::invariant ( ) const
inlineoverrideprotectedvirtualnoexcept

Checks class invariants.

Returns
bool ... Indicates whether the class invariants are maintained.

Reimplemented from DbC.

◆ opequalequal()

string SOA::opequalequal ( ) const
overridevirtual

For operators '==' and 'pstack'.

This function attempts to produce a result that resembles the red book syntax for creating the object.

Reimplemented from SO.

◆ ot()

OTCode SOA::ot ( ) const
inlineoverridevirtual

Returns an OTCode.

A "manual" implementation of polymorphism, where C++-polymorphisms fail

Returns
OTCode ... The OTCode of the instance.

Implements SO.

◆ reduce()

void SOA::reduce ( )

Reduces the array by one SO at the end.

The element will be deleted. An empty array stays unchanged without an error condition.

◆ setSO()

void SOA::setSO ( size_t  p_index,
SOp  p_sop 
)
inline

Setter for an array object.

The existing SOx will be deleted.

Parameters
[in]p_indexindex from 0 to size-1. Attention: no range check.
[in]p_sopthe SOA takes ownership of this SO.
Precondition
p_index < arraysize
p_sop != nullptr

◆ type()

std::string SOA::type ( ) const
inlineoverridevirtual

Returns a type name.

Returns
std::string ... The type name of the instance.

Implements SO.


The documentation for this class was generated from the following files: