亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rtl_array.cpp

?? c-smile 一個語法類似與JS 又有點像C++的 編譯器
?? CPP
字號:
/*
*
* rtl_array.cpp
*
* Copyright (c) 2001, 2002
* Andrew Fedoniouk - andrew@terra-informatica.org
* Portions: Serge Kuznetsov -  kuznetsov@deeptown.org
*
* See the file "COPYING" for information on usage 
* and redistribution of this file
*
*/
#include <stdio.h>
#include <stdlib.h>
#include "c-smile.h"
#include "vm.h"
#include "arithmetic.h"
#include "rtl.h"
namespace c_smile
{
  // ARRAY instance
  ARRAY::ARRAY ( int n )
  {
    data.size ( n, &VM::undefined );
  }

  // markvector - mark a vector
  void
    ARRAY::mark ()
  {
    THING::mark ();
    int n = data.size ();
    if ( n )
    {
      VALUE *pv = &data [ 0 ];
      while ( --n >= 0 )
        ( pv++ )->mark ();
    }
  }

  VALUE &
    ARRAY::operator[] ( int i )
  {
    assert ( i < size () );
    return data [ i ];
  }

  const VALUE &
    ARRAY::operator[] ( int i ) const
  {
    assert ( i < size () );
    return data [ i ];
  }

  int
    ARRAY::push ( const VALUE& v )
  {
    int pos = size ();
    data.push ( v );
    return pos;
  }

  void
    ARRAY::size ( int newsize )
  {
    data.size ( newsize, &VM::undefined );
  }

  VALUE
    ARRAY::pop ()
  {
    if ( data.size () )
      return data.pop ();
    return VM::undefined;
  }

  void
    ARRAY::sort ( void *param,
                  bool ( *less ) ( void *param, VALUE& a, VALUE& b ),
                  int lo, int hi )
  {
    int i = lo;
    int j = hi;
    VALUE *xs = &data [ 0 ];
    VALUE pivot = xs [ ( i + j ) / 2 ];
    do
    {
      while ( ( *less ) ( param, xs [ i ], pivot ) )
        i++;
      while ( ( *less ) ( param, pivot, xs [ j ] ) )
        j--;
      if ( i <= j )
      {
        VALUE temp = xs [ i ];
        xs [ i ] = xs [ j ];
        xs [ j ] = temp;
        i++;
        j--;
      }
    }
    while ( i <= j );

    if ( lo < j )
      sort ( param, less, lo, j );
    if ( i < hi )
      sort ( param, less, i, hi );
  }

  void
    ARRAY::sort ( void *param,
                  bool ( *less ) ( void *param, VALUE& a, VALUE& b ) )
  {
    if ( size () > 1 )
      sort ( param, less, 0, size () - 1 );
  }

  ARRAY *
    ARRAY::slice ( int start, int end )
  {
    int st = start >= 0 ? start : ( size () + start );
    int en = end >= 0 ? end : ( size () + end );

    if ( en > size () )
      en = size ();

    int length = en - st;

    if ( length <= 0 || st >= size () )
      return new ARRAY ( 0 );

    ARRAY *ar = new ARRAY ( length );

    VALUE *src = &data [ st ];
    VALUE *dst = &ar->data [ 0 ];
    for ( int i = 0; i < length; i++ )
      *dst++ = *src++;
      
    return ar;
  }

  void
    ARRAY::remove ( int start, int end )
  {
    int st = start >= 0 ? start : ( size () + start );
    int en = end   >= 0 ? end   : ( size () + end );

    if ( en > size () )
      en = size ();

    int length = en - st;

    if ( length <= 0 || st >= size () )
      return;

    for ( int i = 0; i < length; i++ )
      data.remove ( st );
  }

  CLASS *
    ARRAY::get_class ()
  {
    return VM::class_array;
  }

    // ARRAY CLASS

  VALUE
    ARRAY_CLASS::ctor ( int argc, VALUE *argv )
  {
    if ( argc == 1 && argv [ 0 ].v_type == DT_INTEGER )
    {
      int sz = argv [ 0 ].v.v_integer;
      return VALUE ( new ARRAY ( sz < 0 ? -sz : sz ) );
    }
    else if ( argc == 1 && argv [ 0 ].v_type == DT_ARRAY )
    {
      ARRAY *src = argv [ 0 ].v.v_vector;
      ARRAY *dst = new ARRAY ( src->size () );
      for ( int i = 0; i < src->size (); i++ )
        ( *dst ) [ i ] = ( *src ) [ i ];
      return VALUE ( dst );
    }
    else
    {
      ARRAY * vec = new ARRAY ( argc );
      for ( int i = 0; i < argc; ++i )
        ( *vec ) [ i ] = argv [ i ];
      return VALUE ( vec );
    }
    return VALUE ( new ARRAY ( 0 ) );
  }

  VALUE
    ARRAY_CLASS::literal ( int argc, VALUE *argv )
  {
    ARRAY * vec = new ARRAY ( argc );
    for ( int i = 0; i < argc; ++i )
      ( *vec ) [ i ] = argv [ i ];

    return VALUE ( vec );
  }

  VALUE
    ARRAY_CLASS::length ( int argc, VALUE *argv )
  {
    argcount ( argc, 0 );
    return VALUE ( _this_.v.v_vector->size () );
  }

  VALUE ARRAY_CLASS::push ( int argc, VALUE *argv )
  {
    ARRAY *me = _this_.v.v_vector;
    for ( int i = 0; i < argc; i++ )
      me->push ( argv [ i ] );

    return me->size ();
  }

  VALUE
    ARRAY_CLASS::pop ( int argc, VALUE *argv )
  {
    argcount ( argc, 0 );
    return _this_.v.v_vector->pop ();
  }

  struct value_less_params
  {
    VM *vm;
    VALUE sort_func;
  };

  bool
    value_less_udf ( void *param, VALUE& a, VALUE& b )
  {
    value_less_params *p = ( value_less_params * ) param;
    VALUE ar [ 2 ];
    ar [ 0 ] = a;
    ar [ 1 ] = b;
    return bool ( p->vm->call ( p->sort_func, 2, ar ) );
  }

  bool
    value_less ( void *param, VALUE& a, VALUE& b )
  {
    VALUE v = op_lt ( (VM * ) param, a,b );
    return bool ( v );
  }


  VALUE
    ARRAY_CLASS::sort ( int argc, VALUE *argv )
  {
    if ( argc == 0 )
    {
      _this_.v.v_vector->sort ( VM::current (), value_less );
    }
    else if ( argc == 1 )
    {
      value_less_params p;
      p.vm = VM::current ();
      p.sort_func = *argv;
      _this_.v.v_vector->sort ( &p, value_less_udf );
    }
    return VM::undefined;
  }

  VALUE
    ARRAY_CLASS::slice ( int argc, VALUE *argv )
  {
    ARRAY *me = _this_.v.v_vector;
    if ( argc == 1 && argv [ 0 ].is_number () )
      return VALUE ( me->slice ( int ( argv [ 0 ] ), me->size () ) );
    else if ( argc == 2 && argv [ 0 ].is_number () && argv [ 1 ].is_number () )
      return VALUE ( me->slice ( int ( argv [ 0 ] ), int ( argv [ 1 ] ) ) );

    error_parameters ();

    return VM::undefined;
  }

  VALUE
    ARRAY_CLASS::concat ( int argc, VALUE *argv )
  {
    ARRAY *me = _this_.v.v_vector;
    for ( int i = 0; i < argc; i++ )
    {
      if ( argv [ i ].is_array () )
      {
        ARRAY *a = argv [ i ].v.v_vector;
        for ( int j = 0; j < a->size (); j++ )
          me->push ( (*a ) [ j ] );
      }
      else
        me->push ( argv [ i ] );
    }
    return me->size ();
  }

  VALUE
    ARRAY_CLASS::shift ( int argc, VALUE *argv )
  {
    argcount ( argc, 0 );
    ARRAY *me = _this_.v.v_vector;
    VALUE v;
    if ( me->size () )
    {
      v = ( *me ) [ 0 ];
      for ( int i = 0; i < me->size () - 1; i++ )
        me->data [ i ] = me->data [ i + 1 ];
      me->size ( me->size () - 1 );
    }
    return v;
  }

  VALUE
    ARRAY_CLASS::unshift ( int argc, VALUE *argv )
  {
    if ( argc == 0 )
      return VM::undefined;

    ARRAY *me = _this_.v.v_vector;
    int i;
    int oldsize = me->size ();
    me->size ( oldsize + argc );
    VALUE *src = &me->data [ oldsize - 1 ];
    VALUE *dst = &me->data [ me->size () - 1 ];
    for ( i = 0; i < oldsize ;i++ )
      *dst-- = *src--;
    dst = &me->data [ 0 ];
    for ( i = 0; i < argc; i++ )
      *dst++ = *argv++;

    return VM::undefined;
  }

  VALUE
    ARRAY_CLASS::tostring ( int argc, VALUE *argv )
  {
    ARRAY *me = _this_.v.v_vector;
    string dlmtr;
    if ( argc == 0 )
      dlmtr = ",";
    else if ( argc == 1 && argv [ 0 ].v_type == DT_STRING )
      dlmtr = CSTR ( argv [ 0 ].v.v_string );
    else
      error_parameters ();

    string s;
    int lastel = me->data.size () - 1;
    for ( int i = 0; i <= lastel; i++ )
    {
      VALUE v = me->data [ i ];
      s += string ( v );
      if ( i != lastel )
        s += dlmtr;
    }
    return VALUE ( new STRING ( s ) );
  }

  VALUE
    ARRAY_CLASS::item ( int argc, VALUE *argv )
  {
    ARRAY *me = _this_.v.v_vector;
    chktype ( 0, DT_INTEGER );
    int idx = int ( argv [ 0 ] );
    if ( idx < 0 || idx >= me->size () )
      VM::error ( "Index %d is out of bounds", idx );

    if ( argc == 2 ) // set
      me->data [ idx ] = argv [ 1 ];
    return me->data [ idx ];
  }

  VALUE
    ARRAY_CLASS::clear ( int argc, VALUE *argv )
  {
    ARRAY *me = _this_.v.v_vector;

    if ( argc )
      error_parameters ();
    me->size ( 0 );

    return VM::undefined;
  }

  VALUE
    ARRAY_CLASS::remove ( int argc, VALUE *argv )
  {
    ARRAY *me = _this_.v.v_vector;
    int start = 0;
    int end = 0;
    if ( argc == 1 && argv [ 0 ].is_number () )
      me->remove ( int ( argv [ 0 ] ), me->size () );
    else if ( argc == 2 && argv [ 0 ].is_number () && argv [ 1 ].is_number () )
      me->remove ( int ( argv [ 0 ] ), int ( argv [ 1 ] ) );
    else
      error_parameters ();

    return VM::undefined;
  }

};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩黄色影视| 国产欧美一区二区精品忘忧草| 日韩精品一区在线| 亚洲伦理在线精品| 国产在线播放一区二区三区| 欧美视频在线观看一区二区| 亚洲国产精品传媒在线观看| 久久精品国产精品青草| 欧美三级韩国三级日本三斤| 国产精品家庭影院| 国产夫妻精品视频| 欧美tickle裸体挠脚心vk| 亚洲伊人色欲综合网| www.在线欧美| 国产精品午夜在线观看| 九九九精品视频| 欧美一个色资源| 婷婷中文字幕一区三区| 欧美网站一区二区| 一区二区三区中文字幕精品精品| 国产米奇在线777精品观看| 精品少妇一区二区三区日产乱码 | 视频在线在亚洲| 91久久精品一区二区三区| 国产精品久久影院| 成人综合日日夜夜| 欧美激情一区二区| 国产成人av电影在线播放| 久久一区二区视频| 久久99精品久久久| 精品成人a区在线观看| 美女视频网站久久| 欧美成va人片在线观看| 伦理电影国产精品| 精品国产91乱码一区二区三区| 蜜臀久久久99精品久久久久久| 91精品一区二区三区久久久久久 | 日韩欧美国产午夜精品| 久久精品国产99国产| 欧美精品一区二区三| 激情综合网最新| 久久久久国产精品免费免费搜索| 国产呦萝稀缺另类资源| 欧美激情一区在线| 一道本成人在线| 性做久久久久久| 精品国产91九色蝌蚪| 国产99久久久国产精品免费看| 国产午夜精品美女毛片视频| 不卡高清视频专区| 亚洲欧美经典视频| 在线成人免费观看| 九九在线精品视频| 中文字幕一区二区三区在线不卡| 色婷婷一区二区| 日本美女一区二区三区视频| 亚洲精品在线观看视频| 成人app在线| 天堂av在线一区| 久久女同性恋中文字幕| 成人免费高清视频在线观看| 亚洲一区在线观看视频| 日韩精品一区二区三区三区免费| 国产精品996| 亚洲一区二区欧美激情| 欧美精品一区在线观看| 91麻豆精东视频| 日本视频一区二区三区| 日本一区二区动态图| 欧美日韩一级黄| 国产高清不卡一区二区| 图片区小说区区亚洲影院| 国产偷v国产偷v亚洲高清 | 懂色中文一区二区在线播放| 亚洲综合区在线| 久久精品免费在线观看| 欧美性感一区二区三区| 国产高清亚洲一区| 日本伊人色综合网| 亚洲裸体xxx| 精品久久久久久久久久久久久久久久久| www.欧美亚洲| 国产综合色精品一区二区三区| 亚洲午夜久久久久久久久电影网 | 成人av免费在线观看| 蜜臀av一区二区在线免费观看| 中文字幕字幕中文在线中不卡视频| 欧美一区二区三区视频| 欧洲av一区二区嗯嗯嗯啊| 国产精品888| 久久99精品久久久久久国产越南| 一卡二卡三卡日韩欧美| 国产精品久久久久久久第一福利| 欧美xxxxx牲另类人与| 欧美女孩性生活视频| 日本韩国一区二区三区视频| 国产成人一级电影| 精一区二区三区| 视频一区在线播放| 亚洲成a人v欧美综合天堂| 亚洲欧洲国产日韩| 国产欧美日韩精品一区| 亚洲精品一区二区精华| 日韩欧美亚洲国产另类| 欧美一区二区三区四区高清| 欧美日韩电影一区| 欧洲一区二区av| 91高清视频在线| 色婷婷av一区二区三区大白胸| 成人丝袜18视频在线观看| 国产精品一区二区三区四区| 久久99精品国产.久久久久 | 久久综合久久鬼色中文字| 制服丝袜国产精品| 91精品国产一区二区三区| 欧美一区二区国产| 欧美成人一区二区| 2021国产精品久久精品| 精品国产百合女同互慰| 久久久久亚洲综合| 久久久99免费| 国产精品每日更新| 亚洲欧美自拍偷拍| 有码一区二区三区| 亚洲午夜久久久久久久久电影院| 午夜精品一区在线观看| 日本视频在线一区| 国产中文字幕精品| 成人午夜电影小说| 91理论电影在线观看| 欧美日韩国产高清一区| 日韩精品一区二区在线| 国产日韩三级在线| 一区二区三区日韩精品视频| 丝袜美腿高跟呻吟高潮一区| 琪琪久久久久日韩精品| 国产九色sp调教91| www.成人在线| 欧美人成免费网站| 久久久久97国产精华液好用吗| 中文字幕在线一区免费| 亚洲综合免费观看高清完整版在线 | 麻豆成人久久精品二区三区红| 精品一区二区免费视频| 成人av在线资源网站| 欧洲人成人精品| 精品对白一区国产伦| 亚洲蜜臀av乱码久久精品| 日韩成人伦理电影在线观看| 成人丝袜18视频在线观看| 欧美揉bbbbb揉bbbbb| 欧美精品一区二区三区蜜桃| 1024成人网| 免费欧美在线视频| 99久久99久久精品免费观看| 欧美一区二区三区四区视频| 中文字幕亚洲在| 日本午夜一区二区| 91在线精品一区二区| 精品噜噜噜噜久久久久久久久试看| 国产精品日韩精品欧美在线| 亚洲成a人v欧美综合天堂| 国产精品一区二区在线观看网站| 欧美日韩一级大片网址| 欧美高清在线一区| 奇米在线7777在线精品| 在线区一区二视频| 久久久久久久电影| 蜜芽一区二区三区| 色先锋资源久久综合| 国产清纯白嫩初高生在线观看91| 午夜激情一区二区三区| 色综合天天视频在线观看| 亚洲精品在线一区二区| 日韩精品成人一区二区三区| 99国产精品国产精品毛片| 久久久久久97三级| 免费在线欧美视频| 欧美日韩免费高清一区色橹橹 | 视频一区二区国产| 色综合久久精品| 日本一区二区三区视频视频| 精品一区二区三区欧美| 欧美精品在线一区二区| 一区二区三区欧美激情| 成人av网站免费观看| 欧美国产激情二区三区| 国产成人av电影| 久久久久国产精品人| 国产成人亚洲综合a∨婷婷图片| 欧美r级在线观看| 久久成人羞羞网站| 日韩午夜精品视频| 日本欧美加勒比视频| 欧美一区二区三区成人| 日本一区中文字幕| 日韩精品一区二区三区swag | 日本美女一区二区| 91精品国产91久久综合桃花| 亚洲sss视频在线视频|