Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Consolidate shared DeviceList functionality under a common base class. #1488

Open
wants to merge 86 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
86 commits
Select commit Hold shift + click to select a range
59c8647
Changed RemoteDeviceList to hold devices in a PointerVector.
Dimi1010 Jun 30, 2024
2ce99c0
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Jul 7, 2024
415880e
Added iterator member type definitions conforming to the standard lib…
Dimi1010 Jul 7, 2024
1a678bb
Changed PcapLiveDeviceList to utilize a PointerVector iternally.
Dimi1010 Jul 7, 2024
40da178
Added iteration API to LiveDeviceList.
Dimi1010 Jul 7, 2024
e0eed6c
Updated usages of deprecated `getPcapLiveDevicesList`.
Dimi1010 Jul 7, 2024
265865c
Removed empty destructor.
Dimi1010 Jul 7, 2024
b479b08
Split overly long line.
Dimi1010 Jul 8, 2024
6a4c330
Formatting fixes.
Dimi1010 Jul 10, 2024
f28307a
Fixed documentation of iterator API.
Dimi1010 Jul 10, 2024
326d2cc
Updated PfRingDeviceList to use PointerVector internally.
Dimi1010 Jul 10, 2024
d940946
Moved include to cpp file.
Dimi1010 Jul 10, 2024
21391cb
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Jul 21, 2024
54c0efe
Merge branch 'dev' into refactor/device-list-management
seladb Jul 21, 2024
0b4230c
Merge branch 'dev' into refactor/device-list-management
seladb Jul 25, 2024
118578c
Merge branch 'dev' into refactor/device-list-management
seladb Jul 29, 2024
921dda4
Added a base device list class to contain common functionality betwee…
Dimi1010 Jul 29, 2024
7f3d810
Merge remote-tracking branch 'origin/refactor/device-list-management'…
Dimi1010 Jul 29, 2024
a3c533a
Updated PcapRemoteDeviceList and PfRingDeviceList to utilize DeviceLi…
Dimi1010 Jul 29, 2024
faeb1ee
Merge branch 'dev' into refactor/device-list-management
Dimi1010 Jul 29, 2024
6e990e9
Fixes and cleanup.
Dimi1010 Jul 29, 2024
b31b65f
Deprecation message fixes.
Dimi1010 Jul 29, 2024
d649dd9
Updated DpdkDeviceList to utilize DeviceListBase.
Dimi1010 Jul 29, 2024
e9143d1
Updated KniDeviceList to utilize DeviceListBase.
Dimi1010 Jul 29, 2024
c956f67
Fixed KniDevice device search.
Dimi1010 Jul 29, 2024
ccaac4e
Refactored KniDeviceList::createDevice to use smart pointers during c…
Dimi1010 Jul 29, 2024
df807f7
Fixed KniDevice deletion errors.
Dimi1010 Jul 29, 2024
38b5633
Lint
Dimi1010 Jul 29, 2024
7668b9f
Fixed namespace closure.
Dimi1010 Jul 29, 2024
91ccd0e
Fixed alias.
Dimi1010 Jul 29, 2024
df2730f
Fixed KniDeviceDeleter documentation.
Dimi1010 Jul 29, 2024
e434258
Reverted creation of KniDevice to raw ptr.
Dimi1010 Jul 29, 2024
85a35f5
Fixed KniDeviceDeleter documentation again.
Dimi1010 Jul 29, 2024
ed143d7
Attempt to fix dpdk device fetch by port.
Dimi1010 Jul 29, 2024
e5dc2da
Lint
Dimi1010 Jul 29, 2024
9cf44ce
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Jul 30, 2024
2ae51d2
Minor fixes.
Dimi1010 Jul 30, 2024
a73d4b9
Changed PcapLiveDeviceList getters to 'getDeviceBy*' syntax.
Dimi1010 Jul 31, 2024
75c4e32
Replaced usages of deprecated method 'getPcapLiveDevicesList()'.
Dimi1010 Jul 31, 2024
ab45201
Replaced usages of deprecated method 'getPfRingDevicesList()'.
Dimi1010 Jul 31, 2024
cee1e43
Deprecated old iterator aliases for RemoteDeviceList and updated usages.
Dimi1010 Jul 31, 2024
3b72143
Replaced deprecated function 'getRemoteDeviceList' usages.
Dimi1010 Jul 31, 2024
ffac432
Changed PcapRemoteDeviceList getters to 'getDeviceBy*' syntax.
Dimi1010 Jul 31, 2024
2245bb5
Fixed deprecation message.
Dimi1010 Jul 31, 2024
151f09f
Changed PfRingDeviceList getters to 'getDeviceBy*' syntax.
Dimi1010 Jul 31, 2024
0dbeb1f
Lint
Dimi1010 Jul 31, 2024
0317b91
Fixed documentation error.
Dimi1010 Jul 31, 2024
bb695b8
Attempt to fix the deprecation warning error.
Dimi1010 Aug 1, 2024
3dfe776
Lint
Dimi1010 Aug 1, 2024
5c3f9d3
Attempt to fix doxygen copydoc errors.
Dimi1010 Aug 1, 2024
f5bd24f
Copied the documentation manually as copydoc was causing issues.
Dimi1010 Aug 1, 2024
49ffbd6
Fixed missed copydoc.
Dimi1010 Aug 1, 2024
e473b64
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Aug 7, 2024
e8e86ca
Rename preprocessor macros to remove leading underscores
Dimi1010 Aug 7, 2024
1fabdd1
Merge branch 'dev' into refactor/device-list-management
Dimi1010 Aug 7, 2024
9d515c4
Merge branch 'dev' into refactor/device-list-management
Dimi1010 Aug 12, 2024
abf1171
Updated code to use PointerVector.
Dimi1010 Aug 12, 2024
6ffdc41
Merge branch 'dev' into refactor/device-list-management
Dimi1010 Aug 14, 2024
5215614
Merge branch 'dev' into refactor/device-list-management
Dimi1010 Aug 21, 2024
133c433
Fixed merge errors.
Dimi1010 Aug 23, 2024
87bd25d
Lint
Dimi1010 Aug 23, 2024
848afd5
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Aug 23, 2024
17f742e
Fixed device list name.
Dimi1010 Aug 23, 2024
be2db4b
Fixed pushBack signature.
Dimi1010 Aug 23, 2024
2ea0628
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Aug 25, 2024
8841b6b
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Oct 4, 2024
1a1c0b8
Lint
Dimi1010 Oct 6, 2024
2f890a4
Lint
Dimi1010 Oct 6, 2024
75a1df3
Lint
Dimi1010 Oct 6, 2024
2bdfd2a
Merge branch 'dev' into refactor/device-list-management
Dimi1010 Oct 11, 2024
344a656
Fixed empty line between methods.
Dimi1010 Oct 11, 2024
0cfbdd4
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Oct 24, 2024
274c02c
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Nov 5, 2024
e9ae72e
Lint
Dimi1010 Nov 5, 2024
afd6e92
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Nov 25, 2024
b0d2744
Added self-copy guards.
Dimi1010 Nov 25, 2024
9863b11
Fixed warnings.
Dimi1010 Nov 25, 2024
fc73879
Added tests for DeviceListBase.
Dimi1010 Nov 25, 2024
6bd0cbf
Lint
Dimi1010 Nov 25, 2024
1d84a3c
Add "venv" and "./out" directories to be ignored by codespell.
Dimi1010 Nov 27, 2024
68130d5
Suppress checkersReport messages for cppcheck.
Dimi1010 Nov 27, 2024
9ad70af
Lint
Dimi1010 Nov 27, 2024
871cca7
Added explicit defaulted public destructors to device lists.
Dimi1010 Nov 27, 2024
8eb5f62
Merge branch 'dev' into refactor/device-list-management
Dimi1010 Dec 31, 2024
1b917bf
Merge remote-tracking branch 'upstream/dev' into refactor/device-list…
Dimi1010 Jan 4, 2025
b58284b
Lint
Dimi1010 Jan 4, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 9 additions & 6 deletions Common++/header/PointerVector.h
Original file line number Diff line number Diff line change
Expand Up @@ -109,8 +109,11 @@ namespace pcpp
*/
PointerVector& operator=(const PointerVector& other)
{
// Saves a copy of the old pointer to defer cleanup.
auto oldValues = m_Vector;
if (this == &other)
return *this;

// Moves the old values to a temporary to defer cleanup.
auto oldValues = std::move(m_Vector);
try
{
m_Vector = deepCopyUnsafe(other.m_Vector);
Expand All @@ -134,6 +137,9 @@ namespace pcpp
*/
PointerVector& operator=(PointerVector&& other) noexcept
{
if (this == &other)
return *this;

// Releases all current elements.
clear();
// Moves the elements of the other vector.
Expand Down Expand Up @@ -387,10 +393,7 @@ namespace pcpp
}
catch (const std::exception&)
{
for (auto obj : copyVec)
{
Deleter()(obj);
}
freeVectorUnsafe(copyVec);
throw;
}

Expand Down
4 changes: 2 additions & 2 deletions Examples/PfRingExample-FilterTraffic/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -277,15 +277,15 @@ int main(int argc, char* argv[])
case 'n':
{
std::string ifaceName = std::string(optarg);
dev = pcpp::PfRingDeviceList::getInstance().getPfRingDeviceByName(ifaceName);
dev = pcpp::PfRingDeviceList::getInstance().getDeviceByName(ifaceName);
if (dev == nullptr)
EXIT_WITH_ERROR("Could not find PF_RING device '" << ifaceName << "'");
break;
}
case 's':
{
std::string sendPacketsToIfaceName = std::string(optarg);
sendPacketsToIface = pcpp::PfRingDeviceList::getInstance().getPfRingDeviceByName(sendPacketsToIfaceName);
sendPacketsToIface = pcpp::PfRingDeviceList::getInstance().getDeviceByName(sendPacketsToIfaceName);
if (sendPacketsToIface == nullptr)
EXIT_WITH_ERROR("Could not find PF_RING device '" << sendPacketsToIfaceName << "'");

Expand Down
8 changes: 4 additions & 4 deletions Pcap++/header/KniDevice.h
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ namespace pcpp
class KniDevice : public IDevice
{
friend class KniDeviceList;
friend class internal::KniDeviceDeleter;
friend struct internal::KniDeviceDeleter;
Dimi1010 marked this conversation as resolved.
Show resolved Hide resolved
friend class MBufRawPacket;

public:
Expand Down Expand Up @@ -284,7 +284,7 @@ namespace pcpp
/** This class is not copyable */
KniDevice& operator=(const KniDevice&);
/** All instances of this class MUST be destroyed by KniDeviceList class */
~KniDevice();
~KniDevice() override;

public:
/* Information getters */
Expand Down Expand Up @@ -636,13 +636,13 @@ namespace pcpp
* @return true if the device was opened successfully, false if device is already opened,
* or KNI device configuration and startup failed
*/
bool open();
bool open() override;
/**
* @brief Close the KNI device.
* When device is closed it's not possible to work with it.
* Stops asynchronous packet capture if it is running.
*/
void close();
void close() override;

private:
struct rte_kni* m_Device;
Expand Down
Loading