#ifndef __VALUECAN4_1_H_ #define __VALUECAN4_1_H_ #ifdef __cplusplus #include "icsneo/device/tree/valuecan4/valuecan4.h" #include "icsneo/device/tree/valuecan4/settings/valuecan4-1settings.h" #include "icsneo/platform/cdcacm.h" #include namespace icsneo { class ValueCAN4_1 : public ValueCAN4 { public: // Serial numbers start with V1 for 4-1 static constexpr DeviceType::Enum DEVICE_TYPE = DeviceType::VCAN4_1; static constexpr const char* SERIAL_START = "V1"; static std::vector> Find() { std::vector> found; for(auto neodevice : CDCACM::FindByProduct(USB_PRODUCT_ID)) { if(std::string(neodevice.serial).substr(0, 2) == SERIAL_START) found.emplace_back(new ValueCAN4_1(neodevice)); } return found; } static const std::vector& GetSupportedNetworks() { static std::vector supportedNetworks = { Network::NetID::HSCAN }; return supportedNetworks; } protected: void setupEncoder(Encoder& encoder) override { ValueCAN4::setupEncoder(encoder); encoder.supportCANFD = false; // VCAN 4-1 does not support CAN FD } virtual void setupSupportedRXNetworks(std::vector& rxNetworks) override { for(auto& netid : GetSupportedNetworks()) rxNetworks.emplace_back(netid); } // The supported TX networks are the same as the supported RX networks for this device virtual void setupSupportedTXNetworks(std::vector& txNetworks) override { setupSupportedRXNetworks(txNetworks); } private: ValueCAN4_1(neodevice_t neodevice) : ValueCAN4(neodevice) { initialize(); getWritableNeoDevice().type = DEVICE_TYPE; productId = USB_PRODUCT_ID; } }; } #endif // __cplusplus #endif