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

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

?? objc-act.c

?? gcc庫的原代碼,對編程有很大幫助.
?? C
?? 第 1 頁 / 共 5 頁
字號:
static treeinit_def_list (type)     tree type;{  tree expr, initlist = NULL_TREE;  struct imp_entry *impent;  if (imp_count)    for (impent = imp_list; impent; impent = impent->next)      {	if (TREE_CODE (impent->imp_context) == CLASS_IMPLEMENTATION_TYPE)	  {	    expr = build_unary_op (ADDR_EXPR, impent->class_decl, 0);	    initlist = tree_cons (NULL_TREE, expr, initlist);	  }      }  if (cat_count)    for (impent = imp_list; impent; impent = impent->next)      {	if (TREE_CODE (impent->imp_context) == CATEGORY_IMPLEMENTATION_TYPE)	  {	    expr = build_unary_op (ADDR_EXPR, impent->class_decl, 0);	    initlist = tree_cons (NULL_TREE, expr, initlist);	  }      }  return build_constructor (type, nreverse (initlist));}/* Construct the initial value for all of _objc_symtab.  */static treeinit_objc_symtab (type)     tree type;{  tree initlist;  /* sel_ref_cnt = { ..., 5, ... } */  initlist = build_tree_list (NULL_TREE, build_int_2 (0, 0));  /* refs = { ..., _OBJC_SELECTOR_TABLE, ... } */  if (flag_next_runtime || ! sel_ref_chain)    initlist = tree_cons (NULL_TREE, build_int_2 (0, 0), initlist);  else    initlist = tree_cons (NULL_TREE,			  build_unary_op (ADDR_EXPR,					  UOBJC_SELECTOR_TABLE_decl, 1),			  initlist);  /* cls_def_cnt = { ..., 5, ... } */  initlist = tree_cons (NULL_TREE, build_int_2 (imp_count, 0), initlist);  /* cat_def_cnt = { ..., 5, ... } */  initlist = tree_cons (NULL_TREE, build_int_2 (cat_count, 0), initlist);  /* cls_def = { ..., { &Foo, &Bar, ...}, ... } */  if (imp_count || cat_count)    {      tree field = TYPE_FIELDS (type);      field = TREE_CHAIN (TREE_CHAIN (TREE_CHAIN (TREE_CHAIN (field))));      initlist = tree_cons (NULL_TREE, init_def_list (TREE_TYPE (field)),			    initlist);    }  return build_constructor (type, nreverse (initlist));}/* Push forward-declarations of all the categories   so that init_def_list can use them in a CONSTRUCTOR.  */static voidforward_declare_categories (){  struct imp_entry *impent;  tree sav = implementation_context;  for (impent = imp_list; impent; impent = impent->next)    {      if (TREE_CODE (impent->imp_context) == CATEGORY_IMPLEMENTATION_TYPE)	{	  /* Set an invisible arg to synth_id_with_class_suffix.  */	  implementation_context = impent->imp_context;	  impent->class_decl	    = create_builtin_decl (VAR_DECL, objc_category_template,				   IDENTIFIER_POINTER (synth_id_with_class_suffix ("_OBJC_CATEGORY", implementation_context)));	}    }  implementation_context = sav;}/* Create the declaration of _OBJC_SYMBOLS, with type `strict _objc_symtab'   and initialized appropriately.  */static voidgenerate_objc_symtab_decl (){  tree sc_spec;  if (!objc_category_template)    build_category_template ();  /* forward declare categories */  if (cat_count)    forward_declare_categories ();  if (!objc_symtab_template)    build_objc_symtab_template ();  sc_spec = build_tree_list (NULL_TREE, ridpointers[(int) RID_STATIC]);  UOBJC_SYMBOLS_decl = start_decl (get_identifier ("_OBJC_SYMBOLS"),				   tree_cons (NULL_TREE,					      objc_symtab_template, sc_spec),				   1,				   NULL_TREE, NULL_TREE);  TREE_USED (UOBJC_SYMBOLS_decl) = 1;  DECL_IGNORED_P (UOBJC_SYMBOLS_decl) = 1;  DECL_ARTIFICIAL (UOBJC_SYMBOLS_decl) = 1;  finish_decl (UOBJC_SYMBOLS_decl,	       init_objc_symtab (TREE_TYPE (UOBJC_SYMBOLS_decl)),	       NULL_TREE);}static treeinit_module_descriptor (type)     tree type;{  tree initlist, expr;  /* version = { 1, ... } */  expr = build_int_2 (OBJC_VERSION, 0);  initlist = build_tree_list (NULL_TREE, expr);  /* size = { ..., sizeof (struct objc_module), ... } */  expr = size_in_bytes (objc_module_template);  initlist = tree_cons (NULL_TREE, expr, initlist);  /* name = { ..., "foo.m", ... } */  expr = add_objc_string (get_identifier (input_filename), class_names);  initlist = tree_cons (NULL_TREE, expr, initlist);  if (!flag_next_runtime)    {      /* statics = { ..., _OBJC_STATIC_INSTANCES, ... }  */      if (static_instances_decl)	expr = build_unary_op (ADDR_EXPR, static_instances_decl, 0);      else	expr = build_int_2 (0, 0);      initlist = tree_cons (NULL_TREE, expr, initlist);    }  /* symtab = { ..., _OBJC_SYMBOLS, ... } */  if (UOBJC_SYMBOLS_decl)    expr = build_unary_op (ADDR_EXPR, UOBJC_SYMBOLS_decl, 0);  else    expr = build_int_2 (0, 0);  initlist = tree_cons (NULL_TREE, expr, initlist);  return build_constructor (type, nreverse (initlist));}/* Write out the data structures to describe Objective C classes defined.   If appropriate, compile and output a setup function to initialize them.   Return a string which is the name of a function to call to initialize   the Objective C data structures for this file (and perhaps for other files   also).   struct objc_module { ... } _OBJC_MODULE = { ... };   */static char *build_module_descriptor (){  tree decl_specs, field_decl, field_decl_chain;  objc_module_template    = start_struct (RECORD_TYPE, get_identifier (UTAG_MODULE));  /* Long version; */  decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);  field_decl = get_identifier ("version");  field_decl    = grokfield (input_filename, lineno, field_decl, decl_specs, NULL_TREE);  field_decl_chain = field_decl;  /* long  size; */  decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_LONG]);  field_decl = get_identifier ("size");  field_decl    = grokfield (input_filename, lineno, field_decl, decl_specs, NULL_TREE);  chainon (field_decl_chain, field_decl);  /* char  *name; */  decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_CHAR]);  field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("name"));  field_decl    = grokfield (input_filename, lineno, field_decl, decl_specs, NULL_TREE);  chainon (field_decl_chain, field_decl);  if (!flag_next_runtime)    {      /* void *statics */      decl_specs = get_identifier (UTAG_STATICS);      decl_specs	= build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE, decl_specs));      field_decl	= build1 (INDIRECT_REF, NULL_TREE, get_identifier ("statics"));      field_decl = grokfield (input_filename, lineno, field_decl,			      decl_specs, NULL_TREE);      chainon (field_decl_chain, field_decl);    }  /* struct objc_symtab *symtab; */  decl_specs = get_identifier (UTAG_SYMTAB);  decl_specs = build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE, decl_specs));  field_decl = build1 (INDIRECT_REF, NULL_TREE, get_identifier ("symtab"));  field_decl    = grokfield (input_filename, lineno, field_decl, decl_specs, NULL_TREE);  chainon (field_decl_chain, field_decl);  finish_struct (objc_module_template, field_decl_chain, NULL_TREE);  /* Create an instance of "objc_module". */  decl_specs = tree_cons (NULL_TREE, objc_module_template,			  build_tree_list (NULL_TREE,					   ridpointers[(int) RID_STATIC]));  UOBJC_MODULES_decl = start_decl (get_identifier ("_OBJC_MODULES"),				   decl_specs, 1, NULL_TREE, NULL_TREE);  DECL_ARTIFICIAL (UOBJC_MODULES_decl) = 1;  DECL_IGNORED_P (UOBJC_MODULES_decl) = 1;  finish_decl (UOBJC_MODULES_decl,	       init_module_descriptor (TREE_TYPE (UOBJC_MODULES_decl)),	       NULL_TREE);  /* Mark the decl to avoid "defined but not used" warning. */  DECL_IN_SYSTEM_HEADER (UOBJC_MODULES_decl) = 1;  /* Generate a constructor call for the module descriptor.     This code was generated by reading the grammar rules     of c-parse.in;  Therefore, it may not be the most efficient     way of generating the requisite code. */  if (flag_next_runtime)    return 0;  {    tree parms, function_decl, decelerator, void_list_node;    tree function_type;    extern tree get_file_function_name ();    tree init_function_name = get_file_function_name ('I');    /* Declare void __objc_execClass (void*); */    void_list_node = build_tree_list (NULL_TREE, void_type_node);    function_type      = build_function_type (void_type_node,			     tree_cons (NULL_TREE, ptr_type_node,					void_list_node));    function_decl = build_decl (FUNCTION_DECL,				get_identifier (TAG_EXECCLASS),				function_type);    DECL_EXTERNAL (function_decl) = 1;    DECL_ARTIFICIAL (function_decl) = 1;    TREE_PUBLIC (function_decl) = 1;    pushdecl (function_decl);    rest_of_decl_compilation (function_decl, 0, 0, 0);    parms      = build_tree_list (NULL_TREE,			 build_unary_op (ADDR_EXPR, UOBJC_MODULES_decl, 0));    decelerator = build_function_call (function_decl, parms);    /* void _GLOBAL_$I$<gnyf> () {objc_execClass (&L_OBJC_MODULES);}  */    start_function (void_list_node,		    build_parse_node (CALL_EXPR, init_function_name,				      /* This has the format of the output					 of get_parm_info.  */				      tree_cons (NULL_TREE, NULL_TREE,						 void_list_node),				      NULL_TREE),		    NULL_TREE, NULL_TREE, 0);#if 0 /* This should be turned back on later	 for the systems where collect is not needed.  */    /* Make these functions nonglobal       so each file can use the same name.  */    TREE_PUBLIC (current_function_decl) = 0;#endif    TREE_USED (current_function_decl) = 1;    store_parm_decls ();    assemble_external (function_decl);    c_expand_expr_stmt (decelerator);    TREE_PUBLIC (current_function_decl) = 1;    function_decl = current_function_decl;    finish_function (0);    /* Return the name of the constructor function.  */    return XSTR (XEXP (DECL_RTL (function_decl), 0), 0);  }}/* extern const char _OBJC_STRINGS[]; */static voidgenerate_forward_declaration_to_string_table (){  tree sc_spec, decl_specs, expr_decl;  sc_spec = tree_cons (NULL_TREE, ridpointers[(int) RID_EXTERN], NULL_TREE);  decl_specs = tree_cons (NULL_TREE, ridpointers[(int) RID_CHAR], sc_spec);  expr_decl    = build_nt (ARRAY_REF, get_identifier ("_OBJC_STRINGS"), NULL_TREE);  UOBJC_STRINGS_decl = define_decl (expr_decl, decl_specs);}/* Return the DECL of the string IDENT in the SECTION.  */static treeget_objc_string_decl (ident, section)     tree ident;     enum string_section section;{  tree chain, decl;  if (section == class_names)    chain = class_names_chain;  else if (section == meth_var_names)    chain = meth_var_names_chain;  else if (section == meth_var_types)    chain = meth_var_types_chain;  for (; chain != 0; chain = TREE_VALUE (chain))    if (TREE_VALUE (chain) == ident)      return (TREE_PURPOSE (chain));  abort ();  return NULL_TREE;}/* Output references to all statically allocated objects.  Return the DECL   for the array built.  */static treegenerate_static_references (){  tree decls = NULL_TREE, ident, decl_spec, expr_decl, expr = NULL_TREE;  tree class_name, class, decl, instance, idecl, initlist;  tree cl_chain, in_chain, type;  int num_inst, num_class;  char buf[256];  if (flag_next_runtime)    abort ();  for (cl_chain = objc_static_instances, num_class = 0;       cl_chain; cl_chain = TREE_CHAIN (cl_chain), num_class++)    {      for (num_inst = 0, in_chain = TREE_PURPOSE (cl_chain);	   in_chain; num_inst++, in_chain = TREE_CHAIN (in_chain));      sprintf (buf, "_OBJC_STATIC_INSTANCES_%d", num_class);      ident = get_identifier (buf);      expr_decl = build_nt (ARRAY_REF, ident, NULL_TREE);      decl_spec = tree_cons (NULL_TREE, build_pointer_type (void_type_node),			     build_tree_list (NULL_TREE,					      ridpointers[(int) RID_STATIC]));      decl = start_decl (expr_decl, decl_spec, 1, NULL_TREE, NULL_TREE);      DECL_CONTEXT (decl) = 0;      DECL_ARTIFICIAL (decl) = 1;      /* Output {class_name, ...}.  */      class = TREE_VALUE (cl_chain);      class_name = get_objc_string_decl (TYPE_NAME (class), class_names);      initlist = build_tree_list (NULL_TREE,				  build_unary_op (ADDR_EXPR, class_name, 1));      /* Output {..., instance, ...}.  */      for (in_chain = TREE_PURPOSE (cl_chain);	   in_chain; in_chain = TREE_CHAIN (in_chain))	{	  expr = build_unary_op (ADDR_EXPR, TREE_VALUE (in_chain), 1);	  initlist = tree_cons (NULL_TREE, expr, initlist);	}      /* Output {..., NULL}.  */      initlist = tree_cons (NULL_TREE, build_int_2 (0, 0), initlist);      expr = build_constructor (TREE_TYPE (decl), nreverse (initlist));      finish_decl (decl, expr, NULL_TREE);      TREE_USED (decl) = 1;      type = build_array_type (build_pointer_type (void_type_node), 0);      decl = build_decl (VAR_DECL, ident, type);      make_decl_rtl (decl, 0, 1);      TREE_USED (decl) = 1;      decls	= tree_cons (NULL_TREE, build_unary_op (ADDR_EXPR, decl, 1), decls);    }  decls = tree_cons (NULL_TREE, build_int_2 (0, 0), decls);  ident = get_identifier ("_OBJC_STATIC_INSTANCES");  expr_decl = build_nt (ARRAY_REF, ident, NULL_TREE);  decl_spec = tree_cons (NULL_TREE, build_pointer_type (void_type_node),			 build_tree_list (NULL_TREE,					  ridpointers[(int) RID_STATIC]));  static_instances_decl    = start_decl (expr_decl, decl_spec, 1, NULL_TREE, NULL_TREE);  DECL_CONTEXT (static_instances_decl) = 0;  DECL_ARTIFICIAL (static_instances_decl) = 1;  end_temporary_allocation ();  expr = build_constructor (TREE_TYPE (static_instances_decl),			    nreverse (decls));  finish_decl (static_instances_decl, expr, NULL_TREE);}/* Output all strings. */static voidgenerate_strings (){  tree sc_spec, decl_specs, expr_decl;  tree chain, string_expr;  tree string, decl;  for (chain = class_names_chain; chain; chain = TREE_CHAIN (chain))    {      string = TREE_VALUE (chain);      decl = TREE_PURPOSE (chain);      sc_spec	= tree_cons (NULL_TREE, ridpointers[(int) RID_STATIC], NULL_TREE);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91在线精品一区二区| 日韩一级大片在线| 欧美精品三级日韩久久| 26uuuu精品一区二区| 亚洲在线中文字幕| 本田岬高潮一区二区三区| 日韩欧美一级二级三级| 亚洲一区免费观看| 成人aa视频在线观看| 久久综合九色综合97婷婷女人 | 欧美高清在线视频| 日韩一区欧美二区| 欧美色精品天天在线观看视频| 国产精品日日摸夜夜摸av| 国产在线不卡一区| 精品久久人人做人人爽| 奇米色777欧美一区二区| 欧美日韩免费观看一区三区| 亚洲欧美另类综合偷拍| a级精品国产片在线观看| 国产午夜精品理论片a级大结局 | 久久综合色鬼综合色| 日韩精品成人一区二区在线| 精品视频123区在线观看| 亚洲综合无码一区二区| 色婷婷激情久久| 亚洲欧美一区二区三区孕妇| 成人动漫在线一区| 国产精品你懂的| 99久久国产综合精品色伊| 中文天堂在线一区| 91在线看国产| 亚洲一区二区三区在线看| 欧美日韩综合色| 亚洲1区2区3区4区| 欧美一级高清片在线观看| 免费观看在线色综合| 精品国产髙清在线看国产毛片 | av不卡免费电影| 亚洲欧美另类久久久精品| 色屁屁一区二区| 亚洲电影激情视频网站| 91麻豆精品国产91久久久| 美国毛片一区二区| 国产色产综合色产在线视频| a在线欧美一区| 一级精品视频在线观看宜春院| 欧美性猛交xxxx黑人交 | 亚洲一区二区三区四区在线免费观看| 91浏览器打开| 天堂久久一区二区三区| 欧美mv日韩mv国产网站| 国产精品亚洲а∨天堂免在线| 国产精品欧美久久久久一区二区| 91亚洲精品乱码久久久久久蜜桃 | 亚洲美腿欧美偷拍| 欧美日韩国产一级片| 久久精品国产精品亚洲红杏| 久久久精品蜜桃| 91福利社在线观看| 久久99精品国产麻豆婷婷洗澡| 中文字幕国产精品一区二区| 在线视频中文字幕一区二区| 免播放器亚洲一区| 国产精品久久久久7777按摩| 欧美日韩免费在线视频| 国产精品99精品久久免费| 自拍av一区二区三区| 日韩精品中文字幕一区| 91日韩精品一区| 国模一区二区三区白浆| 亚洲六月丁香色婷婷综合久久| 精品久久五月天| 欧美网站一区二区| 成人福利视频在线| 久久99久久久久久久久久久| 亚洲激情在线激情| 国产婷婷色一区二区三区| 欧美日韩一区成人| 91视频在线看| 国产成人精品www牛牛影视| 日韩成人精品在线| 亚洲女同女同女同女同女同69| 精品第一国产综合精品aⅴ| 欧美三区在线观看| 成人动漫一区二区| 国产自产2019最新不卡| 日韩成人伦理电影在线观看| 亚洲激情一二三区| 国产精品久久国产精麻豆99网站| 欧美成人官网二区| 欧美日韩国产高清一区| 色88888久久久久久影院野外| 国产电影一区在线| 国内精品伊人久久久久av一坑| 日韩av中文字幕一区二区| 亚洲午夜一区二区| 亚洲品质自拍视频网站| 国产女人aaa级久久久级| 久久久久亚洲蜜桃| 久久综合九色欧美综合狠狠| 日韩欧美自拍偷拍| 91精品国产综合久久精品| 在线观看av一区二区| 色丁香久综合在线久综合在线观看| 成人av在线播放网址| 懂色中文一区二区在线播放| 国产成人免费在线观看不卡| 极品美女销魂一区二区三区| 精品无码三级在线观看视频| 精品在线播放免费| 九九热在线视频观看这里只有精品| 三级影片在线观看欧美日韩一区二区| 一区二区久久久久久| 亚洲资源中文字幕| 亚洲高清久久久| 日本欧美肥老太交大片| 蜜桃在线一区二区三区| 蜜臀久久99精品久久久画质超高清| 爽好多水快深点欧美视频| 热久久一区二区| 国产精品综合二区| 成人久久18免费网站麻豆| 91在线国产观看| 91福利在线播放| 日韩午夜激情免费电影| 久久久99精品免费观看不卡| 中文字幕欧美日韩一区| 国产午夜精品一区二区三区四区| 国产亚洲综合性久久久影院| 中文字幕av一区二区三区| 一区二区三区国产豹纹内裤在线| 日韩精品福利网| 国产精品99久久久久久久女警 | 日韩午夜在线观看视频| 久久久www免费人成精品| 国产精品欧美一区二区三区| 亚洲激情校园春色| 欧美a级理论片| 成人污视频在线观看| 欧美性猛片xxxx免费看久爱| 精品日韩一区二区三区| 国产精品久久久久久久久晋中 | 久久国产尿小便嘘嘘| 波多野结衣亚洲一区| 欧美日韩不卡视频| 久久久国产精品不卡| 亚洲美女偷拍久久| 狠狠色综合日日| 日本丶国产丶欧美色综合| 日韩一二三四区| 亚洲男同1069视频| 极品少妇xxxx精品少妇偷拍| 99久久99久久精品免费看蜜桃| 欧美日本一区二区| 国产精品区一区二区三区| 日韩高清国产一区在线| 不卡视频在线观看| 91麻豆精品国产无毒不卡在线观看| 国产精品毛片a∨一区二区三区| 亚洲国产欧美日韩另类综合| 国产精品一区二区男女羞羞无遮挡| 在线一区二区三区| 国产精品天美传媒沈樵| 蜜臀av性久久久久蜜臀av麻豆 | 精品电影一区二区三区| 一区二区三区不卡在线观看| 国产精品一级黄| 日韩精品一区国产麻豆| 亚洲福利视频导航| 99国产麻豆精品| 国产亚洲欧美日韩日本| 日韩电影免费在线| 欧洲精品在线观看| 亚洲婷婷综合色高清在线| 高清在线成人网| 欧美mv和日韩mv的网站| 亚洲高清不卡在线观看| 91亚洲永久精品| 中文字幕中文字幕一区二区| 国产一区二区网址| 精品国产欧美一区二区| 日韩国产精品久久久| 在线视频综合导航| 亚洲蜜臀av乱码久久精品蜜桃| 成人一二三区视频| 久久综合九色综合97婷婷女人| 免费在线观看精品| 欧美一级片免费看| 午夜国产不卡在线观看视频| 欧美在线色视频| 亚洲一区二区精品视频| 欧美影院精品一区| 亚洲一区在线观看免费观看电影高清| 色综合久久综合| 伊人性伊人情综合网| 欧美亚洲禁片免费| 亚洲va欧美va国产va天堂影院| 欧美在线短视频| 一区二区成人在线|