Opening inventory in game makes it lag really bad

so i took a script form a forum post,http://forum.unity3d.com/viewtopic.php?t=46222 , and changed to be used for me:

    //
var inventory : Array;
static private var InventoryOpen: boolean = false;
var InventoryGUI:Texture2D;
var SpawnPoint: Transform;
var ChatOpnener;

var doWindow : boolean = false;

//  
public var emptyTex : Texture;

//  (- )
public var inventorySizeX = 4;
public var inventorySizeY = 5;

//     
var iconWidthHeight = 40;

//   ( X  Y)
var spacing = 4;

// 
public var offSet = Vector2( 100, 100 );

//      (. Update())
private var itemImage : Texture2D;

//   
class InventoryItem
{
   //    
   var worldObject : GameObject;
   //,       
   var texRepresentation : Texture2D;
}

//  
function Awake()
{
ChatOpnener = GameObject.Find("Tank Weapon Shop Keep").GetComponent("ActiveChat");
offSet = Vector2(Screen.width/2+offSet.x,Screen.height/2+offSet.y);
   inventory = new Array(inventorySizeX);

    for( var i = 0; i < inventory.length; i ++ )
    {
        inventory *= new Array(inventorySizeY);*
 *}*
*}*
*function OnGUI() {*
 *var texToUse : Texture2D;*
 *var currentInventoryItem : InventoryItem;*
*if(InventoryOpen&&!ChatOpnener.ChatIsOpen){*
*GUI.Label(Rect(Screen.width/2-200,Screen.height/2-200,400,400),InventoryGUI);*
 *//* 
 *for( var i = 0; i < inventory.length; i ++ )*
 *{*
 *//* 
 _for( var k = 0; k < inventory*.length; k ++ )*_
 _*{*_
 _*texToUse = emptyTex;*_
 <em>_currentInventoryItem = inventory*[k];*_</em>
 <em>_*//    I-   K- ,*_</em> 
 <em><em>_if( inventory*[k] != null )*_</em></em>
 <em><em>_*{*_</em></em>
 <em><em>_*texToUse = currentInventoryItem.texRepresentation;*_</em></em>
 <em><em>_*}*_</em></em>
 <em><em><em>_var it = GUI.Button( new Rect( offSet.x+k*(iconWidthHeight+spacing), offSet.y+i*(iconWidthHeight+spacing), iconWidthHeight, iconWidthHeight ), texToUse );_</em></em></em>
 <em><em><em>_GUI.Button( new Rect( offSet.x+k*(iconWidthHeight+spacing), offSet.y+i*(iconWidthHeight+spacing), iconWidthHeight, iconWidthHeight ), texToUse );_</em></em></em>
 <em><em>_*var w : int = 0;*_</em></em>
 <em><em>_*var h : int = 0;*_</em></em>
 <em><em>_*if (it && currentInventoryItem != null)*_</em></em> 
 <em><em>_*{*_</em></em> 
 <em><em>_*print("TEST");*_</em></em>
 <em><em>_*Instantiate(currentInventoryItem.worldObject,SpawnPoint.transform.position,Quaternion.identity);*_</em></em>
 <em><em>_*currentInventoryItem.texRepresentation = null;*_</em></em> 
 <em><em><em>_inventory*[k] = null;*_</em></em></em>
 <em><em><em>_*}*_</em></em></em>
 <em><em><em>_*//*_</em></em></em> 
 <em><em><em>_*Debug.Log("item droped");*_</em></em></em>
 <em><em><em>_*}*_</em></em></em>
 <em><em><em>_*}*_</em></em></em>
 <em><em><em>_*}*_</em></em></em>
<em><em><em>_*}*_</em></em></em>
<em><em><em>_*function AddItem( item : InventoryItem )*_</em></em></em>
<em><em><em>_*{*_</em></em></em>
 <em><em><em>_*//*_</em></em></em> 
 <em><em><em>_*for( var i = 0; i < inventory.length; i ++ )*_</em></em></em>
 <em><em><em>_*{*_</em></em></em>
 <em><em><em>_*//*_</em></em></em> 
 <em><em><em><em>_for( var k = 0; k < inventory*.length; k ++ )*_</em></em></em></em>
 <em><em><em><em>_*{*_</em></em></em></em>
 <em><em><em><em>_*//  ,*_</em></em></em></em> 
 <em><em><em><em><em>_if( inventory*[k] == null )*_</em></em></em></em></em>
 <em><em><em><em><em>_*{*_</em></em></em></em></em>
 <em><em><em><em><em><em>_inventory*[k] = item;*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*return;*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*}*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*}*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*}*_</em></em></em></em></em></em> 
 <em><em><em><em><em><em>_*//  ,  -*_</em></em></em></em></em></em> 
<em><em><em><em><em><em>_*}*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*function AddItem1( worldObject : GameObject, texRep : Texture2D )*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*{*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*var newItem = new InventoryItem();*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*newItem.worldObject = worldObject;*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*newItem.texRepresentation = texRep;*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*AddItem( newItem );*_</em></em></em></em></em></em> 
<em><em><em><em><em><em>_*}*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*function Update(){*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*if(Input.GetKeyDown(KeyCode.I)){*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*if(InventoryOpen){*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*InventoryOpen=false;*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*}else{*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*InventoryOpen=true;*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*}*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*}*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*}*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*```*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*<p>but when i added this part:</p>*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*```*_</em></em></em></em></em></em>
<em><em><em><em><em><em>_*if (it && currentInventoryItem != null)*_</em></em></em></em></em></em> 
 <em><em><em><em><em><em>_*{*_</em></em></em></em></em></em> 
 <em><em><em><em><em><em>_*print("TEST");*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*Instantiate(currentInventoryItem.worldObject,SpawnPoint.transform.position,Quaternion.identity);*_</em></em></em></em></em></em>
 <em><em><em><em><em><em>_*currentInventoryItem.texRepresentation = null;*_</em></em></em></em></em></em> 
 <em><em><em><em><em><em><em>_inventory*[k] = null;*_</em></em></em></em></em></em></em>
 <em><em><em><em><em><em><em>_*}*_</em></em></em></em></em></em></em>
<em><em><em><em><em><em><em>_*```*_</em></em></em></em></em></em></em>
<em><em><em><em><em><em><em>_*<p>it lagged my game REALLY bad, it must e something here, just try and help me please, if more info is needed tell me</p>*_</em></em></em></em></em></em></em>

You definitely don't want to have that code inside OnGUI. It runs multiple times a frame.

You just need to go through your code and separate the GUI stuff from the calculation stuff. Move the calculations into their own functions and then call them as needed when you press a button in the GUI.

Don't move it to LateUpdate. That won't solve the fundamental issue which is just simply that you need to organize your code into sections that get called when needed instead of multiple times per frame.

First of all - you have to go over the code and tidy it up.... Lots of wasted CPU cycles are bad for global warming :)

Second - if in fact when you add those lines it got really bad, just for kicks try and define it as a boolean and not let UnityScript figure it out by itself. See if it gives you some boost. Duck typing is fun, but has some performance loss.

var it: boolean = GUI.Button(...

instead of:

var it = GUI.Button(...

Use time.timeScale = 0 when inventory is open to freeze time. That should freeze the lag but if you want to have things moving in the background of the inventory than this is not the best option.