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

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

?? rtl_stream.cpp

?? c-smile 一個語法類似與JS 又有點像C++的 編譯器
?? CPP
字號:
/*
*
* rtl_stream.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
{
  using namespace sal;

  // STREAM CLASS

  bool
    STREAM::INSTANCE::get ( char &c )
  {
    if ( buf.length () )
    {
      c = buf [ buf.length () - 1 ];
      buf.cut ( -1 );
      return true;
    }
    else
      return ios->get ( c );
  }

  void
    STREAM::INSTANCE::unget ( char c )
  {
    buf += c;
  }

  VALUE
    STREAM::close ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( me->ios == 0 )
      return VALUE ( false );

    bool r = me->ios->close ();
    me->base = 0;
    delete me->ios;
    me->ios = 0;

    return VALUE ( r );
  }

  VALUE
    STREAM::put ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( me->ios == 0 )
      return VM::undefined;

    //TODO: raise error
    while ( argc-- )
    {
      switch ( argv->v_type )
      {
      case DT_INTEGER:
        if ( !me->ios->put ( argv->v.v_integer  & 0xff ) )
          return VALUE ( false );
        break;
      case DT_STRING:
        if ( !me->ios->put ( CSTR ( argv->v.v_string ) ) )
          return VALUE ( false );
        break;
      default:
        error_parameters ();
      }
      ++argv;
    }
    return VALUE ( true );
  }

  void
    STREAM::fill_params ( array<string>& params, int argc, VALUE *argv )
  {
    for ( int i = 0; i < argc; ++i )
    {
      if ( argv [ i ].is_int () )
        params.push ( string ( char ( int ( argv [ i ] ) ) ) );
      else if ( argv [ i ].is_string () )
        params.push ( CSTR ( argv [ i ].v.v_string ) );
      else if ( argv [ i ].is_array () )
      {
        ARRAY &arr = *argv [ i ].v.v_vector;
        fill_params ( params, arr.size (), &arr [ 0 ] );
      }
      else
        error_parameters ();
    }
  }

  VALUE
    STREAM::get ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( me->ios == 0 )
      return VALUE ();

    me->last_match_arg = 0;

    //TODO: raise error
    if ( argc == 0 )
    {
      char c;
      if ( !me->get ( c ) )
      {
        me->is_eof = true;
        return VM::undefined;
      }
      return VALUE ( int ( c ) );
    }
    else
    {
      array<string> delimeters;
      fill_params ( delimeters, argc, argv );
      string buffer;
      me->last_match_arg = 0;
      int maxlen = 0;
      for ( int i = 0; i < delimeters.size (); ++i )
        if ( maxlen < delimeters [ i ].length () )
          maxlen = delimeters [ i ].length ();

      char c;
      while ( buffer.length () < maxlen )
      {
        if ( !me->get ( c ) )
        {
          if ( buffer.length () )
          {
            return VALUE ( new STRING ( buffer ) );
          }
          else
          {
            me->is_eof = true;
            return VM::undefined;
          }
        }
        buffer += c;
      }

      while ( ( !me->last_match_arg ) &&
              ( buffer.length () < MAX_STRING_BUFFER )
            )
      {
        for ( int i = 0; i < delimeters.size (); ++i )
        {
          string& dlm = delimeters [ i ];
          int len = min ( dlm.length (), maxlen );
          if ( strncmp ( dlm,
                       ( (const char *) buffer ) + buffer.length ()  - maxlen,
                       len ) == 0 )
          {
            me->last_match_arg = i + 1;
            int idx = buffer.length ()  - maxlen + len;
            for ( int k = buffer.length () - 1; k >= idx; k-- )
              me->unget ( buffer [ k ] );
            buffer.cut ( buffer.length () - maxlen );
            return VALUE ( new STRING ( buffer ) );
          }
        }
        if ( !me->get ( c ) )
        {
          if ( buffer.length () )
            break;
          else
          {
            me->is_eof = true;
            return VM::undefined;
          }
        }
        buffer += c;
      }

      return VALUE ( new STRING ( buffer ) );
    }
  }

  VALUE
    STREAM::get_match ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( argc )
      error_read_only ();

    return me->last_match_arg;
  }

  VALUE
    STREAM::printf ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( argc && argv [ 0 ].is_string () )
    {
      string s = format ( CSTR ( argv [ 0 ].v.v_string ), argc - 1, argv + 1 );
      me->ios->put ( (const char *) s);
    }
    else
      error_parameters ();

    return VALUE ( me );
  }

  VALUE
    STREAM::position ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( argc && argv [ 0 ].is_int () )
    {
      me->ios->position ( int ( argv [ 0 ] ) );
    }
    else if ( argc != 0 )
      error_parameters ();

    return VALUE ( (int) me->ios->position () );
  }

  // STREAM::INSTANCE::length
  VALUE
    STREAM::size ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( me->ios == 0 )
      return VALUE ();
    //TODO: raise error

    if ( argc == 0 ) // get
      return VALUE ( (int) me->ios->size () );
    else if ( argc == 1 ) // set
    {
      int i;
      //TODO: raise error if negative!
      VM::arguments ( argc, argv, "i", &i );
      me->ios->size ( i );
      return VALUE ( (int) me->ios->size () );
    }
    return VALUE ();
  }

  VALUE
    STREAM::read ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( argc != 2 || !argv [ 0 ].is_thing () || !argv [ 1 ].is_int () )
      error_parameters ();

    if ( argv [ 0 ].v.v_thing->get_class () != BLOB::INSTANCE::klass )
      error_parameters ();

    BLOB::INSTANCE *buffer = (BLOB::INSTANCE *) argv [ 0 ].v.v_thing;
    int sz = int ( argv [ 1 ] ), sz_read = 0;
    buffer->data.size ( sz );
    bool r = me->ios->read ( (char * ) &buffer->data [ 0 ], sz, &sz_read );
    buffer->data.size ( sz_read );
    if ( sz_read == 0 )
    {
      me->is_eof = true;
      return VM::undefined;
    }

    return VALUE ( sz_read );
  }

  VALUE
    STREAM::write ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( argc == 0 )
      error_parameters ();

    if ( (argc != 1 ) || ( !argv [ 0 ].is_thing () ) )
      error_parameters ();

    if ( argv [ 0 ].v.v_thing->get_class () != BLOB::INSTANCE::klass )
      error_parameters ();

    BLOB::INSTANCE *buffer = (BLOB::INSTANCE *) argv [ 0 ].v.v_thing;
    int start = 0;
    int length = buffer->data.size ();

    if ( argc > 1 )
    {
      if ( !argv [ 1 ].is_int () )
        error_parameters ();

      start = int ( argv [ 1 ] );
      if ( start < 0 )
        start = 0;

      if ( start > length )
        start = length;

      length = buffer->data.size () - start;
    }

    if ( argc > 2 )
    {
      if ( !argv [ 2 ].is_int () )
        error_parameters ();

      length = int ( argv [ 2 ] );

      if ( start + length > buffer->data.size () )
      {
        length = buffer->data.size () - start;
      }
    }

    if ( length <= 0 )
      VM::error ( "std::stream::write count = %d", length );

    int sz_written = 0;
    bool r = me->ios->write ( (char *) &buffer->data [ start ], length,
                              &sz_written );
    if ( sz_written == 0   )
    {
      return VM::undefined;
    }
    return VALUE ( sz_written );
  }

  // STREAM::INSTANCE::length
  VALUE
    STREAM::src ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( me->ios == 0 )
      return VM::null;

    if ( argc == 0 ) // get
      return VALUE ( *me->base );
    else
      error_read_only ();

    return VALUE ();
  }

  VALUE
    STREAM::eof ( int argc, VALUE *argv )
  {
    STREAM::INSTANCE *me = (STREAM::INSTANCE *) _this_.v.v_thing;

    if ( me->ios == 0 )
      return VM::null;

    if ( argc == 0 ) // get
      return VALUE ( me->is_eof );
    else
      error_read_only ();

    return VALUE ();
  }

  CLASS * STREAM::INSTANCE::klass = 0;


  STREAM::STREAM ( PACKAGE* package ) : CLASS ( "stream", 0, package  )
  {
    add_function ( "put",    put    );
    add_function ( "get",    get    );
    add_function ( "printf", printf );
    add_function ( "read",   read   );
    add_function ( "write",  write  );
    add_function ( "close",  close  );

    //enum whence_mode
    add_const ( "sw_absolute", VALUE ( int ( file::fw_absolute ) ) );
    add_const ( "sw_current",  VALUE ( int ( file::fw_current ) ) );
    add_const ( "sw_end",      VALUE ( int ( file::fw_end ) ) );

    add_property ( "get_match", get_match );
    add_property ( "source",    src );
    add_property ( "eof",       eof );
    add_property ( "position",  position );

    STREAM::INSTANCE::klass = this;

  }

};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美在线观看一区二区三区| 亚洲3atv精品一区二区三区| 宅男在线国产精品| 91麻豆精品一区二区三区| 国产裸体歌舞团一区二区| 九九久久精品视频| 国产乱子轮精品视频| 国产主播一区二区三区| 国产一区二区成人久久免费影院 | 亚洲福利一区二区| 亚洲另类一区二区| 亚洲国产成人高清精品| 日韩高清一区在线| 卡一卡二国产精品 | 成人小视频免费观看| 成人免费毛片片v| 91女人视频在线观看| 欧美唯美清纯偷拍| 555www色欧美视频| 久久麻豆一区二区| 亚洲欧洲国产日韩| 亚洲国产综合色| 久久精品国产77777蜜臀| 国产综合久久久久久鬼色| 国产精品99久久久久久久女警| 久久99久久精品欧美| 国产成人亚洲精品狼色在线| 97国产精品videossex| 欧美私模裸体表演在线观看| 欧美成人一区二区三区片免费 | 成人av网站在线| 色94色欧美sute亚洲线路一久| 在线不卡a资源高清| 久久综合色鬼综合色| 中文字幕一区免费在线观看| 日韩专区在线视频| 国模套图日韩精品一区二区| 色哟哟国产精品| 日韩欧美国产一区二区三区| 亚洲精品一二三| 韩国欧美国产1区| 色婷婷国产精品| 久久久.com| 爽好久久久欧美精品| 99久久综合99久久综合网站| 欧美一区二区三区在线视频| 亚洲欧美一区二区三区孕妇| 激情综合亚洲精品| 欧美日韩在线一区二区| 日本一区二区三区电影| 久久国产剧场电影| 91福利视频久久久久| 亚洲国产激情av| 日本成人中文字幕在线视频| 91久久精品国产91性色tv| 欧美韩国日本一区| 久久爱www久久做| 欧美剧情片在线观看| 亚洲欧美日韩中文播放| 风间由美一区二区av101| 日韩一区二区三区四区五区六区| 亚洲综合在线五月| 成人激情小说网站| 久久精品一级爱片| 国产中文一区二区三区| 精品久久久久香蕉网| 日韩精品久久理论片| 911精品国产一区二区在线| 亚洲免费色视频| 色悠悠久久综合| 综合激情网...| 色噜噜久久综合| 亚洲欧美区自拍先锋| 色婷婷综合中文久久一本| 国产精品高清亚洲| 成人97人人超碰人人99| 国产精品久久精品日日| 99精品1区2区| 亚洲免费观看高清完整版在线观看熊 | 亚洲午夜在线电影| 91国偷自产一区二区三区观看| 亚洲欧美另类综合偷拍| 日本乱码高清不卡字幕| 亚洲一区在线观看视频| 欧美日韩国产乱码电影| 亚洲成人先锋电影| 91精品国产综合久久久久| 男人操女人的视频在线观看欧美| 欧美一区二区免费视频| 蜜臀va亚洲va欧美va天堂| 精品99一区二区| 成人性生交大片免费看在线播放| 国产精品乱人伦一区二区| 91亚洲精品一区二区乱码| 一区二区三区国产精华| 9191精品国产综合久久久久久| 精油按摩中文字幕久久| 国产欧美一区二区三区在线老狼| 不卡一区二区中文字幕| 亚洲自拍偷拍麻豆| 欧美一区永久视频免费观看| 国产精品乡下勾搭老头1| 亚洲素人一区二区| 欧美精品自拍偷拍| 国产精品99精品久久免费| 自拍偷拍欧美激情| 欧美一区二区三区男人的天堂| 国产伦精一区二区三区| 一区二区三区日本| 精品国产污网站| 99久久久久免费精品国产| 青娱乐精品视频| 国产精品传媒入口麻豆| 欧美一区二区网站| 成人毛片在线观看| 奇米精品一区二区三区在线观看一| 久久精品欧美一区二区三区不卡 | 欧美另类z0zxhd电影| 久99久精品视频免费观看| 亚洲另类在线视频| 国产三级一区二区三区| 欧美日韩不卡一区| 不卡的av电影| 久久99精品国产| 午夜精品久久久| 亚洲丝袜美腿综合| 久久精品一区八戒影视| 日韩欧美久久久| 在线精品视频一区二区三四| 成人一二三区视频| 黄一区二区三区| 日韩中文字幕不卡| 亚洲一区二区高清| 亚洲欧美综合色| 国产女人水真多18毛片18精品视频 | 成人性生交大片| 激情综合亚洲精品| 乱中年女人伦av一区二区| 亚洲狠狠爱一区二区三区| 亚洲欧洲综合另类| 亚洲私人黄色宅男| 中文字幕一区在线| 亚洲欧洲av在线| 国产精品久久久爽爽爽麻豆色哟哟| 久久女同性恋中文字幕| 精品国产一区久久| 日韩欧美成人一区二区| 在线综合亚洲欧美在线视频| 欧美久久久一区| 777午夜精品免费视频| 欧美日韩综合色| 欧美二区乱c少妇| 欧美精品乱码久久久久久 | 成人午夜视频免费看| 国产一区二区在线看| 久久国产福利国产秒拍| 久久99国内精品| 国产精品911| 99热在这里有精品免费| av欧美精品.com| 91免费在线视频观看| 色婷婷av一区二区| 欧美日韩精品一区二区| 欧美一区二区三区免费| 欧美变态凌虐bdsm| 久久久久88色偷偷免费| 国产精品久久久久久久久免费相片| 国产精品狼人久久影院观看方式| 国产精品国产三级国产aⅴ入口| 成人欧美一区二区三区视频网页| 亚洲你懂的在线视频| 亚洲成人黄色小说| 麻豆精品新av中文字幕| 国产高清久久久久| 99久久精品免费看国产| 欧美亚洲丝袜传媒另类| 欧美一区二区视频在线观看2022 | 国产一区二区成人久久免费影院| 岛国一区二区三区| 91福利视频网站| 精品国产亚洲一区二区三区在线观看| 欧美国产在线观看| 亚洲一区二区高清| 国产一区二区三区在线观看精品| 成人福利视频网站| 欧美精选午夜久久久乱码6080| 久久免费精品国产久精品久久久久| 国产精品久久久久桃色tv| 五月婷婷久久综合| 岛国精品在线观看| 欧美美女视频在线观看| 国产欧美日韩综合| 视频一区二区国产| www.欧美日韩| 精品伦理精品一区| 亚洲一区二区欧美| 本田岬高潮一区二区三区| 欧美一区二区三区免费观看视频 | 国产精品资源在线| 欧美日韩一二三|