mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-20 00:51:42 +00:00
Years update, references to WIND_BASE were removed, and WPILib license was moved to the root directory of the project. If there was already a comment block, a year range through 2016 was created using the first year in the comment. If there was no comment block, a block with just the year 2016 was added. Comments were not added to files from external sources (NI, CTRE). Change-Id: Iff4f098ab908b90b8d929902dea903de2f596acc
74 lines
2.8 KiB
C++
74 lines
2.8 KiB
C++
/*----------------------------------------------------------------------------*/
|
|
/* Copyright (c) FIRST 2011-2016. All Rights Reserved. */
|
|
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
|
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
|
/* the project. */
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
#pragma once
|
|
|
|
#include "ErrorBase.h"
|
|
#include "Task.h"
|
|
#include <map>
|
|
#include <string>
|
|
#include <vector>
|
|
#include "HAL/cpp/Semaphore.hpp"
|
|
#include "tables/ITableListener.h"
|
|
#include "networktables/NetworkTable.h"
|
|
|
|
/**
|
|
* The preferences class provides a relatively simple way to save important
|
|
* values to
|
|
* the RoboRIO to access the next time the RoboRIO is booted.
|
|
*
|
|
* <p>This class loads and saves from a file
|
|
* inside the RoboRIO. The user can not access the file directly, but may
|
|
* modify values at specific
|
|
* fields which will then be automatically periodically saved to the file
|
|
* by the NetworkTable server.</p>
|
|
*
|
|
* <p>This class is thread safe.</p>
|
|
*
|
|
* <p>This will also interact with {@link NetworkTable} by creating a table
|
|
* called "Preferences" with all the key-value pairs.</p>
|
|
*/
|
|
class Preferences : public ErrorBase {
|
|
public:
|
|
static Preferences *GetInstance();
|
|
|
|
std::vector<std::string> GetKeys();
|
|
std::string GetString(llvm::StringRef key, llvm::StringRef defaultValue = "");
|
|
int GetInt(llvm::StringRef key, int defaultValue = 0);
|
|
double GetDouble(llvm::StringRef key, double defaultValue = 0.0);
|
|
float GetFloat(llvm::StringRef key, float defaultValue = 0.0);
|
|
bool GetBoolean(llvm::StringRef key, bool defaultValue = false);
|
|
int64_t GetLong(llvm::StringRef key, int64_t defaultValue = 0);
|
|
void PutString(llvm::StringRef key, llvm::StringRef value);
|
|
void PutInt(llvm::StringRef key, int value);
|
|
void PutDouble(llvm::StringRef key, double value);
|
|
void PutFloat(llvm::StringRef key, float value);
|
|
void PutBoolean(llvm::StringRef key, bool value);
|
|
void PutLong(llvm::StringRef key, int64_t value);
|
|
DEPRECATED(
|
|
"Saving is now automatically performed by the NetworkTables server.")
|
|
void Save();
|
|
bool ContainsKey(llvm::StringRef key);
|
|
void Remove(llvm::StringRef key);
|
|
|
|
protected:
|
|
Preferences();
|
|
virtual ~Preferences() = default;
|
|
|
|
private:
|
|
std::shared_ptr<ITable> m_table;
|
|
class Listener : public ITableListener {
|
|
public:
|
|
void ValueChanged(ITable* source, llvm::StringRef key,
|
|
std::shared_ptr<nt::Value> value, bool isNew) override;
|
|
void ValueChangedEx(ITable* source, llvm::StringRef key,
|
|
std::shared_ptr<nt::Value> value,
|
|
unsigned int flags) override;
|
|
};
|
|
Listener m_listener;
|
|
};
|