#include "storage_function.h" #include #include #include #include using namespace Poincare; namespace Shared { char StorageFunction::k_parenthesedArgument[]("(x)"); bool StorageFunction::BaseNameCompliant(const char * baseName) { if (baseName[0] == 0 || (baseName[0] >= '0' && baseName[0] <= '9')) { // The name cannot be empty nor start with a number return false; } const char * currentChar = baseName; while (*currentChar != 0) { if (!((*currentChar >= 'A' && *currentChar <= 'Z') || (*currentChar >= 'a' && *currentChar <= 'z') || (*currentChar >= '0' && *currentChar <= '9') || *currentChar == '_')) { return false; } currentChar++; } return true; } uint32_t StorageFunction::checksum() { assert(!isNull()); return checksum(); } bool StorageFunction::isActive() const { return recordData()->isActive(); } KDColor StorageFunction::color() const { return recordData()->color(); } void StorageFunction::setActive(bool active) { recordData()->setActive(active); } int StorageFunction::nameWithArgument(char * buffer, size_t bufferSize, char arg) { const char * functionName = fullName(); k_parenthesedArgument[1] = arg; size_t baseNameLength = SymbolAbstract::TruncateExtension(buffer, functionName, bufferSize - k_parenthesedArgumentLength); return baseNameLength + strlcpy(&buffer[baseNameLength], k_parenthesedArgument, bufferSize-baseNameLength); } template T StorageFunction::templatedApproximateAtAbscissa(T x, Poincare::Context * context) const { const char unknownX[2] = {Poincare::Symbol::UnknownX, 0}; return expression(context).approximateWithValueForSymbol(unknownX, x, *context, Preferences::sharedPreferences()->angleUnit()); } StorageFunction::FunctionRecordData * StorageFunction::recordData() const { assert(!isNull()); Ion::Storage::Record::Data d = value(); return reinterpret_cast(const_cast(d.buffer)); } } template float Shared::StorageFunction::templatedApproximateAtAbscissa(float, Poincare::Context*) const; template double Shared::StorageFunction::templatedApproximateAtAbscissa(double, Poincare::Context*) const;