Improve:SharedData module.
This commit is contained in:
parent
1e42c00ae2
commit
8aaf9b4074
|
@ -24,22 +24,22 @@ TEST(SharedDataTest, Demo)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataMinor) {
|
if (nullptr != sharedDataMinor) {
|
||||||
int writableData = 99;
|
int writableData = 99;
|
||||||
sharedDataMinor->mMakeSharedData(sharedDataMinor, sizeof(int), sizeof(int));
|
IMakeSharedData(sharedDataMinor, sizeof(int), sizeof(int));
|
||||||
sharedDataMinor->mSetWritableData(sharedDataMinor, &writableData, sizeof(int));
|
ISetWritableData(sharedDataMinor, &writableData, sizeof(int));
|
||||||
}
|
}
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
int readableData = -1;
|
int readableData = -1;
|
||||||
sharedDataPrimary->mMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
||||||
sharedDataPrimary->mGetReadableData(sharedDataPrimary, &readableData, sizeof(int));
|
IGetReadableData(sharedDataPrimary, &readableData, sizeof(int));
|
||||||
LogInfo("readableData = %d\n", readableData);
|
LogInfo("readableData = %d\n", readableData);
|
||||||
sharedDataPrimary->mFree(sharedDataPrimary);
|
IShareDataFree(sharedDataPrimary);
|
||||||
}
|
}
|
||||||
if (nullptr != sharedDataMinor) {
|
if (nullptr != sharedDataMinor) {
|
||||||
sharedDataMinor->mFree(sharedDataMinor);
|
IShareDataFree(sharedDataMinor);
|
||||||
}
|
}
|
||||||
ILogUnInit();
|
ILogUnInit();
|
||||||
}
|
}
|
||||||
|
@ -50,8 +50,8 @@ TEST(SharedDataTest, Demo2)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataMinor) {
|
if (nullptr != sharedDataMinor) {
|
||||||
IMakeSharedData(sharedDataMinor, sizeof(int), sizeof(int));
|
IMakeSharedData(sharedDataMinor, sizeof(int), sizeof(int));
|
||||||
ISetWritableData(sharedDataMinor, (void *)&WRITABLE_DATA, sizeof(int));
|
ISetWritableData(sharedDataMinor, (void *)&WRITABLE_DATA, sizeof(int));
|
||||||
|
@ -76,8 +76,8 @@ TEST(SharedDataTest, Demo3)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataMinor) {
|
if (nullptr != sharedDataMinor) {
|
||||||
constexpr int WRITABLE_DATA_LENGTH = 9;
|
constexpr int WRITABLE_DATA_LENGTH = 9;
|
||||||
char writableData[WRITABLE_DATA_LENGTH] = {0};
|
char writableData[WRITABLE_DATA_LENGTH] = {0};
|
||||||
|
@ -107,8 +107,8 @@ TEST(SharedDataTest, Demo4)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataMinor) {
|
if (nullptr != sharedDataMinor) {
|
||||||
IMakeSharedData(sharedDataMinor, sizeof(int) * 2, sizeof(int));
|
IMakeSharedData(sharedDataMinor, sizeof(int) * 2, sizeof(int));
|
||||||
ISetWritableData(sharedDataMinor, (void *)&WRITABLE_DATA, sizeof(int));
|
ISetWritableData(sharedDataMinor, (void *)&WRITABLE_DATA, sizeof(int));
|
||||||
|
@ -135,7 +135,7 @@ TEST(SharedDataTest, Demo5)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
constexpr int DEFAULT_DATA = 0;
|
constexpr int DEFAULT_DATA = 0;
|
||||||
int readableData = DEFAULT_DATA;
|
int readableData = DEFAULT_DATA;
|
||||||
|
@ -155,8 +155,8 @@ TEST(SharedDataTest, Demo6)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
constexpr int DEFAULT_DATA = 0;
|
constexpr int DEFAULT_DATA = 0;
|
||||||
int readableData = DEFAULT_DATA;
|
int readableData = DEFAULT_DATA;
|
||||||
|
@ -180,8 +180,8 @@ TEST(SharedDataTest, Demo7)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
||||||
ISetWritableData(sharedDataPrimary, (void *)&WRITABLE_DATA, sizeof(int));
|
ISetWritableData(sharedDataPrimary, (void *)&WRITABLE_DATA, sizeof(int));
|
||||||
|
@ -209,8 +209,8 @@ TEST(SharedDataTest, UNIT_SharedData_DEME_Demo7)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
IMakeSharedData(sharedDataPrimary, sizeof(int) * 2, sizeof(int));
|
IMakeSharedData(sharedDataPrimary, sizeof(int) * 2, sizeof(int));
|
||||||
ISetWritableData(sharedDataPrimary, (void *)&WRITABLE_DATA, sizeof(int));
|
ISetWritableData(sharedDataPrimary, (void *)&WRITABLE_DATA, sizeof(int));
|
||||||
|
@ -237,8 +237,8 @@ TEST(SharedDataTest, UNIT_SharedData_DEME_Demo8)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
int writableData[2] = {0};
|
int writableData[2] = {0};
|
||||||
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int) * 2);
|
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int) * 2);
|
||||||
|
@ -267,8 +267,8 @@ TEST(SharedDataTest, UNIT_SharedData_DEME_Demo9)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
||||||
ISetWritableData(sharedDataPrimary, (void *)&WRITABLE_DATA, sizeof(int));
|
ISetWritableData(sharedDataPrimary, (void *)&WRITABLE_DATA, sizeof(int));
|
||||||
|
@ -296,8 +296,8 @@ TEST(SharedDataTest, UNIT_SharedData_DEME_Demo10)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
||||||
ISetWritableData(sharedDataPrimary, (void *)&WRITABLE_DATA, sizeof(int));
|
ISetWritableData(sharedDataPrimary, (void *)&WRITABLE_DATA, sizeof(int));
|
||||||
|
@ -323,8 +323,8 @@ TEST(SharedDataTest, UNIT_SharedData_DEME_Demo11)
|
||||||
CreateLogModule();
|
CreateLogModule();
|
||||||
ILogInit(LOG_INSTANCE_TYPE_END);
|
ILogInit(LOG_INSTANCE_TYPE_END);
|
||||||
constexpr int PROJECT_ID = 9;
|
constexpr int PROJECT_ID = 9;
|
||||||
SharedData *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
void *sharedDataPrimary = CreateSharedData(SHARER_NAME_PRIMARY, "./shared_file", PROJECT_ID);
|
||||||
SharedData *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
void *sharedDataMinor = CreateSharedData(SHARER_NAME_MINOR, "./shared_file", PROJECT_ID);
|
||||||
IMakeSharedData(sharedDataMinor, sizeof(int), sizeof(int));
|
IMakeSharedData(sharedDataMinor, sizeof(int), sizeof(int));
|
||||||
if (nullptr != sharedDataPrimary) {
|
if (nullptr != sharedDataPrimary) {
|
||||||
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
IMakeSharedData(sharedDataPrimary, sizeof(int), sizeof(int));
|
||||||
|
|
|
@ -105,7 +105,7 @@ const char *GetConfigBaseModuleName(void)
|
||||||
}
|
}
|
||||||
std::shared_ptr<IConfigBase> *NewConfigBase(const char *fileName)
|
std::shared_ptr<IConfigBase> *NewConfigBase(const char *fileName)
|
||||||
{
|
{
|
||||||
LogInfo("Create the uart device object.\n");
|
LogInfo("Create the config base object.\n");
|
||||||
ConfigBase *impl = (ConfigBase *)malloc(sizeof(ConfigBase));
|
ConfigBase *impl = (ConfigBase *)malloc(sizeof(ConfigBase));
|
||||||
if (nullptr == impl) {
|
if (nullptr == impl) {
|
||||||
LogError("NewConfigBase::malloc failed.\n");
|
LogError("NewConfigBase::malloc failed.\n");
|
||||||
|
|
|
@ -13,8 +13,6 @@ include_directories(
|
||||||
# ${EXTERNAL_SOURCE_PATH}/libconfig/libconfig-1.7.3/lib/.libs
|
# ${EXTERNAL_SOURCE_PATH}/libconfig/libconfig-1.7.3/lib/.libs
|
||||||
# )
|
# )
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
aux_source_directory(./src SRC_FILES)
|
aux_source_directory(./src SRC_FILES)
|
||||||
|
|
||||||
set(TARGET_NAME SharedData)
|
set(TARGET_NAME SharedData)
|
||||||
|
|
|
@ -30,37 +30,12 @@ enum SHARER_NAME
|
||||||
SHARER_NAME_MINOR,
|
SHARER_NAME_MINOR,
|
||||||
SHARER_NAME_END
|
SHARER_NAME_END
|
||||||
};
|
};
|
||||||
typedef struct shared_data SharedData;
|
void *CreateSharedData(const enum SHARER_NAME name, const char *path, const int projectId);
|
||||||
typedef struct shared_data
|
const StatusCode IMakeSharedData(void *object, const unsigned int readableSize, const unsigned int writableSize);
|
||||||
{
|
const StatusCode ICleanSharedData(void *object);
|
||||||
const StatusCode (*mMakeSharedData)(SharedData *, const unsigned int, const unsigned int);
|
const StatusCode IGetReadableData(void *object, void *buf, const unsigned int bufLength);
|
||||||
const StatusCode (*mCleanSharedData)(SharedData *);
|
void ISetWritableData(void *object, void *buf, const unsigned int bufLength);
|
||||||
const StatusCode (*mGetReadableData)(SharedData *, void *, const unsigned int);
|
void IShareDataFree(void *object);
|
||||||
void (*mSetWritableData)(SharedData *, void *, const unsigned int);
|
|
||||||
void (*mFree)(void *);
|
|
||||||
} SharedData;
|
|
||||||
SharedData *CreateSharedData(const enum SHARER_NAME name, const char *path, const int projectId);
|
|
||||||
static inline const StatusCode IMakeSharedData(SharedData *object, const unsigned int readableSize,
|
|
||||||
const unsigned int writableSize)
|
|
||||||
{
|
|
||||||
return object->mMakeSharedData(object, readableSize, writableSize);
|
|
||||||
}
|
|
||||||
static inline const StatusCode ICleanSharedData(SharedData *object)
|
|
||||||
{
|
|
||||||
return object->mCleanSharedData(object);
|
|
||||||
}
|
|
||||||
static inline const StatusCode IGetReadableData(SharedData *object, void *buf, const unsigned int bufLength)
|
|
||||||
{
|
|
||||||
return object->mGetReadableData(object, buf, bufLength);
|
|
||||||
}
|
|
||||||
static inline void ISetWritableData(SharedData *object, void *buf, const unsigned int bufLength)
|
|
||||||
{
|
|
||||||
object->mSetWritableData(object, buf, bufLength);
|
|
||||||
}
|
|
||||||
static inline void IShareDataFree(SharedData *object)
|
|
||||||
{
|
|
||||||
object->mFree(object);
|
|
||||||
}
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
51
utils/SharedData/src/ISharedData.cpp
Normal file
51
utils/SharedData/src/ISharedData.cpp
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2023 Fancy Code.
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#include "ISharedData.h"
|
||||||
|
#include "ILog.h"
|
||||||
|
#include "SharedDataImpl.h" // TODO: 互相包含,需要修改
|
||||||
|
#include <string.h>
|
||||||
|
void ISharedData::MakeSharedMemory(const unsigned int readableSize, const unsigned int writableSize)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
const StatusCode ISharedData::GetReadableMemory(void *buf, const unsigned int &bufLength)
|
||||||
|
{
|
||||||
|
return CreateStatusCode(STATUS_CODE_VIRTUAL_FUNCTION);
|
||||||
|
}
|
||||||
|
void ISharedData::SetWritableMemory(void *buf, const unsigned int &bufLength)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
StatusCode ISharedData::FreeSharedMemory(void)
|
||||||
|
{
|
||||||
|
return CreateStatusCode(STATUS_CODE_VIRTUAL_FUNCTION);
|
||||||
|
}
|
||||||
|
static const char *SHARED_DATA_NAME = "shared_data";
|
||||||
|
const char *GetSharedDataModuleName(void)
|
||||||
|
{
|
||||||
|
return SHARED_DATA_NAME;
|
||||||
|
}
|
||||||
|
std::shared_ptr<ISharedData> *NewSharedData(const enum SHARER_NAME &name, const char *path, const int &projectId)
|
||||||
|
{
|
||||||
|
LogInfo("Create the shared data object.\n");
|
||||||
|
SharedData *impl = (SharedData *)malloc(sizeof(SharedData));
|
||||||
|
if (nullptr == impl) {
|
||||||
|
LogError("NewConfigBase::malloc failed.\n");
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
SharedData tmp;
|
||||||
|
memcpy((void *)impl, (void *)&tmp, sizeof(SharedData));
|
||||||
|
impl->mHeader.mCheckName = SHARED_DATA_NAME;
|
||||||
|
impl->mISharedData = std::make_shared<SharedDataImpl>(name, path, projectId);
|
||||||
|
return (std::shared_ptr<ISharedData> *)(((char *)impl) + sizeof(ISharedDataHeader));
|
||||||
|
}
|
41
utils/SharedData/src/ISharedData.h
Normal file
41
utils/SharedData/src/ISharedData.h
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2023 Fancy Code.
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef I_SHARED_DATA_H
|
||||||
|
#define I_SHARED_DATA_H
|
||||||
|
#include "SharedData.h"
|
||||||
|
#include "StatusCode.h"
|
||||||
|
#include <memory>
|
||||||
|
class ISharedData
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
ISharedData() = default;
|
||||||
|
virtual ~ISharedData() = default;
|
||||||
|
virtual void MakeSharedMemory(const unsigned int readableSize, const unsigned int writableSize);
|
||||||
|
virtual const StatusCode GetReadableMemory(void *buf, const unsigned int &bufLength);
|
||||||
|
virtual void SetWritableMemory(void *buf, const unsigned int &bufLength);
|
||||||
|
virtual StatusCode FreeSharedMemory(void);
|
||||||
|
};
|
||||||
|
typedef struct i_shared_data_header
|
||||||
|
{
|
||||||
|
const char *mCheckName;
|
||||||
|
} ISharedDataHeader;
|
||||||
|
typedef struct config_base
|
||||||
|
{
|
||||||
|
ISharedDataHeader mHeader;
|
||||||
|
std::shared_ptr<ISharedData> mISharedData;
|
||||||
|
} SharedData;
|
||||||
|
const char *GetSharedDataModuleName(void);
|
||||||
|
std::shared_ptr<ISharedData> *NewSharedData(const enum SHARER_NAME &name, const char *path, const int &projectId);
|
||||||
|
#endif
|
|
@ -13,8 +13,62 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
#include "SharedData.h"
|
#include "SharedData.h"
|
||||||
#include "SharedDataImpl.h"
|
#include "ILog.h"
|
||||||
SharedData *CreateSharedData(const enum SHARER_NAME name, const char *path, const int projectId)
|
#include "ISharedData.h"
|
||||||
|
static bool ObjectCheck(void *object)
|
||||||
{
|
{
|
||||||
return (SharedData *)NewSharedDataImpl(name, path, projectId);
|
if (nullptr == object) {
|
||||||
|
LogError("nullptr object!\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (*((const char **)(((char *)object) - sizeof(ISharedDataHeader))) != GetSharedDataModuleName()) {
|
||||||
|
LogError("Illegal object!\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
void *CreateSharedData(const enum SHARER_NAME name, const char *path, const int projectId)
|
||||||
|
{
|
||||||
|
std::shared_ptr<ISharedData> *sharedDataObject = NewSharedData(name, path, projectId);
|
||||||
|
if (nullptr != sharedDataObject) {
|
||||||
|
// (*sharedDataObject)->OpenConfigFile();
|
||||||
|
}
|
||||||
|
return sharedDataObject;
|
||||||
|
}
|
||||||
|
const StatusCode IMakeSharedData(void *object, const unsigned int readableSize, const unsigned int writableSize)
|
||||||
|
{
|
||||||
|
if (ObjectCheck(object) == true) {
|
||||||
|
(*(std::shared_ptr<ISharedData> *)object)->MakeSharedMemory(readableSize, writableSize);
|
||||||
|
return CreateStatusCode(STATUS_CODE_OK);
|
||||||
|
}
|
||||||
|
return CreateStatusCode(STATUS_CODE_INVALID_PARAMENTER);
|
||||||
|
}
|
||||||
|
const StatusCode ICleanSharedData(void *object)
|
||||||
|
{
|
||||||
|
if (ObjectCheck(object) == true) {
|
||||||
|
// (*(std::shared_ptr<ISharedData> *)object)->MakeSharedMemory(readableSize, writableSize);
|
||||||
|
return CreateStatusCode(STATUS_CODE_INVALID_PARAMENTER);
|
||||||
|
}
|
||||||
|
return CreateStatusCode(STATUS_CODE_INVALID_PARAMENTER);
|
||||||
|
}
|
||||||
|
const StatusCode IGetReadableData(void *object, void *buf, const unsigned int bufLength)
|
||||||
|
{
|
||||||
|
if (ObjectCheck(object) == true) {
|
||||||
|
return (*(std::shared_ptr<ISharedData> *)object)->GetReadableMemory(buf, bufLength);
|
||||||
|
}
|
||||||
|
return CreateStatusCode(STATUS_CODE_INVALID_PARAMENTER);
|
||||||
|
}
|
||||||
|
void ISetWritableData(void *object, void *buf, const unsigned int bufLength)
|
||||||
|
{
|
||||||
|
if (ObjectCheck(object) == true) {
|
||||||
|
(*(std::shared_ptr<ISharedData> *)object)->SetWritableMemory(buf, bufLength);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void IShareDataFree(void *object)
|
||||||
|
{
|
||||||
|
if (ObjectCheck(object) == true) {
|
||||||
|
(*(std::shared_ptr<ISharedData> *)object)->FreeSharedMemory();
|
||||||
|
(*(std::shared_ptr<ISharedData> *)object).reset();
|
||||||
|
free(((char *)object) - sizeof(ISharedDataHeader));
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -18,14 +18,14 @@
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
static const char *SHARED_DATA_NAME = "shared_data";
|
static const char *SHARED_DATA_NAME = "shared_data";
|
||||||
constexpr short THERE_TWO_USER_DATA_HEADER = 2;
|
constexpr short THERE_TWO_USER_DATA_HEADER = 2;
|
||||||
SharedDataCpp::SharedDataCpp(const SHARER_NAME &sharerName, const char *path, const int &projectId)
|
SharedDataImpl::SharedDataImpl(const SHARER_NAME &sharerName, const char *path, const int &projectId)
|
||||||
: SharedMemory(path, projectId), mSharerName(sharerName)
|
: SharedMemory(path, projectId), mSharerName(sharerName)
|
||||||
{
|
{
|
||||||
mPrimaryReadSize = 0;
|
mPrimaryReadSize = 0;
|
||||||
mMinorReadSize = 0;
|
mMinorReadSize = 0;
|
||||||
mSharedMemeory = nullptr;
|
mSharedMemeory = nullptr;
|
||||||
}
|
}
|
||||||
void SharedDataCpp::MakeSharedMemory(const unsigned int readableSize, const unsigned int writableSize)
|
void SharedDataImpl::MakeSharedMemory(const unsigned int readableSize, const unsigned int writableSize)
|
||||||
{
|
{
|
||||||
if (SHARER_NAME_PRIMARY == mSharerName) {
|
if (SHARER_NAME_PRIMARY == mSharerName) {
|
||||||
mPrimaryReadSize = readableSize;
|
mPrimaryReadSize = readableSize;
|
||||||
|
@ -44,29 +44,7 @@ void SharedDataCpp::MakeSharedMemory(const unsigned int readableSize, const unsi
|
||||||
mSharedMemeory = SharedMemory::GetMemory();
|
mSharedMemeory = SharedMemory::GetMemory();
|
||||||
WritableDataInit();
|
WritableDataInit();
|
||||||
}
|
}
|
||||||
void SharedDataCpp::WritableDataInit(void)
|
const StatusCode SharedDataImpl::GetReadableMemory(void *buf, const unsigned int &bufLength)
|
||||||
{
|
|
||||||
if (nullptr == mSharedMemeory) {
|
|
||||||
LogError("mSharedMemeory is nullptr, failed.\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (SHARER_NAME_PRIMARY == mSharerName) {
|
|
||||||
UserDataHeader *writableHeader =
|
|
||||||
(UserDataHeader *)((char *)mSharedMemeory + sizeof(UserDataHeader) + mPrimaryReadSize);
|
|
||||||
memcpy(writableHeader->mUserName, USER_NAME_INIT_NAME, USER_NAME_BUF_LENGTH);
|
|
||||||
writableHeader->mDataLength = mMinorReadSize;
|
|
||||||
}
|
|
||||||
else if (SHARER_NAME_MINOR == mSharerName) {
|
|
||||||
UserDataHeader *writableHeader = (UserDataHeader *)((char *)mSharedMemeory);
|
|
||||||
memcpy(writableHeader->mUserName, USER_NAME_INIT_NAME, USER_NAME_BUF_LENGTH);
|
|
||||||
writableHeader->mDataLength = mPrimaryReadSize;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
LogError("Make shared memory failed.\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
const StatusCode SharedDataCpp::GetReadableMemory(void *buf, const unsigned int &bufLength)
|
|
||||||
{
|
{
|
||||||
if (nullptr == mSharedMemeory) {
|
if (nullptr == mSharedMemeory) {
|
||||||
LogError("mSharedMemeory is nullptr, failed.\n");
|
LogError("mSharedMemeory is nullptr, failed.\n");
|
||||||
|
@ -105,7 +83,7 @@ const StatusCode SharedDataCpp::GetReadableMemory(void *buf, const unsigned int
|
||||||
}
|
}
|
||||||
return CreateStatusCode(STATUS_CODE_OK);
|
return CreateStatusCode(STATUS_CODE_OK);
|
||||||
}
|
}
|
||||||
void SharedDataCpp::SetWritableMemory(void *buf, const unsigned int &bufLength)
|
void SharedDataImpl::SetWritableMemory(void *buf, const unsigned int &bufLength)
|
||||||
{
|
{
|
||||||
if (nullptr == mSharedMemeory) {
|
if (nullptr == mSharedMemeory) {
|
||||||
LogError("mSharedMemeory is nullptr, failed.\n");
|
LogError("mSharedMemeory is nullptr, failed.\n");
|
||||||
|
@ -136,45 +114,29 @@ void SharedDataCpp::SetWritableMemory(void *buf, const unsigned int &bufLength)
|
||||||
LogError("Set writable memory failed.\n");
|
LogError("Set writable memory failed.\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
static const StatusCode MakeSharedData(SharedData *object, const unsigned int readableSize,
|
StatusCode SharedDataImpl::FreeSharedMemory(void)
|
||||||
const unsigned int writableSize)
|
|
||||||
{
|
{
|
||||||
SharedDataImpl *impl = ((SharedDataImpl *)(((char *)object) - sizeof(SharedDataHeader)));
|
return CleanSharedMemory();
|
||||||
impl->mSharedData->MakeSharedMemory(readableSize, writableSize);
|
|
||||||
return CreateStatusCode(STATUS_CODE_OK);
|
|
||||||
}
|
}
|
||||||
static const StatusCode GetSharedReadableMemory(SharedData *object, void *buf, const unsigned int bufLength)
|
void SharedDataImpl::WritableDataInit(void)
|
||||||
{
|
{
|
||||||
SharedDataImpl *impl = ((SharedDataImpl *)(((char *)object) - sizeof(SharedDataHeader)));
|
if (nullptr == mSharedMemeory) {
|
||||||
return impl->mSharedData->GetReadableMemory(buf, bufLength);
|
LogError("mSharedMemeory is nullptr, failed.\n");
|
||||||
}
|
return;
|
||||||
static void SetSharedWritableMemory(SharedData *object, void *buf, const unsigned int bufLength)
|
}
|
||||||
{
|
if (SHARER_NAME_PRIMARY == mSharerName) {
|
||||||
SharedDataImpl *impl = ((SharedDataImpl *)(((char *)object) - sizeof(SharedDataHeader)));
|
UserDataHeader *writableHeader =
|
||||||
impl->mSharedData->SetWritableMemory(buf, bufLength);
|
(UserDataHeader *)((char *)mSharedMemeory + sizeof(UserDataHeader) + mPrimaryReadSize);
|
||||||
}
|
memcpy(writableHeader->mUserName, USER_NAME_INIT_NAME, USER_NAME_BUF_LENGTH);
|
||||||
static void SharedDataImplFree(void *ptr)
|
writableHeader->mDataLength = mMinorReadSize;
|
||||||
{
|
}
|
||||||
SharedDataImpl *object = ((SharedDataImpl *)(((char *)ptr) - sizeof(SharedDataHeader)));
|
else if (SHARER_NAME_MINOR == mSharerName) {
|
||||||
if (SHARED_DATA_NAME == object->mHeader.mCheckName) {
|
UserDataHeader *writableHeader = (UserDataHeader *)((char *)mSharedMemeory);
|
||||||
object->mSharedData->CleanSharedMemory();
|
memcpy(writableHeader->mUserName, USER_NAME_INIT_NAME, USER_NAME_BUF_LENGTH);
|
||||||
object->mSharedData = nullptr;
|
writableHeader->mDataLength = mPrimaryReadSize;
|
||||||
free(((char *)ptr) - sizeof(SharedDataHeader));
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
LogError("Unknow ptr.\n");
|
LogError("Make shared memory failed.\n");
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
SharedData *NewSharedDataImpl(const SHARER_NAME &name, const char *path, const int &projectId)
|
|
||||||
{
|
|
||||||
SharedDataImpl *impl = (SharedDataImpl *)malloc(sizeof(SharedDataImpl));
|
|
||||||
SharedDataImpl tmp;
|
|
||||||
memcpy((void *)impl, (void *)&tmp, sizeof(SharedDataImpl));
|
|
||||||
impl->mHeader.mCheckName = SHARED_DATA_NAME;
|
|
||||||
impl->mBase.mMakeSharedData = MakeSharedData;
|
|
||||||
impl->mBase.mGetReadableData = GetSharedReadableMemory;
|
|
||||||
impl->mBase.mSetWritableData = SetSharedWritableMemory;
|
|
||||||
impl->mBase.mFree = SharedDataImplFree;
|
|
||||||
impl->mSharedData = std::make_shared<SharedDataCpp>(name, path, projectId);
|
|
||||||
return (SharedData *)(((char *)impl) + sizeof(SharedDataHeader));
|
|
||||||
}
|
|
|
@ -14,10 +14,10 @@
|
||||||
*/
|
*/
|
||||||
#ifndef SHARED_DATA_IMPL_H
|
#ifndef SHARED_DATA_IMPL_H
|
||||||
#define SHARED_DATA_IMPL_H
|
#define SHARED_DATA_IMPL_H
|
||||||
#include "SharedData.h"
|
#include "ISharedData.h"
|
||||||
#include "SharedMemory.h"
|
#include "SharedMemory.h"
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <mutex>
|
// #include <mutex>
|
||||||
constexpr int USER_NAME_BUF_LENGTH = 4;
|
constexpr int USER_NAME_BUF_LENGTH = 4;
|
||||||
#define USER_NAME_INIT_NAME "XING"
|
#define USER_NAME_INIT_NAME "XING"
|
||||||
enum USER_DATA_INIT
|
enum USER_DATA_INIT
|
||||||
|
@ -41,14 +41,15 @@ typedef struct user_data_header
|
||||||
unsigned int mDataLength;
|
unsigned int mDataLength;
|
||||||
int mIsInit;
|
int mIsInit;
|
||||||
} UserDataHeader;
|
} UserDataHeader;
|
||||||
class SharedDataCpp : public SharedMemory
|
class SharedDataImpl : public ISharedData, public SharedMemory
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
SharedDataCpp(const SHARER_NAME &sharerName, const char *path, const int &projectId);
|
SharedDataImpl(const SHARER_NAME &sharerName, const char *path, const int &projectId);
|
||||||
virtual ~SharedDataCpp() = default;
|
virtual ~SharedDataImpl() = default;
|
||||||
void MakeSharedMemory(const unsigned int readableSize, const unsigned int writableSize);
|
void MakeSharedMemory(const unsigned int readableSize, const unsigned int writableSize) override;
|
||||||
const StatusCode GetReadableMemory(void *buf, const unsigned int &bufLength);
|
const StatusCode GetReadableMemory(void *buf, const unsigned int &bufLength) override;
|
||||||
void SetWritableMemory(void *buf, const unsigned int &bufLength);
|
void SetWritableMemory(void *buf, const unsigned int &bufLength) override;
|
||||||
|
StatusCode FreeSharedMemory(void) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void WritableDataInit(void);
|
void WritableDataInit(void);
|
||||||
|
@ -59,12 +60,4 @@ private:
|
||||||
unsigned int mMinorReadSize;
|
unsigned int mMinorReadSize;
|
||||||
void *mSharedMemeory;
|
void *mSharedMemeory;
|
||||||
};
|
};
|
||||||
typedef struct shared_data_impl SharedDataImpl;
|
|
||||||
typedef struct shared_data_impl
|
|
||||||
{
|
|
||||||
SharedDataHeader mHeader;
|
|
||||||
SharedData mBase;
|
|
||||||
std::shared_ptr<SharedDataCpp> mSharedData;
|
|
||||||
} SharedDataImpl;
|
|
||||||
SharedData *NewSharedDataImpl(const SHARER_NAME &name, const char *path, const int &projectId);
|
|
||||||
#endif
|
#endif
|
Loading…
Reference in New Issue
Block a user