User story #225
Updated by Ivan Herrero 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/StaticList.cpp
* Source/Core/BareMetal/L1Portability/StaticList.h
* Source/Core/BareMetal/L1Portability/StaticListHolder.cpp
* Source/Core/BareMetal/L1Portability/StaticListHolder.h
* 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/StaticListTest.cpp
* Test/Core/BareMetal/L1Portability/StaticListTest.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/StaticListGTest.cpp
* 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
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/StaticList.cpp
* Source/Core/BareMetal/L1Portability/StaticList.h
* Source/Core/BareMetal/L1Portability/StaticListHolder.cpp
* Source/Core/BareMetal/L1Portability/StaticListHolder.h
* 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/StaticListTest.cpp
* Test/Core/BareMetal/L1Portability/StaticListTest.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/StaticListGTest.cpp
* 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