Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

tradingbigboy

Muliple Output Functions Easy Language

Recommended Posts

Hi All,

 

For the pros in here, I would love for you to tell me if this is possible. I've coded an indicator using a different zigzag algorithm - not TS but the one used by MT4 and Dukas etc. It is coded perfectly and works. It does 2 passes through the data and simply operates ONLY on the lastbar of the chart.

 

If LastBarOnChart then Begin
   Array_SetMaxIndex(lowMapBuffer, BarNumber+1);
   Array_SetMaxIndex(highMapBuffer, BarNumber+1);
   Array_SetMaxIndex(zigzagBuffer, BarNumber+1);

etc.

 

Now I want to make this multi-timeframe and use the zigzag values in strategies etc so am attempting to turn this into a function. I get the function finished and values are all correct. The function has the same structure as the indicator, just doesn't draw TL and stuff. Now I'm trying to get values FROM this function.

 

The problem is most functions operate per bar from the beginning 1 pass through and spit out values like averages and other stuff. This indicator that pings the function must grab all of its values as well from the last bar on the chart. This would seem like the function must really return an array to the indy/strategy and I'm lost at how to do this.

 

Here's the inputs I have for the zigzag function:

inputs:
   extDepth(Numericsimple),  // 12
   extDeviation(Numericsimple),  // 5
   extBackstep(Numericsimple),   // 3
   oshift(Numericref),
   oZZupBeg(numericref),
   oZZupEnd(numericref),
   oZZdnBeg(numericref), 
   oZZdnEnd(numericref);
   Input: oZZ[n](numericarrayRef);

I'm experimenting here trying to get something to work including a numericarryref but it is not giving values.

 

In the function itself I have the oZZ being assigned as follows:

oZZ[n]=zigzagBuffer[shiftago];

 

In the indicator to test the function I have tried this:

If LastBarOnChart then begin
//method void AnalysisTechnique_Initialized( elsystem.Object sender, elsystem.InitializedEventArgs args ) 
value2 = ZZdukas(12,5,3,shift,oZZupBegval,oZZupEndval,oZZdnBegval,oZZdnEndval,oZZvalsa);
For Value1 = 0 to 999 begin
print("oZZvalsa[value1] = ",oZZvalsa[value1]);
end;

It all verfies but there is nothing but zeros in the values.

 

Any help is appreciated!!

TBB

Share this post


Link to post
Share on other sites

tbb,

 

Didn't exactly follow all you're trying to accomplish (esp re multiple timeframes, etc.)

but if you're putting this code into a strategy, instead of calling a function in the long run you would be better off putting the code in a method and appending (multiple timeframe) returns to elements in a (circular) vector ...

call method only when it's needed for real - instead of last bar on chart, etc...

 

hth

Share this post


Link to post
Share on other sites

Hi hth!

Thank you so much for your reply. I figured out how to use the Global Dictionary to share values but need to rework this code for ZigZags as I need to reference values of it BEFORE the lastbaronchart in order to use values in strategies etc. I can take the lastbaronchart and uncomment it BUT it gets VERY expensive in computation to do this each bar and really shouldn't be calculating always from the beginning but should retain values from past calculations. I don't know how this is done in easy langauge but I'm sure you know. Yes I would love to first make it efficient THEN put it into a method as you say but I'm not a OOP guy. In fact I switched back to easy language partly because Java was killing me. I did manage to port this zigzag over correctly and thought I was golden. :( Anyway thank you so much for your help here.

 

// ZigZag Best Algorithm
inputs:
   extDepth(12),
   extDeviation(5),
   extBackstep(3);

variables:
int whatlookfor(0),
int lasthighpos(0),
int lastlowpos(0),
   double val(0.0),
   double res(0.0),
   int shift(0),
   int shiftago(0),
   int back(0),
int j(0),
double lastlow(0),
double lasthigh(0),
double curlow(0),
double curhigh(0), 
double instrPips(0.0001),
double zigzagago(0),
zigzagagobar(0),
double zzupstartpr(0),
zzupstartbar(0),
double zzdnstartpr(0),
zzdnstartbar(0), 
IDup(0),
IDdn(0),
double Dnfibhighpr(0.0),
double Dnfiblowpr(0.0),
Dnfibstartbar(0),
double Upfibhighpr(0.0),
double Upfiblowpr(0.0),
Upfibstartbar(0);	
Arrays:
Double lowMapBuffer[](0.0),
Double highMapBuffer[](0.0),
Double zigzagBuffer[](0.0);	

If LastBarOnChart then Begin
//If Currentbar=0 then Begin
   Array_SetMaxIndex(lowMapBuffer, BarNumber+1);
   Array_SetMaxIndex(highMapBuffer, BarNumber+1);
   Array_SetMaxIndex(zigzagBuffer, BarNumber+1);
   // initialize array each time through
   Value40=0;
   While Value40 <= BarNumber+1 begin
   	lowMapBuffer[Value40]=0.0;
   	highMapBuffer[Value40]=0.0;
   	zigzagBuffer[Value40]=0.0;
   	Value40=Value40+1;
   End;

   IDdn=0;
zzdnstartpr=0;
zzdnstartbar=0;
IDup=0;
zzupstartpr=0;
zzupstartbar=0;
zigzagago=0;
zigzagagobar=0;
instrPips= 1 Point;
Value2 = MinMove / PriceScale;
//print(date," ",time," instrPips = ",instrPips:0:4," minmove/pricescale = ",Value2:0:4);

   While TL_Exist(TL_GetFirst(1)) begin
   	value50 = TL_GetFirst(1);
   	Value51 = TL_Delete(value50);
   end;


For shift = (1 + extDepth) to Currentbar Begin 
	//If Currentbar = 1 then Begin
	shiftago = Currentbar - shift;
	///    Lows
	val = Low[shiftago];
//print(date[shiftago]," ",time[shiftago]," shiftago = ",shiftago," shift = ",shift," Low shiftago = ",Low[shiftago]:0:4);
	For j = (shift-1) Downto (shift - extDepth) Begin
		Value2 = Currentbar - j;
		val = MinList(val, Low[Value2]);
//If shift=13 then print(date[Value2]," ",time[Value2]," J = ",J," Shift - 1 = ",shift-1," shift - extdepth = ",shift-extDepth," val = ",val);
	End; 
	If (val = lastlow) then Begin
		val = 0.0;
	End
	Else Begin
		lastlow = val;
		If (Low[shiftago] - val > extDeviation * instrPips) then Begin
			val = 0.0;
		End
		Else Begin
			For back = 1 to extBackstep Begin
			    value3=shift-back;
			    value4=Currentbar-value3;
				// res=lowMapBuffer[shift - back];
				res=lowMapBuffer[value4];
				If res <> 0 and res > val then Begin
					// lowMapBuffer[shift - back] = 0.0;
			     lowMapBuffer[value4] = 0.0;
				End;
			End;
		End;
	End;		
	If Low[shiftago] = val then Begin
		//lowMapBuffer[shift] = val;
		lowMapBuffer[shiftago] = val;
	End
	Else Begin
		//lowMapBuffer[shift] = 0.0;
		lowMapBuffer[shiftago] = 0.0;
	End;
	//   Highs now
	val = High[shiftago];
	For j = (shift-1) Downto (shift - extDepth) Begin
		Value2 = Currentbar - J; 
		val = MaxList(val, High[Value2]);
	End; 
	If val = lasthigh then Begin
		val = 0.0;
	End
	Else Begin
		lasthigh = val;
		If (val - High[shiftago] > extDeviation * instrPips) then Begin
			val = 0.0;
		End
		Else Begin
			For back = 1 to extBackstep Begin
				value3= shift-back;
				Value4 = Currentbar - value3;
				//res=highMapBuffer[shift-back];
				res=highMapBuffer[value4];
				If res <> 0 and res < val then Begin
					//highMapBuffer[shift - back] = 0.0;
					highMapBuffer[value4] = 0.0;
				End;
			End;
		End;
	End; 
	If High[shiftago] = val then Begin
		//highMapBuffer[shift] = val;
		highMapBuffer[shiftago] = val;
		End
	Else Begin
		//highMapBuffer[shift] = 0.0;
		highMapBuffer[shiftago] = 0.0;
	End;
End;
////   FINAL CUTTING
If whatlookfor = 0 then Begin
	lastlow = 0;
	lasthigh = 0;
End
Else Begin
	lastlow = curlow;
	lasthigh = curhigh;
End;
For shift = (1 + extDepth) to Currentbar Begin // 2nd loop through

	shiftago = Currentbar - shift;
	Switch (whatlookfor)
	Begin
	Case 0:  // look for peak or lawn 
		If highMapBuffer[shiftago] <> 0 then Begin
			lasthigh = High[shiftago];
			lasthighpos = shiftago;
			whatlookfor = -1;
			zigzagBuffer[shiftago] = lasthigh;
		End;
		If lowMapBuffer[shiftago] <> 0 then Begin
			lastlow = Low[shiftago];
			lastlowpos = shiftago;
			whatlookfor = 1;
			zigzagBuffer[shiftago] = lastlow;
		End;
		Break;
	Case 1:   // look for peak
		If (lowMapBuffer[shiftago] <> 0 And lowMapBuffer[shiftago] < lastlow And highMapBuffer[shiftago] = 0.0) then Begin
			zigzagBuffer[lastlowpos] = 0.0;
			lastlowpos = shiftago;
			lastlow = lowMapBuffer[shiftago];
			zigzagBuffer[shiftago] = lastlow;
		End;
		If (highMapBuffer[shiftago] <> 0 And lowMapBuffer[shiftago] = 0.0) then Begin
			lasthigh = highMapBuffer[shiftago];
			lasthighpos = shiftago;
			zigzagBuffer[shiftago] = lasthigh;
			whatlookfor = -1;
		End;
		Break;	
	Case -1:  // look for lawn
		If (highMapBuffer[shiftago] <> 0 And highMapBuffer[shiftago] > lasthigh And lowMapBuffer[shiftago] = 0.0) then Begin
			zigzagBuffer[lasthighpos] = 0.0;
			lasthighpos = shiftago;
			lasthigh = highMapBuffer[shiftago];
			zigzagBuffer[shiftago] = lasthigh;
		End;
		If (lowMapBuffer[shiftago] <> 0 And highMapBuffer[shiftago] = 0.0) then Begin
			lastlow = lowMapBuffer[shiftago];
			lastlowpos = shiftago;
			zigzagBuffer[shiftago] = lastlow;
			whatlookfor = 1;
		End;
		Break;
	End;  // end of case begin
If zigzagBuffer[shiftago] <> 0.0 then Begin
	If zigzagago > 0.0 then begin
		If zigzagBuffer[shiftago] > zigzagago then begin  // zigzag is up
		    IDdn=0;
		    If zzupstartpr=0 then begin
		    	// set begin zigzag vars
		    	zzupstartpr = zigzagago;
		    	zzupstartbar = zigzagagobar;

		    	//  reset zzdn vars
		    	zzdnstartpr=0;
		    	zzdnstartbar=0;
		    End;
	    	If IDup <> 0 then TL_Delete(IDup);
		    IDup = TL_New(date[zzupstartbar],time[zzupstartbar], zzupstartpr, date[shiftago], Time[shiftago], zigzagBuffer[shiftago]);
			If IDup > 0 then Begin
				TL_SetColor(IDup, Green);
				TL_SetSize(IDup, 1);
			End;



		End  /// end of zigzag is up

		Else Begin	// zigzag is down
		    IDup=0;
;
			If zzdnstartpr = 0 then begin
				// set begin ZZ vars
				zzdnstartpr = zigzagago;
				zzdnstartbar = zigzagagobar;
				// reset ZZUP vars
				zzupstartpr=0;
				zzupstartbar=0;
			End;

		    If IDdn <> 0 then TL_Delete(IDdn);
		    IDdn = TL_New(date[zzdnstartbar],time[zzdnstartbar], zzdnstartpr, date[shiftago], Time[shiftago], zigzagBuffer[shiftago]);
			If IDdn > 0 then begin
				TL_SetColor(IDdn, Red);
				TL_SetSize(IDdn, 1);
			End;


		End;
	End  // endzigzagago <> 0.0
	Else Begin  //   endzigzagago = 0.0 so this is first on chart
		//Print("Starting zigzag");
	End;
//print(Date[shiftago]," ",Time[shiftago]," ","IDup = ",IDup," IDdn = ",IDdn);
	zigzagago = zigzagBuffer[shiftago];
	zigzagagobar = shiftago;
End;
//If zigzagBuffer[shiftago] <> 0.0 then Print(Date[shiftago]," ",Time[shiftago]," END - zigzagBuffer[shiftago] = ",zigzagBuffer[shiftago]:0:4," shiftago = ",shiftago);
End;  // End of For Shift 2nd loop
End;  // end of lastbaronchart = 1

Share this post


Link to post
Share on other sites
Hi hth!

Thank you so much for your reply. I figured out how to use the Global Dictionary to share values but need to rework this code for ZigZags as I need to reference values of it BEFORE the lastbaronchart in order to use values in strategies etc. I can take the lastbaronchart and uncomment it BUT it gets VERY expensive in computation to do this each bar and really shouldn't be calculating always from the beginning but should retain values from past calculations. I don't know how this is done in easy langauge but I'm sure you know. Yes I would love to first make it efficient THEN put it into a method as you say but I'm not a OOP guy. In fact I switched back to easy language partly because Java was killing me. I did manage to port this zigzag over correctly and thought I was golden. :( Anyway thank you so much for your help here.

 

 

 

Think of ‘it’s not really OOP’ so much as it is EOP (event oriented programming)...

 

Think of methods as a way of putting function calls ‘in-line’ ... after initial ‘learning curve’, etc. I find them much easier to debug,etc.

 

Think of vectors as a way of storing an array with multiple ‘data’ types in it... once you get the ‘read’ and 'write' syntax down, they are just as manageable and usable as arrays

 

hth

Share this post


Link to post
Share on other sites

Thank HTH,

 

So before I go down this path, let me ask a few questions about methods. First they must be called in the analysis or strategy and the code must be placed there, yes?

 

If so, then the analysis or strategy that seeks to utilize multiple time frames must have that time frame as a 2nd symbol on the chart, correct?

 

OR, can a method in a different chart somehow share info with an analysis or strategy on a different chart using some type of global variables in this method, or would it end up also using the global dictionary to accomplish this??

 

Thank you!! The easylanguage helps on the internet rarely give help to programming in the new OOP additions to easylanguage so there are almost no examples of how to do this stuff.

 

TTB

Share this post


Link to post
Share on other sites

TTB,

 

re: ""... in the new OOP additions to easylanguage so there are almost no examples of how to do this stuff."

 

Omg It’s worse than that. ... and now they’ve had years to build some good instructions... and haven’t...

For adequate beginner coverage of OOEL, look for OOEL+Concepts_AndroidMarvin.pdf in TS Forum. If you can’t get or find it, pm me with an email address and I will attach a copy to you.

 

re: "Methods... must be called in the analysis or strategy and the code must be placed there...? "

Yes. All method code is placed after procedural level declarations , etc. and before procedure code.

 

re: "If so, then the analysis or strategy that seeks to utilize multiple time frames must have that time frame as a 2nd symbol on the chart, correct?

 

OR, can a method in a different chart somehow share info with an analysis or strategy on a different chart "

Either would work... ultimately depends on your design preferences and requirements. How many timeframes are involved?

 

re: "different chart ... using the global dictionary to accomplish this??"

Global dictionary has some little wierdnesses but can ultimately be designed to run like a global vector. If I remember correctly, the pdf mentioned above uses zigs in his global dictionary example

 

hth

 

zdo

Share this post


Link to post
Share on other sites

Hi hth,

 

Yes I'm using at minimum 2 different time frames on a chart plus another symbol as I'm doing some divergence analysis as well. In fact for some reason one of my indies won't run with a forex and stock on the same chart so have to run that in a different chart so it gets complicated and yes I would like to figure out how to have this data wherever I need it.

 

Perhaps it needs to be a OOEL method placed in a function?

 

Thanks for your help!

TBB

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Topics

  • Posts

    • Date: 11th July 2025.   Demand For Gold Rises As Trump Announces Tariffs!   Gold prices rose significantly throughout the week as investors took advantage of the 2.50% lower entry level. Investors also return to the safe-haven asset as the US trade policy continues to escalate. As a result, investors are taking a more dovish tone. The ‘risk-off’ appetite is also something which can be seen within the stock market. The NASDAQ on Thursday took a 0.90% dive within only 30 minutes.   Trade Tensions Escalate President Trump has been teasing with new tariffs throughout the week. However, the tariffs were confirmed on Thursday. A 35% tariff on Canadian imports starting August 1st, along with 50% tariffs on copper and goods from Brazil. Some experts are advising that Brazil has been specifically targeted due to its association with the BRICS.   However, the President has not directly associated the tariffs with BRICS yet. According to President Trump, Brazil is targeting US technology companies and carrying out a ‘witch hunt’against former Brazilian President Jair Bolsonaro, a close ally who is currently facing prosecution for allegedly attempting to overturn the 2022 Brazilian election.   Although Brazil is one of the largest and fastest-growing economies in the Americas, it is not the main concern for investors. Investors are more concerned about Tariffs on Canada. The White House said it will impose a 35% tariff on Canadian imports, effective August 1st, raised from the earlier 25% rate. This covers most goods, with exceptions under USMCA and exemptions for Canadian companies producing within the US.   It is also vital for investors to note that Canada is among the US;’s top 3 trading partners. The increase was justified by Trump citing issues like the trade deficit, Canada’s handling of fentanyl trafficking, and perceived unfair trade practices.   The President is also threatening new measures against the EU. These moves caused US and European stock futures to fall nearly 1%, while the Dollar rose and commodity prices saw small gains. However, the main benefactor was Silver and Gold, which are the two best-performing metals of the day.   How Will The Fed Impact Gold? The FOMC indicated that the number of members warming up to the idea of interest rate cuts is increasing. If the Fed takes a dovish tone, the price of Gold may further rise. In the meantime, the President pushing for a 3% rate cut sparked talk of a more dovish Fed nominee next year and raised worries about future inflation.   Meanwhile, jobless claims dropped for the fourth straight week, coming in better than expected and supporting the view that the labour market remains strong after last week’s solid payroll report. Markets still expect two rate cuts this year, but rate futures show most investors see no change at the next Fed meeting. Gold is expected to finish the week mostly flat.       Gold 15-Minute Chart     If the price of Gold increases above $3,337.50, buy signals are likely to materialise again. However, the price is currently retracing, meaning traders are likely to wait for regained momentum before entering further buy trades. According to HSBC, they expect an average price of $3,215 in 2025 (up from $3,015) and $3,125 in 2026, with projections showing a volatile range between $3,100 and $3,600   Key Takeaway Points: Gold Rises on Safe-Haven Demand. Gold gained as investors reacted to rising trade tensions and market volatility. Canada Tariffs Spark Concern. A 35% tariff on Canadian imports drew attention due to Canada’s key trade role. Fed Dovish Shift Supports Gold. Growing expectations of rate cuts and Trump’s push for a 3% cut boosted the gold outlook. Gold Eyes Breakout Above $3,337.5. Price is consolidating; a move above $3,337.50 could trigger new buy signals. Always trade with strict risk management. Your capital is the single most important aspect of your trading business.   Please note that times displayed based on local time zone and are from time of writing this report.   Click HERE to access the full HFM Economic calendar.   Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding of how markets work. Click HERE to register for FREE!   Click HERE to READ more Market news.   Michalis Efthymiou HFMarkets   Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in Leveraged Products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
    • Back in the early 2000s, Netflix mailed DVDs to subscribers.   It wasn’t sexy—but it was smart. No late fees. No driving to Blockbuster.   People subscribed because they were lazy. Investors bought the stock because they realized everyone else is lazy too.   Those who saw the future in that red envelope? They could’ve caught a 10,000%+ move.   Another story…   Back in the mid-2000s, Amazon launched Prime.   It wasn’t flashy—but it was fast.   Free two-day shipping. No minimums. No hassle.   People subscribed because they were impatient. Investors bought the stock because they realized everyone hates waiting.   Those who saw the future in that speedy little yellow button? They could’ve caught another 10,000%+ move.   Finally…   Back in 2011, Bitcoin was trading under $10.   It wasn’t regulated—but it worked.   No bank. No middleman. Just wallet to wallet.   People used it to send money. Investors bought it because they saw the potential.   Those who saw something glimmering in that strange orange coin? They could’ve caught a 100,000%+ move.   The people who made those calls weren’t fortune tellers. They just noticed something simple before others did.   A better way. A quiet shift. A small edge. An asymmetric bet.   The red envelope fixed late fees. The yellow button fixed waiting. The orange coin gave billions a choice.   Of course, these types of gains are rare. And they happen only once in a blue moon. That’s exactly why it’s important to notice when the conditions start to look familiar.   Not after the move. Not once it's on CNBC. But in the quiet build-up— before the surface breaks.   Enter the Blue Button Please read more here: https://altucherconfidential.com/posts/netflix-amazon-bitcoin-blue  Profits from free accurate cryptos signals: https://www.predictmag.com/ 
    • What These Attacks Look Like There are several ways you could get hacked. And the threats compound by the day.   Here’s a quick rundown:   Phishing: Fake emails from your “bank.” Click the link, give your password—game over.   Ransomware: Malware that locks your files and demands crypto. Pay up, or it’s gone.   DDoS: Overwhelm a website with traffic until it crashes. Like 10,000 bots blocking the door. Often used by nations.   Man-in-the-Middle: Hackers intercept your messages on public WiFi and read or change them.   Social Engineering: Hackers pose as IT or drop infected USB drives labeled “Payroll.”   You don’t need to be “important” to be a target.   You just need to be online.   What You Can Do (Without Buying a Bunker) You don’t have to be tech-savvy.   You just need to stop being low-hanging fruit.   Here’s how:   Use a YubiKey (physical passkey device) or Authenticator app – Ditch text message 2FA. SIM swaps are real. Hackers often have people on the inside at telecom companies.   Use a password manager (with Yubikey) – One unique password per account. Stop using your dog’s name.   Update your devices – Those annoying updates patch real security holes. Use them.   Back up your files – If ransomware hits, you don’t want your important documents held hostage.   Avoid public WiFi for sensitive stuff – Or use a VPN.   Think before you click – Emails that feel “urgent” are often fake. Go to the websites manually for confirmation.   Consider Starlink in case the internet goes down – I think it’s time for me to make the leap. Don’t Panic. Prepare. (Then Invest.)   I spent an hour in that basement bar reading about cyberattacks—and watching real-world systems fall apart like dominos.   The internet going down used to be an inconvenience. Now, it’s a warning.   Cyberwar isn’t coming. It’s here.   And the next time your internet goes out, it might not just be your router.   Don’t panic. Prepare.   And maybe keep a backup plan in your back pocket. Like a local basement bar with good bourbon—and working WiFi.   As usual, we’re on the lookout for more opportunities in cybersecurity. Stay tuned.   Author: Chris Campbell (AltucherConfidential) Profits from free accurate cryptos signals: https://www.predictmag.com/   
    • DUMBSHELL:  re the automation of corruption ---  200,000 "Science Papers" in academic journal database PubMed may have been AI-generated with errors, hallucinations and false sourcing 
    • Does any crypto exchanges get banned in your country? How's about other as Bybit, Kraken, MEXC, OKX?
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.