Jump to content

destroy a block in the world(xyz) droping what it drops <SOLVED>


perromercenary00

Recommended Posts

goood days

 

i know this looks noob question but i get stuck here

 

i wanna break some blocks wuith a custom item, but idont realize how to declare this

 

weel i been doing some research and fin this

 

world.destroyBlock(x,y,z, true); but not work in 1.710

 

in some forum they say thath deprecated but there is still a

 

world.func_147480_a(x, y,z, true);  but still not work

 

and inthe world class i found

 

world.destroyBlockInWorldPartially(int,int,int,int,int);  but i dont get how to use this and the examples well the re is no examples. and donot know the order of the int's is not clear 

i been triying

 

Block blck = world.getBlock(x, y, z);

int idblock=Block.getIdFromBlock(blck);

int idplayer=p_77659_3_.getEntityId();

 

 

world.destroyBlockInWorldPartially(idplayer,x,y,z,-1); not work

world.destroyBlockInWorldPartially(idblock,x,y,z,-1); not work

 

 

ñaaaaaaaaa

 

 

sooo howdo you do to destroy a block in the given coordinates xyz  droping what its drops.??

 

 

 

 

 

Link to comment
Share on other sites

Block blck = world.getBlock(x, y, z);

blck.dropBlockAsItem(...);

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

jejejeje

is half way

but i must question again

 

public ItemStack onItemRightClick(ItemStack p_77659_1_, World world, EntityPlayer p_77659_3_){

int[] coordenadas = util.coordenadaDeBlockeEnFoco(world, 10);

Block blck = world.getBlock(coordenadas[0],coordenadas[1],coordenadas[2]);

blck.dropBlockAsItem(world, coordenadas[0],coordenadas[1],coordenadas[2], 0, 0);

}

 

thismake the block drop but dont destroy the block, is bad declarated or

is mandatory to set the block to air whith

world.setBlock(x,y,z, Block.air);

 

???

Link to comment
Share on other sites

It works, but I'd suggest calling

blck.removedByPlayer(...) instead.  removedByPlayer lets the block destroy itself, as well as call any ancillary functions that it might have that happens when the block is destroyed (I'm actually working on a mod right now that overrides this function).

 

I'd also suggest inserting a call to blck.onBlockDestroyedByPlayer(...) somewhere as well (before the call to removedByPlayer or setBlockToAir).

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

Wait, what do you mean by

 

"world.func_147480_a(x, y,z, true);  but still not work "

 

I've used that code many times in 1.7.10, so I don't know how it isn't working. Please explain.

-Mitchellbrine

 

Minecraft can do ANYTHING, it's coded in Java and you got the full power of Java behind you when you code. So nothing is impossible.

It may be freaking fucking hard though, but still possible ;)

 

If you create a topic on Modder Support, live by this motto:

I don't want your charity, I want your information
Link to comment
Share on other sites

Are you sure your coordinates are correct?

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

i been cleaning up mi code and converting the arrays[]  to ArrayList<Integer>  and

just figure out what happened but

 

the problem is that when i hold the rigthclick it sends like tenthousand orders to break this specific block soo after testing it whit the ArrayList system

world.func_147480_a(x,y,z, true); works breaking the block and droping in just one step

 

blck.dropBlockAsItem(world, x,y,z, 0, 0); works make the block drops whitout destroy and

 

world.setBlock(x,y,z, Blocks.air); delete the block as well

 

 

but i see this before in others mods

the blocks are destroy and drops item but still there, if try to jump in the hole i get stuck,  and if i close the game and reload the world the blocks come back like nothing happend

 

?is nesesary to cast some kind of sorcery to get the world to save the change in the chunks ¿

 

 

 

 

 

 

 

 

Link to comment
Share on other sites

ñaaa

 

//codigo

 

public static void romper(World world,List<Integer> lis){

System.out.println("####  romper");

 

int llist=lis.size(); //longitud de la lista

System.out.println("####  llist="+llist);

 

for (int conteo=0; conteo < llist;conteo=conteo+3){

int x=lis.get(conteo),y=lis.get(conteo+1),z=lis.get(conteo+2);

 

//Block blck = world.getBlock(x,y,z);

//blck.dropBlockAsItem(world, x,y,z, 1, 1);

//world.setBlock(x,y,z, Blocks.air);

 

world.func_147480_a(x,y,z, true);

 

//#######  aqui esta la flag \/ \/ \/

if (world.isRemote){ System.out.println("####  world.isRemote=true ");}

else                      { System.out.println("####  world.isRemote=false");}

//#######  aqui esta la flag /\ /\ /\

 

 

System.out.println("####  x="+x+" y="+y+" z="+z);

System.out.println("####  conteo="+conteo);

}

}

 

//codigo

 

 

####  romper

[12:43:28] [Client thread/INFO] [sTDOUT]:  ####  llist=12

[12:43:28] [Client thread/INFO] [sTDOUT]:  ####  world.isRemote=true

[12:43:28] [Client thread/INFO] [sTDOUT]:  ####  x=221 y=77 z=342

 

 

by this code im working on a remote world??

 

remenber from other guides something about a class proxiserver and proxiclient is that related whith error.this

 

 

 

 

Link to comment
Share on other sites

very confused whit this

is the world is provided by the method onItemRightClick

anyway this are the two principal class of this item and  a video showing how works

 

//############

package mercenary00.mercenarymod.items;

 

 

import java.io.IOException;

 

import net.minecraft.init.Items;

import mercenary00.mercenarymod.utilidades.cfg;

import net.minecraft.item.EnumAction;

import net.minecraft.item.Item;

import net.minecraft.item.ItemStack;

import mercenary00.mercenarymod.Mercenary;

import cpw.mods.fml.common.registry.GameRegistry;

import cpw.mods.fml.relauncher.Side;

import cpw.mods.fml.relauncher.SideOnly;

import net.minecraft.block.Block;

import net.minecraft.client.Minecraft;

import net.minecraft.client.renderer.texture.IIconRegister;

import net.minecraft.creativetab.CreativeTabs;

import net.minecraft.entity.player.EntityPlayer;

import net.minecraft.item.Item;

import net.minecraft.util.IChatComponent;

import net.minecraft.util.IIcon;

import net.minecraft.util.MovingObjectPosition;

import net.minecraft.world.World;

import net.minecraftforge.common.MinecraftForge;

import net.minecraftforge.event.entity.player.ArrowNockEvent;

import mercenary00.mercenarymod.utilidades.util;

import cpw.mods.fml.relauncher.Side;

import cpw.mods.fml.relauncher.SideOnly;

import net.minecraft.client.renderer.texture.IIconRegister;

import net.minecraft.creativetab.CreativeTabs;

import net.minecraft.enchantment.Enchantment;

import net.minecraft.enchantment.EnchantmentHelper;

import net.minecraft.entity.player.EntityPlayer;

import net.minecraft.entity.projectile.EntityArrow;

import net.minecraft.init.Items;

import net.minecraft.util.IIcon;

import net.minecraft.world.World;

import net.minecraftforge.common.MinecraftForge;

import net.minecraftforge.event.entity.player.ArrowLooseEvent;

import net.minecraftforge.event.entity.player.ArrowNockEvent;

import java.util.ArrayList;

 

public class varaMercenaria00 extends Item{

 

public static String name="varamercenaria00";

public static final String[] bowPullIconNameArray = new String[] {"pulling_0", "pulling_1", "pulling_2"};

@SideOnly(Side.CLIENT)

private IIcon[] iconArray;

private static final String __OBFID = "CL_00001777";

 

public static ArrayList<Integer> coordenadas0 = new ArrayList<Integer>();

public static ArrayList<Integer> coordenadas1 = new ArrayList<Integer>();

public static ArrayList<Integer> coordenadas2 = new ArrayList<Integer>();

public static boolean coor1=false;

public static boolean coor2=false;

 

//#############################################################################################

public varaMercenaria00() {

setUnlocalizedName(Mercenary.MODID + "_" + name);

GameRegistry.registerItem(this, name);

setCreativeTab(CreativeTabs.tabTools);

    setTextureName(Mercenary.MODID + ":" + name);

    this.maxStackSize = 1;

    this.setMaxDamage(500);

    this.setCreativeTab(CreativeTabs.tabCombat);

 

 

}

//#############################################################################################

//#############################################################################################

 

public ItemStack onItemRightClick(ItemStack p_77659_1_, World world, EntityPlayer steve){

// System.out.println("###    presss");

 

 

coordenadas0=util.coordenadaDeBlockeEnFocol(world, 10);

// util.MostrarLista(coordenadas0);

 

 

if (util.compararListas(coordenadas2,coordenadas0)==false){ //ignorar click

 

 

 

if (coor1){

// System.out.println("coor1 true");

 

 

if ((coor2==false)&&(util.compararListas(coordenadas0,coordenadas1)==false)){

 

coordenadas2=coordenadas0;coor2=true;

}

 

 

}else{

// System.out.println("coor1 false");

coordenadas1=coordenadas0;coor1=true;

}

 

 

if ((coor1)&&(coor2)){

System.out.println("Tengo dos coordenadas distintas");

util.MostrarLista(coordenadas1);

util.MostrarLista(coordenadas2);

coor1=false;

coor2=false;

 

//util.romper(world, util.Cuadrado(0, coordenadas1,coordenadas2));

util.romper(world,util.circulo( coordenadas1,coordenadas2));

 

}

 

} //ignorar click

 

return p_77659_1_;

}

 

}//fin de la classe

 

//##########################################################################

//##########################################################################

//##########################################################################

//##########################################################################

//##########################################################################

//##########################################################################

//##########################################################################

//##########################################################################

//##########################################################################

 

 

 

package mercenary00.mercenarymod.utilidades;

 

import net.minecraft.init.Blocks;

 

import java.io.IOException;

import java.util.ArrayList;

import java.util.List;

 

import net.minecraft.init.Items;

import mercenary00.mercenarymod.utilidades.cfg;

import net.minecraft.item.Item;

import net.minecraft.item.ItemStack;

import mercenary00.mercenarymod.Mercenary;

import cpw.mods.fml.common.registry.GameRegistry;

import cpw.mods.fml.relauncher.Side;

import cpw.mods.fml.relauncher.SideOnly;

import net.minecraft.block.Block;

import net.minecraft.client.Minecraft;

import net.minecraft.client.renderer.texture.IIconRegister;

import net.minecraft.creativetab.CreativeTabs;

import net.minecraft.entity.player.EntityPlayer;

import net.minecraft.item.Item;

import net.minecraft.util.IIcon;

import net.minecraft.util.MovingObjectPosition;

import net.minecraft.world.World;

import net.minecraftforge.common.MinecraftForge;

import net.minecraftforge.event.entity.player.ArrowNockEvent;

import mercenary00.mercenarymod.utilidades.util;

 

 

public class util{

 

 

//#################################################################################################################

//#### devuelve las coordenadas del blocke al que esta mirando steve

 

public static ArrayList<Integer> coordenadaDeBlockeEnFocol(World world,int distancia){

//System.out.println("###coordenadaDeBlockeEnFocoL");

 

ArrayList<Integer> lin =new ArrayList<Integer>();

 

//      x          y          z

//lin.add(0);lin.add(0);lin.add(0);

 

 

MovingObjectPosition mop = Minecraft.getMinecraft().renderViewEntity.rayTrace(distancia, 1.0F);

//System.out.println("###mop="+mop);

if(mop != null)

{

    int blockHitSide = mop.sideHit;

    Block blockLookingAt = world.getBlock(mop.blockX, mop.blockY, mop.blockZ) ;

   

    int fx=(int)mop.blockX;

    int fy=(int)mop.blockY;

    int fz=(int)mop.blockZ;

   

// System.out.println("fx="+fx+" fy="+fy+" fz="+fz);

    lin.add(0,fx);

    lin.add(1,fy);

    lin.add(2,fz);

}

//

// int x=lin.get(0);

// int y=lin.get(1);

// int z=lin.get(2);

// if (world.isAirBlock(x,y,z)) {System.out.println(">>>>>### el blocke x="+x+" y="+y+" z="+z+" es aire");}

 

//  System.out.println("x="+lin.get(0)+" y="+lin.get(1)+" z="+lin.get(2));

return lin;

 

 

//

 

}

 

 

//#################################################################################################################

 

//### devuelve la id 0 del blocke en las coordenadas

public static int IDdelBlockeEn(World world, List<Integer> lin){

 

//int x=lin.get(0);

//int y=lin.get(1);

//int z=lin.get(3);

 

Block blck = world.getBlock(lin.get(0),lin.get(1),lin.get(2));

int iblck=Block.getIdFromBlock(blck);

return iblck;

}

 

//#################################################################################################################

 

public static boolean compararListas(List<Integer> lia, List<Integer> lib){

// System.out.println("compararVectores");

 

int la=lia.size(),lb=lib.size();int count=0;

 

if (la==lb){

// System.out.println("A y B miden lo mismo la="+la+" lb="+lb);

 

for (int c=0; c < la ;c++){

// System.out.println("c="+c);

 

int a=lia.get©,b=lib.get©;

 

if (a==b){

count++;

;}

// System.out.println("count="+count+" a="+a+" y b="+b);

 

}

}

 

// System.out.println("count="+count+" la="+la+" lb="+lb);

 

 

if ((count==la)&&(la==lb)){

return true;

}else{

return false;

}

 

}

//#################################################################################################################

 

 

public static List<Integer> minmax(List<Integer> lia, List<Integer> lib){

System.out.println("#### \nMetodo minmax");

 

ArrayList<Integer> orga =new  ArrayList<Integer>();

 

for (int or=0; or<6 ; or++ )

{

orga.add(0);

}

 

int count=0;

int liasize=lia.size(),libsize=lib.size();

 

 

 

System.out.println("x="+lia.get(0)+" y="+lia.get(1)+" z="+lia.get(2));

        System.out.println("x="+lib.get(0)+" y="+lib.get(1)+" z="+lib.get(2));

System.out.println("");

 

 

 

if (liasize==libsize){

// System.out.println("los dos vectores miden lo mismo ");

 

 

 

for (int c=0;c<3;c++){

int a=lia.get©;

int b=lib.get©;

 

if ( a <= b ){ orga.set( c , a ) ;}

if ( a >= b ){ orga.set((c+3) , a);}

 

if ( b <= a ){ orga.set( c , b ) ;}

if ( b >= a ){ orga.set((c+3) , b);}

 

 

                    }

                    }

return orga;

 

                          }

//#################################################################################################################

 

 

public static void romper(World world,List<Integer> lis){

System.out.println("####  romper");

 

int llist=lis.size(); //longitud de la lista

 

System.out.println("####  llist="+llist);

 

 

for (int conteo=0; conteo < llist;conteo=conteo+3){

int x=lis.get(conteo),y=lis.get(conteo+1),z=lis.get(conteo+2);

 

 

//Block blck = world.getBlock(x,y,z);

//blck.dropBlockAsItem(world, x,y,z, 1, 1);

//world.setBlock(x,y,z, Blocks.air);

 

world.func_147480_a(x,y,z, true);

 

if (world.isRemote){ System.out.println("####  world.isRemote=true ");}

else              { System.out.println("####  world.isRemote=false");}

 

 

 

System.out.println("####  x="+x+" y="+y+" z="+z);

System.out.println("####  conteo="+conteo);

}

}

 

 

//#################################################################################################################

 

public static ArrayList<Integer> Cuadrado(int modo,List<Integer> lia, List<Integer> lib){

 

ArrayList<Integer> li = new ArrayList<Integer>();

ArrayList<Integer> lo = new ArrayList<Integer>();

ArrayList<Integer> orga = new ArrayList<Integer>();

 

//System.out.println("antes de organizar");

//System.out.println("min x="+min[0]+" y="+min[1]+" z="+min[2]);

//System.out.println("max x="+max[0]+" y="+max[1]+" z="+max[2]);

 

orga=(ArrayList<Integer>) minmax(lia , lib); ///por si acaso organizar min y maximos

 

 

System.out.println("despues de organizar");

System.out.println("min x="+orga.get(0)+" y="+orga.get(1)+" z="+orga.get(2));

System.out.println("max x="+orga.get(3)+" y="+orga.get(4)+" z="+orga.get(5));

 

 

//#############################################

 

 

int xmin=orga.get(0), ymin=orga.get(1), zmin=orga.get(2);

int xmax=orga.get(3), ymax=orga.get(4), zmax=orga.get(5);

 

for(int u=zmin;u<=zmax;u++){

for(int o=ymin;o<=ymax;o++){

for(int i=xmin;i<=xmax;i++){

 

 

li.add(i);

li.add(o);

li.add(u);

 

 

}}}

//#############################################

 

 

 

 

 

 

 

/*

try {

Thread.sleep (10000);

} catch (Exception e) {

// Mensaje en caso de que falle

}

*/

return li;

}

 

public static void MostrarLista(List<Integer> in){

 

int lilong=in.size();

 

for (int lins=0 ; lins < lilong ; lins=lins+3){

 

int x=in.get(lins),y=in.get(lins+1),z=in.get(lins+2);

System.out.println(lins+" > x="+x+" y="+y+" z="+z);

 

;}

 

 

}

//#################################################################################################################

 

 

 

public static ArrayList<Integer> circulo(List<Integer> lia, List<Integer> lib){

 

 

ArrayList<Integer> li = new ArrayList<Integer>();

ArrayList<Integer> lo = new ArrayList<Integer>();

ArrayList<Integer> orga = new ArrayList<Integer>();

 

li.clear();

lo.clear();

orga.clear();

 

double xc=lia.get(0), yc=lia.get(1), zc=lia.get(2);

double xr=lib.get(0), yr=lib.get(1), zr=lib.get(2);

 

 

 

double radio= Math.sqrt(Math.pow((xc-xr),2)+Math.pow((zc-zr),2));

int    radiu=(int)radio;

 

int longitud=(int)(yc-yr); if (longitud < 0){longitud=-longitud ;}

 

System.out.println("Radio="+radio+"\nLongitud="+longitud);

//z2+x2=r2

 

System.out.println("cargar li");

for (int y=0 ; y<= longitud ; y++ ){

 

for (int x=(-radiu);x <= radiu ;x++){

 

double dz=Math.sqrt( Math.pow(radio,2)-Math.pow(x,2) );

 

//System.out.println("x="+x+" y="+y+" z="+dz);

 

//li.add(x);li.add(y);li.add((int)dz);

int zmax=(int)dz;

int zmin=(int) -dz;

 

for (int relleno=zmin; relleno <= zmax ; relleno++){

 

li.add(x);li.add(y);li.add(relleno);

 

;}

//li.add(x);li.add(y);li.add((int) -dz);

 

}

 

}

 

//util.MostrarLista(li);

 

 

int lisize=li.size();

System.out.println("cargar lo lisize="+lisize);

 

for (int lis=0 ; lis < lisize ; lis=lis+3){

 

System.out.println("lis="+lis);

 

lo.add( (int) (xc+li.get(lis)));

lo.add( (int) (yc+li.get(lis+1)));

lo.add( (int) (zc+li.get(lis+2)));

 

 

}

 

return lo;

}

 

}//fin de la classe

 

 

Link to comment
Share on other sites

very confused whit this

is the world is provided by the method onItemRightClick

minecraft always calls that kind of methods twice once with the client word once with the server world:

 

	   public ItemStack onItemRightClick(ItemStack stack, World world, EntityPlayer steve){
      System.out.println(world.isRemote);
      return stack;
   }

This would print out:

true

false

 

I'm not too sure about the code tho (I'm somewhat new to coding)

But what i think happens is u check for coor1 to be true and then call ur own method with the client world, then u set coor1 to false. When the method actually gets called with the server world coor1 is false and you ofc dont call the method, so, Maybe just put the whole code in onItemRightClick in a if(!world.isRemote)

Link to comment
Share on other sites

public static int conteo=0;

 

public ItemStack onItemRightClick(ItemStack p_77659_1_, World world, EntityPlayer steve){

// System.out.println("###    presss");

 

conteo++;

System.out.println("is "+conteo+" times onItemRightClick is execute");

System.out.println("world.isRemote="+world.isRemote);

 

coordenadas0=util.coordenadaDeBlockeEnFocol(world, 10);

// util.MostrarLista(coordenadas0);

 

 

 

it gets weirder here :

 

16:00:10]  Player962 joined the game

[16:00:20] items.varaMercenaria00:onItemRightClick:79]: is 1 times onItemRightClick is execute

[16:00:20] items.varaMercenaria00:onItemRightClick:80]: world.isRemote=true

[16:00:20] items.varaMercenaria00:onItemRightClick:79]: is 2 times onItemRightClick is execute

[16:00:20] items.varaMercenaria00:onItemRightClick:80]: world.isRemote=false

[16:00:21] items.varaMercenaria00:onItemRightClick:79]: is 3 times onItemRightClick is execute

[16:00:21] items.varaMercenaria00:onItemRightClick:80]: world.isRemote=true

 

[16:00:21] items.varaMercenaria00:onItemRightClick:107]: Tengo dos coordenadas distintas

[16:00:21] .utilidades.util:romper:174]: ####  romper

[16:00:21] .utilidades.util:romper:191]: ####  world.isRemote=true

[16:00:21] .utilidades.util:romper:191]: ####  world.isRemote=true

 

_________________________________________________________________________

 

the world is remote true an then false an again is true in the romper part is always true

 

anyway on item rigth click is giving my this remote  world and dont think this is a bug this code was copy from the item.bow class

 

 

_________________________________________________________________________

soo i made a little xperiment create a block that on click it breaks the floor under and make the world check think

 

 

[server thread/INFO] [sTDOUT]: onBlockClicked:46]: se ejecuto onBlockClicked

[16:47:33] [server thread/INFO] [sTDOUT]:onBlockClicked:50]: ####  world.isRemote=false

[16:47:33] [server thread/INFO] [sTDOUT]l:romper:174]: ####  romper

[16:47:33] [Client thread/INFO] [sTDOUT]:: se ejecuto onBlockClicked

[16:47:33] [Client thread/INFO] [sTDOUT]:onBlockClicked:49]: ####  world.isRemote=true 

 

[Client thread/INFO] [sTDOUT]:: se ejecuto onBlockActivated

[16:47:49] [Client thread/INFO] : ####  world.isRemote=true

[16:47:49] [Client thread/INFO]  ####  romper

[16:47:49] [Client thread/INFO] : ####  world.isRemote=true

[16:47:49] [Client thread/INFO: ####  world.isRemote=true

 

[server thread/INFO] [sTDOUT]:: se ejecuto onBlockActivated

[16:47:49] [server thread/INFO] [sTDOUT]: ####  world.isRemote=false

[16:47:49] [server thread/INFO] [sTDOUT]:: ####  romper

Link to comment
Share on other sites

SO i made little video showing this think

 

the think jeopardizing is this

 

[16:59:49] [Client thread/INFO] [sTDOUT]

[16:59:49] [Client thread/INFO] [sTDOUT]

[16:59:49] [server thread/INFO] [sTDOUT]

[16:59:49] [server thread/INFO] [sTDOUT]:

 

Client thread | Server thread 

wen i destroy whit the block is make a cycle on client and then a cycle on server but

 

why this is not  happening with the wand

 

 

Link to comment
Share on other sites

i use the bow code as base to make this,  cut paste i edit wat i need soo the code for varita mercenaria is a few post up.

 

basicli im using the method

 

public ItemStack onItemRightClick(ItemStack p_77659_1_, World world, EntityPlayer steve){

}  // i get this from the bow class

 

varamercenaria00 exist just to get two blocks coordenates  i name it  coordenadas1=firstclick  coordenadas2=secundclick

coordenadas0 is just a cache for the input from util.coordenadaDeBlockeEnFocol(world, 10);

 

when there is two diferent coordenates loaded in coordenadas1 and coordenas2 it run

 

util.romper(world,util.circulo( coordenadas1,coordenadas2));

 

and set to zero coordenadas1 and coordenas2

 

the magic is in util.circulo( coordenadas1,coordenadas2) who define all the block in a cilinder volumen and returit like a list of coordenates then util.romper take the world data and break all the blocks in the list

late i the nigth i gona reduce the exit of system.out soo the importantings could be seen in the eclipse stoudout

 

the trouble whith eclipse,  it have a limit to the output so i can grab all the exit,

 

 

 

 

Link to comment
Share on other sites

 

public ItemStack onItemRightClick(ItemStack p_77659_1_, World world, EntityPlayer steve){

//      System.out.println("###    presss");

 

conteo++;

System.out.println("is "+conteo+" times onItemRightClick is execute");

System.out.println("world.isRemote="+world.isRemote);

       

return p_77659_1_;

}

 

//stoudout

 

 

[20:52:32] [Client thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:89]: is 1 times onItemRightClick is execute

[20:52:32] [Client thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:90]: world.isRemote=true

[20:52:32] [server thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:89]: is 2 times onItemRightClick is execute

[20:52:32] [server thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:90]: world.isRemote=false

[20:52:32] [Client thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:89]: is 3 times onItemRightClick is execute

[20:52:32] [Client thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:90]: world.isRemote=true

[20:52:32] [server thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:89]: is 4 times onItemRightClick is execute

[20:52:32] [server thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:90]: world.isRemote=false

[20:52:33] [Client thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:89]: is 5 times onItemRightClick is execute

[20:52:33] [Client thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:90]: world.isRemote=true

[20:52:33] [server thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:89]: is 6 times onItemRightClick is execute

[20:52:33] [server thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:90]: world.isRemote=false

[20:52:39] [Client thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:89]: is 7 times onItemRightClick is execute

[20:52:39] [Client thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:90]: world.isRemote=true

[20:52:39] [server thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:89]: is 8 times onItemRightClick is execute

[20:52:39] [server thread/INFO] [sTDOUT]: [mercenary00.mercenarymod.items.varaMercenaria00:onItemRightClick:90]: world.isRemote=false

 

 

Link to comment
Share on other sites

I just realized

in which consist the problem

 

when one uses the method onItemRightClick() validates several times

runs several times

interleaving the worlds first remote then the local remote again and again the local

performance obsessed me as I wrote the code so that it will only accept a cycle by sending the coordinates and the parameters only once so sending only the first world the remote world that is always first, ignoring the local world.

change the code to just send the variables only when the world is local

and only do it once until  the coordinates change

now looks like this

 

if ((coor1)&&(coor2)&&(!world.isRemote)){

 

util.romper(world,util.circulo( coordenadas1,coordenadas2));

}

 

 

there in a one more cuestion but it goes in another treat

 

 

Link to comment
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
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  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.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • container@pterodactyl~ Server marked as starting... [Pterodactyl Daemon]: Pulling Docker container image, this could take a few minutes to complete... [Pterodactyl Daemon]: Finished pulling Docker container image container@pterodactyl~ java -version openjdk version "17.0.10" 2024-01-16 OpenJDK Runtime Environment Temurin-17.0.10+7 (build 17.0.10+7) OpenJDK 64-Bit Server VM Temurin-17.0.10+7 (build 17.0.10+7, mixed mode, sharing) container@pterodactyl~ java -Xms128M -Xmx10240M -Dterminal.jline=false -Dterminal.ansi=true -jar server.jar Starting net.fabricmc.loader.impl.game.minecraft.BundlerClassPathCapture [15:07:29] [main/INFO]: Loading Minecraft 1.20.1 with Fabric Loader 0.15.9 [15:07:29] [ForkJoinPool-1-worker-3/WARN]: Mod geophilic uses the version v2.0.0-mc1.20u1.20.1 which isn't compatible with Loader's extended semantic version format (Could not parse version number component 'v2'!), SemVer is recommended for reliably evaluating dependencies and prioritizing newer version [15:07:29] [main/INFO]: Dependencies overridden for fabric-api, cem, colormatic, debugify [15:07:30] [main/WARN]: Warnings were found!  - Mod 'Debugify' (debugify) 1.20.1+2.0 recommends any 3.x version of yet-another-config-lib, which is missing!          - You should install any 3.x version of yet-another-config-lib for the optimal experience.  - Mod 'Fabric API' (fabric-api) 0.87.0+1.20.1 recommends any version after 4.5.0 of Fabulously Optimized, which is missing!          - You should install any version after 4.5.0 of Fabulously Optimized for the optimal experience. [15:07:30] [main/INFO]: Loading 174 mods:         - appleskin 2.5.0+mc1.20         - architectury 9.1.12         - ash_api 3.0.2+1.20.1         - axesareweapons 1.7.1         - balm-fabric 7.0.7         - betteradvancements 0.3.2.161         - betterdeserttemples 1.20-Fabric-3.0.1            \-- org_reflections_reflections 0.10.2         - betterdungeons 1.20-Fabric-4.0.1         - betterfortresses 1.20-Fabric-2.0.2         - betterjungletemples 1.20-Fabric-2.0.1         - bettermineshafts 1.20-Fabric-4.0.1         - betteroceanmonuments 1.20-Fabric-3.0.1         - betterstrongholds 1.20-Fabric-4.0.1         - betterwitchhuts 1.20-Fabric-3.0.1         - bookshelf 20.0.3         - cardinal-components 5.2.2            |-- cardinal-components-base 5.2.2            |-- cardinal-components-block 5.2.2            |-- cardinal-components-chunk 5.2.2            |-- cardinal-components-entity 5.2.2            |-- cardinal-components-item 5.2.2            |-- cardinal-components-level 5.2.2            |-- cardinal-components-scoreboard 5.2.2            \-- cardinal-components-world 5.2.2         - carryon 2.1.1.3         - cloth-config 11.1.106            \-- cloth-basic-math 0.6.1         - collective 6.65         - comforts 6.3.3+1.20.1            \-- spectrelib 0.13.12+1.20.1                 |-- com_electronwill_night-config_core 3.6.5                 \-- com_electronwill_night-config_toml 3.6.5         - completeconfig 2.5.0            |-- completeconfig-base 2.5.0            |-- completeconfig-gui-cloth 2.5.0            \-- completeconfig-gui-yacl 2.5.0         - connectiblechains 2.2.1+1.20.1         - customizableelytra 2.1.0+1.20         - cyclepaintings 3.2         - debugify 1.20.1+2.0         - diagonalfences 8.0.1         - diagonalwindows 8.0.1         - doubledoors 5.0         - easyanvils 8.0.1         - easymagic 8.0.1         - easyshulkerboxes 8.0.0            \-- puzzlesapi 8.0.2                 \-- puzzlesaccessapi 8.0.5         - elytraslot 6.3.0+1.20.1         - emotecraft 2.2.7-b.build.50            \-- bendy-lib 4.0.0         - enchanted-vertical-slabs 1.9         - endrem 5.2.2         - fabric-api 0.87.0+1.20.1            |-- fabric-api-base 0.4.30+7abfd51577            |-- fabric-api-lookup-api-v1 1.6.35+4d8536c977            |-- fabric-biome-api-v1 13.0.10+b3afc78b77            |-- fabric-block-api-v1 1.0.9+e022e5d177            |-- fabric-blockrenderlayer-v1 1.1.40+b3afc78b77            |-- fabric-client-tags-api-v1 1.1.1+97bb207577            |-- fabric-command-api-v1 1.2.33+f71b366f77            |-- fabric-command-api-v2 2.2.12+b3afc78b77            |-- fabric-commands-v0 0.2.50+df3654b377            |-- fabric-containers-v0 0.1.63+df3654b377            |-- fabric-content-registries-v0 4.0.9+b3afc78b77            |-- fabric-convention-tags-v1 1.5.4+a1a980da77            |-- fabric-crash-report-info-v1 0.2.18+aeb40ebe77            |-- fabric-data-generation-api-v1 12.2.2+1e61dba177            |-- fabric-dimensions-v1 2.1.53+8536527b77            |-- fabric-entity-events-v1 1.5.22+b3afc78b77            |-- fabric-events-interaction-v0 0.6.1+e91849a877            |-- fabric-events-lifecycle-v0 0.2.62+df3654b377            |-- fabric-game-rule-api-v1 1.0.38+b04edc7a77            |-- fabric-item-api-v1 2.1.27+b3afc78b77            |-- fabric-item-group-api-v1 4.0.10+23d9108177            |-- fabric-key-binding-api-v1 1.0.36+fb8d95da77            |-- fabric-keybindings-v0 0.2.34+df3654b377            |-- fabric-lifecycle-events-v1 2.2.21+b3afc78b77            |-- fabric-loot-api-v2 1.1.39+b3afc78b77            |-- fabric-loot-tables-v1 1.1.43+9e7660c677            |-- fabric-message-api-v1 5.1.7+3265161977            |-- fabric-mining-level-api-v1 2.1.49+b3afc78b77            |-- fabric-model-loading-api-v1 1.0.2+709a987177            |-- fabric-models-v0 0.4.1+9386d8a777            |-- fabric-networking-api-v1 1.3.10+eeb8eb3677            |-- fabric-networking-v0 0.3.50+df3654b377            |-- fabric-object-builder-api-v1 11.1.1+6beca84877            |-- fabric-particles-v1 1.1.1+201a23a077            |-- fabric-recipe-api-v1 1.0.20+b3afc78b77            |-- fabric-registry-sync-v0 2.3.2+4df89eb277            |-- fabric-renderer-api-v1 3.1.2+6bdb2ed077            |-- fabric-renderer-indigo 1.4.2+6bdb2ed077            |-- fabric-renderer-registries-v1 3.2.45+df3654b377            |-- fabric-rendering-data-attachment-v1 0.3.34+b3afc78b77            |-- fabric-rendering-fluids-v1 3.0.27+b3afc78b77            |-- fabric-rendering-v0 1.1.48+df3654b377            |-- fabric-rendering-v1 3.0.7+b3afc78b77            |-- fabric-resource-conditions-api-v1 2.3.5+ea08f9d877            |-- fabric-resource-loader-v0 0.11.9+132c48c177            |-- fabric-screen-api-v1 2.0.7+b3afc78b77            |-- fabric-screen-handler-api-v1 1.3.29+b3afc78b77            |-- fabric-sound-api-v1 1.0.12+b3afc78b77            |-- fabric-transfer-api-v1 3.3.0+cdf060b277            \-- fabric-transitive-access-wideners-v1 4.3.0+6c31357e77         - fabric-language-kotlin 1.10.10+kotlin.1.9.10            |-- org_jetbrains_kotlin_kotlin-reflect 1.9.10            |-- org_jetbrains_kotlin_kotlin-stdlib 1.9.10            |-- org_jetbrains_kotlin_kotlin-stdlib-jdk7 1.9.10            |-- org_jetbrains_kotlin_kotlin-stdlib-jdk8 1.9.10            |-- org_jetbrains_kotlinx_atomicfu-jvm 0.22.0            |-- org_jetbrains_kotlinx_kotlinx-coroutines-core-jvm 1.7.3            |-- org_jetbrains_kotlinx_kotlinx-coroutines-jdk8 1.7.3            |-- org_jetbrains_kotlinx_kotlinx-datetime-jvm 0.4.0            |-- org_jetbrains_kotlinx_kotlinx-serialization-cbor-jvm 1.6.0            |-- org_jetbrains_kotlinx_kotlinx-serialization-core-jvm 1.6.0            \-- org_jetbrains_kotlinx_kotlinx-serialization-json-jvm 1.6.0         - fabricloader 0.15.9            \-- mixinextras 0.3.5         - forgeconfigapiport 8.0.0         - furnacerecycle 2.0         - geophilic v2.0.0-mc1.20u1.20.1         - gildedarmor 1.8.0+fabric-1.20.1         - guiclock 4.2         - guicompass 4.2         - iceberg 1.1.15         - interactic 0.2.0+1.20         - java 17         - kiwi 11.1.1         - lazydfu 0.1.3         - leavesbegone 8.0.0         - lithium 0.11.2         - minecraft 1.20.1         - mixin-conflict-helper 1.2.0         - mixintrace 1.1.1+1.17         - moonlight 1.20-2.8.13         - morebannerfeatures 1.2.0         - mousewheelie 1.12.2+mc1.20.1            |-- amecsapi 1.5.1+mc1.20-pre1            |-- coat 1.0.0-beta.20+mc1.20-pre1            |-- fabric-key-binding-api-v1 1.0.36+fb8d95da77            |-- fabric-screen-api-v1 2.0.7+b3afc78b77            |-- tweed4_annotated 1.3.1+mc1.20-pre1            |-- tweed4_base 1.7.1+mc1.20-pre1            |-- tweed4_data 1.2.1+mc1.20-pre1            |-- tweed4_data_hjson 1.1.1+mc1.20-pre1            |-- tweed4_tailor_coat 1.1.3+mc1.20-pre1            |-- tweed4_tailor_lang_json_descriptions 1.1.0+mc1.20-pre1            \-- tweed4_tailor_screen 1.1.4+mc1.20-pre1         - mru 0.2.1+1.20         - netherportalspread 7.5         - nochatreports 1.20.1-v2.2.2            |-- fabric-rendering-v1 3.0.6+b3afc78b82            \-- fabric-screen-api-v1 2.0.6+b3afc78b82         - nullscape 1.2.2         - nyfsspiders 2.1.1         - owo 0.11.1+1.20            \-- blue_endless_jankson 1.2.2         - patchouli 1.20.1-81-FABRIC            \-- fiber 0.23.0-2         - player-animator 1.0.2-rc1+1.20         - puzzleslib 8.0.24         - rare-ice 0.6.0         - replantingcrops 5.1         - riverredux 0.3.1         - shuffle 9.0.0+1.20.1         - sit 1.20-24         - snowrealmagic 9.0.1         - snowundertrees 1.1.0+1.20         - sound_physics_remastered 1.20.1-1.2.1         - starlight 1.1.2+fabric.dbc156f         - statement 4.2.8+1.14.4-1.20.1            |-- kanos_config 0.4.1+1.14.4-1.19.4            \-- statement_vanilla_compatibility 1.0.1+1.16.5-1.17         - terrablender 3.0.0.169         - transparent 8.0.1+1.20.1         - trinkets 3.7.1         - universalbonemeal 8.0.1         - vanillatweaks 1.5.69         - visualoverhaul 5.0.1            \-- midnightlib 1.4.1         - visualworkbench 8.0.0         - voicechat 1.20.1-2.4.24            \-- fabric-key-binding-api-v1 1.0.36+fb8d95da82         - wandering_collector 1.2.1+mc1.20-pre5            |-- coat 1.0.0-beta.20+mc1.20-pre1            |-- tweed4_annotated 1.3.1+mc1.20-pre1            |-- tweed4_base 1.7.1+mc1.20-pre1            |-- tweed4_data 1.2.1+mc1.20-pre1            |-- tweed4_data_hjson 1.1.1+mc1.20-pre1            |-- tweed4_tailor_coat 1.1.3+mc1.20-pre1            |-- tweed4_tailor_lang_json_descriptions 1.1.0+mc1.20-pre1            \-- tweed4_tailor_screen 1.1.4+mc1.20-pre1         - waterdripsound 1.19-0.3.2         - weaponmaster 3.0.5         - yet_another_config_lib_v3 3.1.1+1.20            |-- com_twelvemonkeys_common_common-image 3.10.0-SNAPSHOT            |-- com_twelvemonkeys_common_common-io 3.10.0-SNAPSHOT            |-- com_twelvemonkeys_common_common-lang 3.10.0-SNAPSHOT            |-- com_twelvemonkeys_imageio_imageio-core 3.10.0-SNAPSHOT            |-- com_twelvemonkeys_imageio_imageio-metadata 3.10.0-SNAPSHOT            \-- com_twelvemonkeys_imageio_imageio-webp 3.10.0-SNAPSHOT         - yosbr 0.1.2         - yungsapi 1.20-Fabric-4.0.1            \-- org_javassist_javassist 3.29.2-GA         - yungsbridges 1.20-Fabric-4.0.1         - yungsextras 1.20-Fabric-4.0.1 [15:07:30] [main/INFO]: Applying default options... (YOSBR) [15:07:30] [main/INFO]: SpongePowered MIXIN Subsystem Version=0.8.5 Source=file:/home/container/libraries/net/fabricmc/sponge-mixin/0.12.5+mixin.0.8.5/sponge-mixin-0.12.5+mixin.0.8.5.jar Service=Knot/Fabric Env=SERVER [15:07:30] [main/INFO]: Compatibility level set to JAVA_17 [15:07:31] [main/INFO]: Preloading Debugify [15:07:31] [main/INFO]: Loaded configuration file for Lithium: 115 options available, 0 override(s) found [15:07:31] [main/WARN]: Reference map 'mru-refmap.json' for mru.mixins.json could not be read. If this is a development environment you can ignore this message [15:07:31] [main/WARN]: Reference map 'yungsextras.refmap.json' for yungsextras.mixins.json could not be read. If this is a development environment you can ignore this message [15:07:31] [main/WARN]: Reference map 'yungsextras.refmap.json' for yungsextras_fabric.mixins.json could not be read. If this is a development environment you can ignore this message [15:07:32] [main/WARN]: Error loading class: fr/catcore/server/translations/api/resource/language/SystemDelegatedLanguage (java.lang.ClassNotFoundException: fr/catcore/server/translations/api/resource/language/SystemDelegatedLanguage) [15:07:32] [main/ERROR]: A mod crashed on startup! net.fabricmc.loader.impl.FormattedException: java.lang.RuntimeException: Could not execute entrypoint stage 'preLaunch' due to errors, provided by 'spectrelib'!         at net.fabricmc.loader.impl.FormattedException.ofLocalized(FormattedException.java:63) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.launch.knot.Knot.init(Knot.java:162) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.launch.knot.Knot.launch(Knot.java:68) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.launch.knot.KnotServer.main(KnotServer.java:23) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.launch.server.FabricServerLauncher.main(FabricServerLauncher.java:69) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.installer.ServerLauncher.main(ServerLauncher.java:69) ~[server.jar:1.0.0] Caused by: java.lang.RuntimeException: Could not execute entrypoint stage 'preLaunch' due to errors, provided by 'spectrelib'!         at net.fabricmc.loader.impl.FabricLoaderImpl.lambda$invokeEntrypoints$2(FabricLoaderImpl.java:388) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.util.ExceptionUtil.gatherExceptions(ExceptionUtil.java:33) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.FabricLoaderImpl.invokeEntrypoints(FabricLoaderImpl.java:386) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.launch.knot.Knot.init(Knot.java:160) ~[fabric-loader-0.15.9.jar:?]         ... 4 more Caused by: java.lang.NoClassDefFoundError: net/fabricmc/loader/impl/entrypoint/EntrypointUtils         at com.illusivesoulworks.spectrelib.SpectrePreLaunchFabricMod.onPreLaunch(SpectrePreLaunchFabricMod.java:33) ~[spectrelib-0.13.12+1.20.1-205a4d5a45c9ac39.jar:?]         at net.fabricmc.loader.impl.FabricLoaderImpl.invokeEntrypoints(FabricLoaderImpl.java:384) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.launch.knot.Knot.init(Knot.java:160) ~[fabric-loader-0.15.9.jar:?]         ... 4 more Caused by: java.lang.ClassNotFoundException: net.fabricmc.loader.impl.entrypoint.EntrypointUtils         at jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:641) ~[?:?]         at java.lang.ClassLoader.loadClass(ClassLoader.java:525) ~[?:?]         at net.fabricmc.loader.impl.launch.knot.KnotClassDelegate.loadClass(KnotClassDelegate.java:226) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.launch.knot.KnotClassLoader.loadClass(KnotClassLoader.java:119) ~[fabric-loader-0.15.9.jar:?]         at java.lang.ClassLoader.loadClass(ClassLoader.java:525) ~[?:?]         at com.illusivesoulworks.spectrelib.SpectrePreLaunchFabricMod.onPreLaunch(SpectrePreLaunchFabricMod.java:33) ~[spectrelib-0.13.12+1.20.1-205a4d5a45c9ac39.jar:?]         at net.fabricmc.loader.impl.FabricLoaderImpl.invokeEntrypoints(FabricLoaderImpl.java:384) ~[fabric-loader-0.15.9.jar:?]         at net.fabricmc.loader.impl.launch.knot.Knot.init(Knot.java:160) ~[fabric-loader-0.15.9.jar:?]         ... 4 more container@pterodactyl~ Server marked as offline... [Pterodactyl Daemon]: ---------- Detected server process in a crashed state! ---------- [Pterodactyl Daemon]: Exit code: 1 [Pterodactyl Daemon]: Out of memory: false [Pterodactyl Daemon]: Aborting automatic restart, last crash occurred less than 60 seconds ago.
    • i cut it up into 3 parts   because it was too big apparentley  1:https://paste.ee/p/Y2stT     2https://paste.ee/p/c96dU         last part: 3:https://paste.ee/p/Sohay   
    • anytime i use it and hit submit it says page expired due to inactivitiy im not stoppoing for more then 30 sec
    • Hi, before starting, i'd like to state that this is not a problem of forge, but still i wanted to ask help here since i've got no results yet from other sources. I've recently made a custom model on blockbench of a block/item, i got everything correct in the resource pack folder (it's just a texture/model, no mods or anything else is required when using it), i get in the game and rename the item to the name that would turn it into the custom textured item. When having it in the inventory/hotbar, the texture does display, but when placing it it does not. Any help please? EDIT: i don't need to use or interact with the item, i just need to display it like a hologram/title
  • Topics

×
×
  • Create New...

Important Information

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