Do not include kicad_curl.h (and therefore curl.h) in kicad_curl_easy.h
curl.h has constraints on Windows (because it includes winsocks2.h) and must be included before any wxxxx.h. Because only very few files need curl.h, kicad_curl.h is included only in these files
This commit is contained in:
parent
6c7c9ca50c
commit
f59e66a897
|
@ -2064,7 +2064,6 @@ void OPENGL_GAL::drawBitmapOverbar( double aLength, double aHeight )
|
||||||
std::pair<VECTOR2D, float> OPENGL_GAL::computeBitmapTextSize( const UTF8& aText ) const
|
std::pair<VECTOR2D, float> OPENGL_GAL::computeBitmapTextSize( const UTF8& aText ) const
|
||||||
{
|
{
|
||||||
static const FONT_GLYPH_TYPE* defaultGlyph = LookupGlyph( '(' ); // for strange chars
|
static const FONT_GLYPH_TYPE* defaultGlyph = LookupGlyph( '(' ); // for strange chars
|
||||||
static const FONT_GLYPH_TYPE* lineGlyph = LookupGlyph( '_' ); // for overbar thickness
|
|
||||||
|
|
||||||
VECTOR2D textSize( 0, 0 );
|
VECTOR2D textSize( 0, 0 );
|
||||||
float commonOffset = std::numeric_limits<float>::max();
|
float commonOffset = std::numeric_limits<float>::max();
|
||||||
|
|
|
@ -22,6 +22,9 @@
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
// kicad_curl_easy.h **must be** included before any wxWidgets header to avoid conflicts
|
||||||
|
// at least on Windows/msys2
|
||||||
|
#include <kicad_curl/kicad_curl.h>
|
||||||
#include <kicad_curl/kicad_curl_easy.h>
|
#include <kicad_curl/kicad_curl_easy.h>
|
||||||
|
|
||||||
#include <cstdarg>
|
#include <cstdarg>
|
||||||
|
@ -72,6 +75,23 @@ static size_t stream_write_callback( void* contents, size_t size, size_t nmemb,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int xferinfo( void* p, curl_off_t dltotal, curl_off_t dlnow, curl_off_t ultotal,
|
||||||
|
curl_off_t ulnow )
|
||||||
|
{
|
||||||
|
CURL_PROGRESS* progress = (CURL_PROGRESS*) p;
|
||||||
|
curl_off_t curtime = 0;
|
||||||
|
|
||||||
|
curl_easy_getinfo( progress->curl->GetCurl(), CURLINFO_TOTAL_TIME_T, &curtime );
|
||||||
|
|
||||||
|
if( curtime - progress->last_run_time >= progress->interval )
|
||||||
|
{
|
||||||
|
progress->last_run_time = curtime;
|
||||||
|
return progress->callback( dltotal, dlnow, ultotal, ulnow );
|
||||||
|
}
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
KICAD_CURL_EASY::KICAD_CURL_EASY() : m_headers( nullptr )
|
KICAD_CURL_EASY::KICAD_CURL_EASY() : m_headers( nullptr )
|
||||||
{
|
{
|
||||||
// Call KICAD_CURL::Init() from in here everytime, but only the first time
|
// Call KICAD_CURL::Init() from in here everytime, but only the first time
|
||||||
|
@ -204,23 +224,6 @@ std::string KICAD_CURL_EASY::Escape( const std::string& aUrl )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int KICAD_CURL_EASY::xferinfo( void* p, curl_off_t dltotal, curl_off_t dlnow, curl_off_t ultotal,
|
|
||||||
curl_off_t ulnow )
|
|
||||||
{
|
|
||||||
CURL_PROGRESS* progress = (CURL_PROGRESS*) p;
|
|
||||||
curl_off_t curtime = 0;
|
|
||||||
|
|
||||||
curl_easy_getinfo( progress->curl->m_CURL, CURLINFO_TOTAL_TIME_T, &curtime );
|
|
||||||
|
|
||||||
if( curtime - progress->last_run_time >= progress->interval )
|
|
||||||
{
|
|
||||||
progress->last_run_time = curtime;
|
|
||||||
return progress->callback( dltotal, dlnow, ultotal, ulnow );
|
|
||||||
}
|
|
||||||
|
|
||||||
return CURLE_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool KICAD_CURL_EASY::SetTransferCallback( const TRANSFER_CALLBACK& aCallback, size_t aInterval )
|
bool KICAD_CURL_EASY::SetTransferCallback( const TRANSFER_CALLBACK& aCallback, size_t aInterval )
|
||||||
{
|
{
|
||||||
|
|
|
@ -25,15 +25,15 @@
|
||||||
#define KICAD_CURL_EASY_H_
|
#define KICAD_CURL_EASY_H_
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* KICAD_CURL_EASY.h must be included before wxWidgets headers because on Windows,
|
* curl.h, and therefore kicad_curl.h must be included before wxWidgets headers because on Windows,
|
||||||
* kicad_curl.h does not include curl.h, because wxWidgets ends up including windows.h
|
* wxWidgets ends up including windows.h before winsocks2.h
|
||||||
* before winsocks2.h inside curl and curl.h causes build warnings if included before and wxxxx.h
|
* curl and curl.h causes build warnings if included before any wxxxx.h
|
||||||
*
|
*
|
||||||
* so including kicad_curl.h could be needed in a few sources
|
* So kicad_curl_easy.h does not include curl.h to avoid constraints,
|
||||||
|
* and including kicad_curl.h could be needed in a few sources
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <kicad_curl/kicad_curl.h>
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <ostream>
|
#include <ostream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
@ -138,6 +138,9 @@ public:
|
||||||
|
|
||||||
bool SetOutputStream( const std::ostream* aOutput );
|
bool SetOutputStream( const std::ostream* aOutput );
|
||||||
|
|
||||||
|
CURL* GetCurl() { return m_CURL; }
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/**
|
/**
|
||||||
* Function setOption
|
* Function setOption
|
||||||
|
@ -150,7 +153,7 @@ private:
|
||||||
template <typename T>
|
template <typename T>
|
||||||
int setOption( int aOption, T aArg );
|
int setOption( int aOption, T aArg );
|
||||||
|
|
||||||
static int xferinfo( void*, curl_off_t, curl_off_t, curl_off_t, curl_off_t );
|
//static int xferinfo( void*, curl_off_t, curl_off_t, curl_off_t, curl_off_t );
|
||||||
|
|
||||||
CURL* m_CURL;
|
CURL* m_CURL;
|
||||||
curl_slist* m_headers;
|
curl_slist* m_headers;
|
||||||
|
|
|
@ -18,8 +18,9 @@
|
||||||
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// kicad_curl_easy.h *must be* included before any wxWidgets header to avoid conflicts
|
// kicad_curl.h *must be* included before any wxWidgets header to avoid conflicts
|
||||||
// at least on Windows/msys2
|
// at least on Windows/msys2
|
||||||
|
#include <kicad_curl/kicad_curl.h>
|
||||||
#include "kicad_curl/kicad_curl_easy.h"
|
#include "kicad_curl/kicad_curl_easy.h"
|
||||||
|
|
||||||
#include "pcm.h"
|
#include "pcm.h"
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
*/
|
*/
|
||||||
// kicad_curl_easy.h **must be** included before any wxWidgets header to avoid conflicts
|
// kicad_curl_easy.h **must be** included before any wxWidgets header to avoid conflicts
|
||||||
// at least on Windows/msys2
|
// at least on Windows/msys2
|
||||||
|
#include <kicad_curl/kicad_curl.h>
|
||||||
#include "kicad_curl/kicad_curl_easy.h"
|
#include "kicad_curl/kicad_curl_easy.h"
|
||||||
|
|
||||||
#include "pcm_task_manager.h"
|
#include "pcm_task_manager.h"
|
||||||
|
|
Loading…
Reference in New Issue