Project

General

Profile

User story #225

Updated by André Neto over 9 years ago

Refactor the ClassRegistryDatabase so that each registered class gets a unique identifier.

The implementation shall offer a search facility, by unique identifier, which allows to quickly retrieve a registered class (i.e. without having to walk all the list).

Tasks:
# Develop a new list class StaticListHolder
# Refactor the implementation of ClassRegistryDatabase (use StaticListHolder instead of LinkedListHolder as internal class database)

h1. Source code files modified

* Source/Core/BareMetal/L1Portability/GlobalObjectI.cpp
* Source/Core/BareMetal/L1Portability/GlobalObjectI.h
* Source/Core/BareMetal/L1Portability/GlobalObjectsDatabase.cpp
* Source/Core/BareMetal/L1Portability/GlobalObjectsDatabase.h
* Source/Core/BareMetal/L1Portability/HeapManager.cpp
* Source/Core/BareMetal/L1Portability/HeapManager.h
* Source/Core/BareMetal/L2Objects/ClassRegistryDatabase.cpp
* Source/Core/BareMetal/L2Objects/ClassRegistryDatabase.h

* Test/Core/BareMetal/L1Portability/GlobalObjectsDatabaseTest.cpp
* Test/Core/BareMetal/L1Portability/GlobalObjectsDatabaseTest.h
* Test/Core/BareMetal/L2Objects/ClassRegistryDatabaseTest.cpp
* Test/Core/BareMetal/L2Objects/ClassRegistryDatabaseTest.h

* Test/GTest/GlobalObjectsDatabaseGTest.cpp

h1. Architecture & design review

*Date of the review:* 08/09/2015

*Person who did the review:* Andre' Neto

*Version of architecture & design document:* N/A. As per the original MARTe implementation, this is a support function and does not require formal design in UML.

*Result of review:* N/A

*List of non-conformities:* N/A

h1. Code and documentation review

*Date of the review:* 23/09/2015

*Person who did the review:* Llorenç Capellà

*Result of review:* PASS

*Notes1:* In the StaticListHolder.h documentation, the formula MAXCAPACITY cannot be visualized with doxygen tool.

*Noter2:* Maybe a glossary of acronyms is needed.

*List of non-conformities:* N/A.

h1. Unit test review

*Date of the review:* 23/09/2015

*Person who did the review:* Llorenç Capellà

*Result of coverage tests review:* PASS (93.2%)

*Result of functional tests review:* PASS

*Result of review:* PASS

*Note1:* TestAddOnFullList disabled due to it takes a quiet significant amount of time.

*Note2:* The coverage is not 100% due to some conditions will never should happen.

*List of non-conformities:* N/A

Back