Files
libpigpio/libpigwindows.cpp
2025-08-05 22:33:23 +02:00

302 lines
5.0 KiB
C++

/*****************************************************************************
source::worx libPiGPio
Copyright © 2022 c.holzheuer
chris@sourceworx.org
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
Uses:
pigpiod_if2.h
by joan2937, pigpio @ abyz.me.uk
https://abyz.me.uk/rpi/pigpio
sigslot.h
by 2017 Pierre-Antoine Lacaze
https://github.com/palacaze/sigslot
***************************************************************************/
/// ---
#ifdef _WIN32
#include <iostream>
#include <libpigwindows.h>
#include <ws2tcpip.h>
#include <winsock2.h>
#include <windows.h>
namespace pigpio
{
int pigWindows::init( const std::string& , const std::string& )
{
//::gpioInitialise();
return 42;
}
//
// pin config
//
int pigWindows::set_io_mode( bcm_t, io_t )
{
//::set_io_mode( _Pi, pin.bcm, pin.mode );
return 0;
}
int pigWindows::get_io_mode( bcm_t )
{
return 0;
}
int pigWindows::set_pud_mode( bcm_t, pud_t )
{
//::set_pud_mode( _Pi, pin.bcm, pin.pud );
return 0;
}
int pigWindows::set_glitch_filter( bcm_t, uint32_t )
{
// ::set_glitch_filter( _Pi, pin.bcm, glitch );
return 0;
}
//Sets a noise filter on a GPIO.
int pigWindows::set_noise_filter( bcm_t, uint32_t, uint32_t )
{
//int set_noise_filter(int pi, unsigned user_gpio, unsigned steady, unsigned active)
return 0;
}
///
/// pin operations
///
int pigWindows::get_level( bcm_t )
{
return 0;
}
int pigWindows::set_level( bcm_t, level_t )
{
return 0;
}
int pigWindows::wait_for_edge( bcm_t, edge_t, double )
{
return 0;
}
//This function sends a trigger pulse to a GPIO. The GPIO is set to level for pulseLen microseconds and then reset to not level.
int pigWindows::trigger_level( bcm_t, level_t, uint32_t )
{
//int trigger_level(int pi, unsigned user_gpio, unsigned pulseLen, unsigned level)
return 0;
}
///
/// interface
///
int pigWindows::set_callback( bcm_t, pigCall*, edge_t )
{
//::callback_ex( _Pi, pin.bcm, pin.edge, &pigNode::trigger, (void*) &widget );
//pin.cbId = ::callback_ex( _Pi, pin.bcm, pin.edge, trigger, widget );
return 0;
}
int pigWindows::cancel_callback( int )
{
return 0;
}
///
/// ic2
///
int pigWindows::i2c_open( pigI2C& )
{
return 0;
}
int pigWindows::i2c_close( pigI2C& )
{
return 0;
}
/*
int pigWindows::i2c_write_quick( pigI2C&, unsigned )
{
return 0;
}
int pigWindows::i2c_write_byte( pigI2C&, unsigned )
{
return 0;
}
int pigWindows::i2c_write_byte_data( pigI2C&, unsigned, unsigned )
{
return 0;
}
int pigWindows::i2c_write_word_data( pigI2C&, unsigned, unsigned )
{
return 0;
}
int pigWindows::i2c_write_block_data( pigI2C&, unsigned, char* buf, unsigned count )
{
return 0;
}
int pigWindows::i2c_write_i2c_block_data( pigI2C&, unsigned, char* buf, unsigned count )
{
return 0;
}*/
int pigWindows::i2c_write_device( pigI2C&, char*, unsigned )
{
return 0;
}
/*
int pigWindows::i2c_read_byte( pigI2C& )
{
return 0;
}
int pigWindows::i2c_read_byte_data( pigI2C&, unsigned )
{
return 0;
}
int pigWindows::i2c_read_word_data( pigI2C&, unsigned )
{
return 0;
}
int pigWindows::i2c_read_block_data( pigI2C&, unsigned, char* )
{
return 0;
}
int pigWindows::i2c_read_i2c_block_data( pigI2C&, unsigned, char*, unsigned )
{
return 0;
}
int pigWindows::i2c_read_device( pigI2C&, char* buf, unsigned )
{
return 0;
}
int pigWindows::i2c_process_call( pigI2C&, unsigned, unsigned )
{
return 0;
}
int pigWindows::i2c_block_process_call( pigI2C&, unsigned, char*, unsigned )
{
return 0;
}
int pigWindows::i2c_zip( pigI2C&, char*, unsigned, char*, unsigned )
{
return 0;
}
*/
///
/// advanced
///
//Starts hardware PWM on a GPIO at the specified frequency and dutycycle. Frequencies above 30MHz are unlikely to work.
int pigWindows::hardware_PWM( bcm_t, uint32_t, uint32_t )
{
//int hardware_PWM(int pi, unsigned gpio, unsigned PWMfreq, uint32_t PWMduty)
return 0;
}
///
/// convenience
///
int pigWindows::show_error( int error )
{
std::cout << "Error: " << std::endl;
return error;
}
//Starts a hardware clock on a GPIO at the specified frequency. Frequencies above 30MHz are unlikely to work.
int pigWindows::hardware_clock( bcm_t, uint32_t )
{
//int hardware_clock(int pi, unsigned gpio, unsigned clkfreq)
return 0;
}
uint32_t pigWindows::get_current_tick()
{
//int hardware_clock(int pi, unsigned gpio, unsigned clkfreq)
return 0;
}
//Get the Pi's hardware revision number.
int pigWindows::get_hardware_revision()
{
//uint32_t get_hardware_revision(int pi)
return 0;
}
//Returns the pigpio version.
int pigWindows::get_pigpio_version()
{
//uint32_t get_pigpio_version(int pi)
return 0;
}
//Return the pigpiod_if2 version.
unsigned pigWindows::pigpiod_if_version()
{
//unsigned pigpiod_if_version(void)
return 0;
}
} // namespace
#endif