# FastLED Platform: stub Native (no‑hardware) platform used for tests and host builds; may delegate to WASM clockless for browser builds or a generic stub. ## Files (quick pass) - `fastled_stub.h`: Aggregator enabling stub clockless and SPI; defines `HAS_HARDWARE_PIN_SUPPORT` for compatibility. - `clockless_stub.h`: Selects between WASM clockless (`emscripten`) or `clockless_stub_generic.h` when `FASTLED_STUB_IMPL` is set. ## Subdirectories - `generic/`: Generic stub sysdefs/pin helpers used when not targeting WASM. ## Behavior - Used by C++ unit tests and host builds to provide a hardware‑free implementation. When compiled to WASM, this path can route to the WASM clockless backend for browser visualization. ## Unit test usage - The stub platform is the default for C++ unit tests. It provides no‑hardware implementations for pin, SPI, and clockless paths so rendering logic can be validated on hosts. - Tests that verify export behavior use the `shared/active_strip_data` facilities to snapshot frame/strip data without physical LEDs. - When targeting browser demos, the stub can route to the WASM clockless backend under `emscripten` to visualize frames without hardware. ## Optional feature defines - **`FASTLED_STUB_IMPL`**: Enable stubbed platform behavior. Default set in `led_sysdefs_stub_generic.h` when targeting stub builds. - **`FASTLED_HAS_MILLIS`**: Default `1`. - **`FASTLED_ALLOW_INTERRUPTS`**: Default `1`. - **`FASTLED_USE_PROGMEM`**: Default `0`. - **`FASTLED_ALL_PINS_HARDWARE_SPI`**: Declared in stub SPI header for compatibility. - Optional thread helpers: **`FASTLED_USE_PTHREAD_DELAY`**, **`FASTLED_USE_PTHREAD_YIELD`** influence time/yield behavior in `time_stub.cpp`. Define before including `FastLED.h` to override.