It was the Bitcointalk forum that inspired us to create Bitcointalksearch.org - Bitcointalk is an excellent site that should be the default page for anybody dealing in cryptocurrency, since it is a virtual gold-mine of data. However, our experience and user feedback led us create our site; Bitcointalk's search is slow, and difficult to get the results you need, because you need to log in first to find anything useful - furthermore, there are rate limiters for their search functionality.
The aim of our project is to create a faster website that yields more results and faster without having to create an account and eliminate the need to log in - your personal data, therefore, will never be in jeopardy since we are not asking for any of your data and you don't need to provide them to use our site with all of its capabilities.
We created this website with the sole purpose of users being able to search quickly and efficiently in the field of cryptocurrency so they will have access to the latest and most accurate information and thereby assisting the crypto-community at large.
int32_t g_code_pages = 1;
int32_t g_data_pages = 1;
int32_t g_call_stack_pages = 1;
int32_t g_user_stack_pages = 1;
const int64_t c_default_balance = 100;
int64_t g_val = 0;
int64_t g_val1 = 0;
int64_t g_balance = c_default_balance;
bool g_first_call = true;
int32_t g_increment_func = 0;
struct function_data
{
function_data( )
{
loop = false;
offset = 0;
}
bool loop;
size_t offset;
vector< int64_t > data;
};
map< int32_t, function_data > g_function_data;
int64_t get_function_data( int32_t func_num )
{
if( func_num == g_increment_func )
{
if( g_first_call )
g_first_call = false;
else
{
for( map< int32_t, function_data >::iterator i = g_function_data.begin( ); i != g_function_data.end( ); ++i )
{
if( ++( i->second.offset ) >= i->second.data.size( ) )
{
if( i->second.loop )
i->second.offset = 0;
else
--( i->second.offset );
}
}
}
}
int64_t rc = g_function_data[ func_num ].data[ g_function_data[ func_num ].offset ];
return rc;
}
hash160(1xxATxxYptzC5a7p9obc2SLMPS148G2Qxg) OP_CHECKSTATE (original 100)
INPUT:hash160(1xxATxxYptzC5a7p9obc2SLMPS148G2Qxg) OP_CHECKSTATE (original 100)
Use Case: Atomic Cross-Chain Transfer
-------------------------------------
An AT that enables an atomic cross-chain transfer to be executed by creating two separate instances of itself
on two seperate blockchains. When constructing the first instance a 32 byte secret needs to be "hashed" using
SHA256 and stored in the first 32 bytes of "initial data" followed by another 32 bytes for the address of the
other party, and then the number of minutes to wait until refunding the AT's balance back to its creator.
The initial creator would then wait for the other party to create a matching AT (with a significantly smaller
number of minutes for refund). The hash values would need to be identical. Once the initiator has seen enough
confirmations of the other AT then they will send the secret to the other AT as a message. This AT will first
copy this message into its data storage and then check if when hashed it matches the initial data values that
were provided when it was created. If they match then the funds are sent to the address stored in the initial
data.
Finally the creator of the second AT can now work out from checking their AT's state what the secret is. They
would then send a message to the originally created AT instance with the same secret and it would pay them so
the atomic cross-chain transfer will be completed.
Note that if the second party never actually creates their AT then the first party just needs to wait for the
refund to occur. Likewise once the second party has created their AT then if the first party fails to send it
the secret on time then a refund will occur (and the first party will also be refunded). The first party will
need to be careful not to send the secret too close to the deadline otherwise there is the possibility that a
refund will occur in the second AT but the secret will have already been seen in the message tx.
Another concern is possible attacks by "clogging the AT" up with tiny false message txs to try and prevent it
from paying out. This is perhaps best prevented by making sure that the minimum fee for the ATs is well above
anything that would permit such an attack to be economically beneficial.
Variables
---------
@00 ==> @hash_part1
@01 ==> @hash_part2
@02 ==> @hash_part3
@03 ==> @hash_part4
@04 ==> @address_part1
@05 ==> @address_part2
@06 ==> @address_part3
@07 ==> @address_part4
@08 ==> @refund_minutes
@09 ==> @refund_timestamp
@0a ==> @current_timestamp
@0b ==> @secret_part1
@0c ==> @secret_part2
@0d ==> @secret_part3
@0e ==> @secret_part4
@0f ==> @tx_type
@10 ==> @comparator
@11 ==> @secret_temp1
@12 ==> @secret_temp2
@13 ==> @secret_temp3
@14 ==> @secret_temp4
Script Assembly
---------------
if @refund_timestamp not zero goto loop 1e0a0000001c
set @refund_timestamp to AT creation time 35010309000000
add @refund_minutes to @refund_timestamp 370604090000000900000008000000
:loop (0x1c)
set @current_timestamp to block timestamp 3500030a000000
if @current_timestamp >= @refund_timestamp goto refund 210a00000009000000f0
:txloop (0x2d)
store tx after @current_timestamp in A 3504030a000000
check if A is zero and store result to @comparator 35250110000000
if @comparator is zero finish 2610000000
get type for tx in A and store in @tx_type 3505030f000000
if @tx_type is not 0 goto :check_message 1b0f00000012
get timestamp for tx in A and store in @current_timestamp3507030a000000
goto txloop 1a2d000000
:check_message (0x59)
store message of tx in A to B 320903
swap A and B 322801
sha256 of A and store in B 320402
set @secret_temp1 to A1 35000111000000
set @secret_temp2 to A2 35010112000000
set @secret_temp3 to A3 35020113000000
set @secret_temp4 to A4 35030114000000
set A1 to @hash_part1 33100100000000
set A2 to @hash_part2 33110101000000
set A3 to @hash_part3 33120102000000
set A4 to @hash_part4 33130103000000
check A equals to B and store in @comparator 35270110000000
if comparator is not 0 goto :payout 1b100000000b
goto :txloop 1a2d000000
:payout (0xa7)
set @secret_part1 to $secret_temp1 020b00000011000000
set @secret_part2 to $secret_temp2 020c00000012000000
set @secret_part3 to $secret_temp3 020d00000013000000
set @secret_part4 to $secret_temp4 020e00000014000000
set B1 to @address_part1 33160104000000
set B2 to @address_part2 33170105000000
set B3 to @address_part3 33180106000000
set B4 to @address_part4 33190107000000
send all to address in B 320304
finish 28
:refund (0xf0)
set B to address of the AT creator 320b03
send remaining balance to addres in B 320304
finish 28
Assembly Code
-------------
00000000* BNZ $0000000a :0000001c
00000006 FUN @00000009 0x0301
0000000d FUN @00000009 0x0406 $00000009 $00000008
0000001c FUN @0000000a 0x0300
00000023 BGE $0000000a $00000009 :00000013
0000002d FUN @0000000a 0x0304
00000034 FUN @00000010 0x0125
0000003b FIZ @00000010
00000040 FUN @0000000f 0x0305
00000047 BZR $0000000f :00000059
0000004d FUN @0000000a 0x0307
00000054 JMP :0000002d
00000059 FUN 0x0309
0000005c FUN 0x0128
0000005f FUN 0x0204
00000062 FUN @00000011 0x0100
00000069 FUN @00000012 0x0101
00000070 FUN @00000013 0x0102
00000077 FUN @00000014 0x0103
0000007e FUN 0x0110 $00000000
00000085 FUN 0x0111 $00000001
0000008c FUN 0x0112 $00000002
00000093 FUN 0x0113 $00000003
0000009a FUN @00000010 0x0127
000000a1 BZR $00000010 :000000ac
000000a7 JMP :0000002d
000000ac SET @0000000b $00000011
000000b5 SET @0000000c $00000012
000000be SET @0000000d $00000013
000000c7 SET @0000000e $00000014
000000d0 FUN 0x0116 $00000004
000000d7 FUN 0x0117 $00000005
000000de FUN 0x0118 $00000006
000000e5 FUN 0x0119 $00000007
000000ec FUN 0x0403
000000ef FIN
000000f0 FUN 0x030b
000000f3 FUN 0x0403
000000f6 FIN
Machine Code
------------
1e0a0000001c350103090000003706040900000009000000080000003500030a000000210a00000009000000f03504030a0000003525011000000026100000003505030f0000001b0f000000123507030a0000001a2d0000003209033228013204023500011100000035010112000000350201130000003503011400000033100100000000331101010000003312010200000033130103000000352701100000001b100000000b1a2d000000020b00000011000000020c00000012000000020d00000013000000020e000000140000003316010400000033170105000000331801060000003319010700000032030428320b0332030428
Variables
--------
@00 ==> @refund_minutes
@01 ==> @refund_timestamp
@02 ==> @current_timestamp
Script Assembly
---------------
if @refund_timestamp not zero goto loop 1e010000001c
set @refund_timestamp to AT creation time 35010301000000
add @refund_minutes to @refund_timestamp 370604010000000100000000000000
:loop (0x1c)
set @current_timestamp to block timestamp 35000302000000
if @current_timestamp >= @refund_timestamp goto refund 2102000000010000002d
(add NOP padding to insert code later) 7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f
:refund (0x50)
set B to address of the AT creator 320b03
send remaining balance to address in B 320304
Assembly Code
-------------
00000000* BNZ $00000001 :0000001c
00000006 FUN @00000001 0x0301
0000000d FUN @00000001 0x0406 $00000001 $00000000
0000001c FUN @00000002 0x0300
00000023 BGE $00000002 $00000001 :00000050
0000002d NOP
00000050 FUN 0x030b
00000053 FUN 0x0403
Machine Code
------------
1e010000001c35010301000000370604010000000100000000000000350003020000002102000000010000002d7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f320b03320304