@ -4,6 +4,7 @@
@@ -4,6 +4,7 @@
# include "bitcoinunits.h"
# include "util.h"
# include "init.h"
# include "base58.h"
# include <QString>
# include <QDateTime>
@ -80,6 +81,11 @@ bool parseBitcoinURI(const QUrl &uri, SendCoinsRecipient *out)
@@ -80,6 +81,11 @@ bool parseBitcoinURI(const QUrl &uri, SendCoinsRecipient *out)
if ( uri . scheme ( ) ! = QString ( " bitcoin " ) )
return false ;
// check if the address is valid
CBitcoinAddress addressFromUri ( uri . path ( ) . toStdString ( ) ) ;
if ( ! addressFromUri . IsValid ( ) )
return false ;
SendCoinsRecipient rv ;
rv . address = uri . path ( ) ;
rv . amount = 0 ;
@ -222,19 +228,18 @@ Qt::ConnectionType blockingGUIThreadConnection()
@@ -222,19 +228,18 @@ Qt::ConnectionType blockingGUIThreadConnection()
bool checkPoint ( const QPoint & p , const QWidget * w )
{
QWidget * atW = qApp - > widgetAt ( w - > mapToGlobal ( p ) ) ;
if ( ! atW ) return false ;
return atW - > topLevelWidget ( ) = = w ;
QWidget * atW = qApp - > widgetAt ( w - > mapToGlobal ( p ) ) ;
if ( ! atW ) return false ;
return atW - > topLevelWidget ( ) = = w ;
}
bool isObscured ( QWidget * w )
{
return ! ( checkPoint ( QPoint ( 0 , 0 ) , w )
& & checkPoint ( QPoint ( w - > width ( ) - 1 , 0 ) , w )
& & checkPoint ( QPoint ( 0 , w - > height ( ) - 1 ) , w )
& & checkPoint ( QPoint ( w - > width ( ) - 1 , w - > height ( ) - 1 ) , w )
& & checkPoint ( QPoint ( w - > width ( ) / 2 , w - > height ( ) / 2 ) , w ) ) ;
return ! ( checkPoint ( QPoint ( 0 , 0 ) , w )
& & checkPoint ( QPoint ( w - > width ( ) - 1 , 0 ) , w )
& & checkPoint ( QPoint ( 0 , w - > height ( ) - 1 ) , w )
& & checkPoint ( QPoint ( w - > width ( ) - 1 , w - > height ( ) - 1 ) , w )
& & checkPoint ( QPoint ( w - > width ( ) / 2 , w - > height ( ) / 2 ) , w ) ) ;
}
void openDebugLogfile ( )