当前位置: 首页>>代码示例>>C#>>正文


C# ILuaState.CheckStack方法代码示例

本文整理汇总了C#中ILuaState.CheckStack方法的典型用法代码示例。如果您正苦于以下问题:C# ILuaState.CheckStack方法的具体用法?C# ILuaState.CheckStack怎么用?C# ILuaState.CheckStack使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在ILuaState的用法示例。


在下文中一共展示了ILuaState.CheckStack方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: AuxResume

		private static int AuxResume( ILuaState lua, ILuaState co, int narg )
		{
			if(!co.CheckStack(narg)) {
				lua.PushString("too many arguments to resume");
				return -1; // error flag
			}
			if( co.Status == ThreadStatus.LUA_OK && co.GetTop() == 0 )
			{
				lua.PushString( "cannot resume dead coroutine" );
				return -1; // error flag
			}
			lua.XMove( co, narg );
			ThreadStatus status = co.Resume( lua, narg );
			if( status == ThreadStatus.LUA_OK || status == ThreadStatus.LUA_YIELD )
			{
				int nres = co.GetTop();
				if(!lua.CheckStack(nres+1)) {
					co.Pop(nres); // remove results anyway;
					lua.PushString("too many results to resume");
					return -1; // error flag
				}
				co.XMove( lua, nres ); // move yielded values
				return nres;
			}
			else
			{
				co.XMove( lua, 1 ); // move error message
				return -1;
			}
		}
开发者ID:Jornason,项目名称:UniLua,代码行数:30,代码来源:LuaCoroLib.cs

示例2: FinishPCall

 private static int FinishPCall( ILuaState lua, bool status )
 {
     // no space for extra boolean?
     if(!lua.CheckStack(1)) {
         lua.SetTop(0); // create space for return values
         lua.PushBoolean(false);
         lua.PushString("stack overflow");
         return 2;
     }
     lua.PushBoolean( status );
     lua.Replace( 1 );
     return lua.GetTop();
 }
开发者ID:rokyado,项目名称:UniLua,代码行数:13,代码来源:LuaBaseLib.cs

示例3: TBL_Unpack

		private static int TBL_Unpack( ILuaState lua )
		{
			lua.L_CheckType( 1, LuaType.LUA_TTABLE );
			int i = lua.L_OptInt( 2, 1 );
			int e = lua.L_OptInt( 3, lua.L_Len(1) );
			if( i > e ) return 0; // empty range
			int n = e - i + 1; // number of elements
			if( n <= 0 || !lua.CheckStack(n) ) // n <= 0 means arith. overflow
				return lua.L_Error( "too many results to unpack" );
			lua.RawGetI( 1, i ); // push arg[i] (avoiding overflow problems
			while( i++ < e ) // push arg[i + 1...e]
				lua.RawGetI( 1, i );
			return n;
		}
开发者ID:jaydenh,项目名称:UniLua,代码行数:14,代码来源:LuaTableLib.cs

示例4: pushargs

 /*
 ** Push on the stack the contents of table 'arg' from 1 to #arg
 */
 static int pushargs(ILuaState L)
 {
     int i, n;
     if (L.GetGlobal("arg") != LuaType.Table)
         L.Error("'arg' is not a table");
     n = L.LLen(-1);
     L.CheckStack(n + 3, "too many arguments to script");
     for (i = 1; i <= n; i++)
         L.RawGetI(-i, i);
     L.Remove(-i);  /* remove table from the stack */
     return n;
 }
开发者ID:ygrenier,项目名称:LuaN,代码行数:15,代码来源:Program.cs

示例5: l_print

 /*
 ** Prints (calling the Lua 'print' function) any values on the stack
 */
 static void l_print(ILuaState L)
 {
     int n = L.GetTop();
     if (n > 0)
     {  /* any result to be printed? */
         L.CheckStack(L.MinStack, "too many results to print");
         L.GetGlobal("print");
         L.Insert(1);
         if (L.PCall(n, 0, 0) != LuaStatus.OK)
             l_message(L, progname, L.PushFString("error calling 'print' (%s)", L.ToString(-1)));
     }
 }
开发者ID:ygrenier,项目名称:LuaN,代码行数:15,代码来源:Program.cs


注:本文中的ILuaState.CheckStack方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。