# pragma region License
/*
License ( OLC - 3 )
~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
Copyright 2024 Joshua Sigona < sigonasr2 @ gmail . com >
Redistribution and use in source and binary forms , with or without modification ,
are permitted provided that the following conditions are met :
1. Redistributions or derivations of source code must retain the above copyright
notice , this list of conditions and the following disclaimer .
2. Redistributions or derivative works in binary form must reproduce the above
copyright notice . This list of conditions and the following disclaimer must be
reproduced in the documentation and / or other materials provided with the distribution .
3. Neither the name of the copyright holder nor the names of its contributors may
be used to endorse or promote products derived from this software without specific
prior written permission .
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS " AS IS " AND ANY
EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE IMPLIED WARRANTIES
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT
SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT , INDIRECT ,
INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT NOT LIMITED
TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR
BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN
CONTRACT , STRICT LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN
ANY WAY OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF
SUCH DAMAGE .
Portions of this software are copyright <EFBFBD> 2023 The FreeType
Project ( www . freetype . org ) . Please see LICENSE_FT . txt for more information .
All rights reserved .
*/
# pragma endregion
# pragma once
# include "Error.h"
# include <format>
# include "IT.h"
using namespace std : : literals ;
struct FunctionPrimingData {
bool primed = false ;
std : : string dependentFunction = " " ;
inline FunctionPrimingData ( std : : string dependentFunction )
: dependentFunction ( dependentFunction ) { }
bool operator = ( bool rhs ) {
return primed = rhs ;
}
} ;
struct MerchantFunctionPrimingData : public FunctionPrimingData {
IT item = " " s ;
uint32_t amt = 0 ;
inline MerchantFunctionPrimingData ( std : : string dependentFunction )
: FunctionPrimingData ( dependentFunction ) { }
virtual inline void Validate ( IT item , uint32_t amt ) {
if ( ! primed ) ERR ( std : : format ( " WARNING! {} should be called before running this function! Priming Requirement! " , dependentFunction ) ) ;
if ( this - > item ! = item ) ERR ( std : : format ( " WARNING! Primed items are not matching! {}!={} " , std : : string ( this - > item ) , std : : string ( item ) ) ) ;
if ( this - > amt ! = amt ) ERR ( std : : format ( " WARNING! Primed amounts are not matching! {}!={} " , this - > amt , amt ) ) ;
primed = false ;
}
bool operator = ( bool rhs ) {
return primed = rhs ;
}
} ;
struct ItemEnhancementFunctionPrimingData : public FunctionPrimingData {
IT item = " " s ;
uint8_t enhancementLevel = 0 ;
uint8_t qty = 0 ;
inline ItemEnhancementFunctionPrimingData ( std : : string dependentFunction )
: FunctionPrimingData ( dependentFunction ) { }
virtual inline void Validate ( IT item , uint8_t enhancementLevel , uint8_t qty ) {
if ( ! primed ) ERR ( std : : format ( " WARNING! {} should be called before running this function! Priming Requirement! " , dependentFunction ) ) ;
if ( this - > item ! = item ) ERR ( std : : format ( " WARNING! Primed items are not matching! {}!={} " , std : : string ( this - > item ) , std : : string ( item ) ) ) ;
if ( this - > qty ! = qty ) ERR ( std : : format ( " WARNING! Primed items do not have the same quantity! {}!={} " , this - > qty , qty ) ) ;
if ( this - > enhancementLevel ! = enhancementLevel ) ERR ( std : : format ( " WARNING! Primed enhancement levels are not matching! {}!={} " , this - > enhancementLevel , enhancementLevel ) ) ;
primed = false ;
}
bool operator = ( bool rhs ) {
return primed = rhs ;
}
} ;