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

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

?? objc-actions.c

?? 早期freebsd實現
?? C
?? 第 1 頁 / 共 5 頁
字號:
{  tree type = TREE_TYPE (decl);  static int alreadyWarned = 0;  if (TREE_CODE (type) == RECORD_TYPE && TREE_STATIC_TEMPLATE (type))    {      if (!alreadyWarned)	{	  error ("GNU compiler does not support statically allocated objects");	  alreadyWarned = 1;	}      error_with_decl (decl, "`%s' cannot be statically allocated");    }}/* implement static typing. at this point, we know we have an interface... */treeget_static_reference (interface)     tree interface;{  return xref_tag (RECORD_TYPE, CLASS_NAME (interface));}/* Create and push a decl for a built-in external variable or field NAME.   CODE says which.   TYPE is its data type.  */static treecreate_builtin_decl (code, type, name)     enum tree_code code;     tree type;     char *name;{  tree decl = build_decl (code, get_identifier (name), type);  if (code == VAR_DECL)    {      TREE_STATIC (decl) = 1;      make_decl_rtl (decl, 0, 1);      pushdecl (decl);    }  return decl;}/* *	purpose: "play" parser, creating/installing representations *		 of the declarations that are required by Objective-C. * *	model: * *		type_spec--------->sc_spec *		(tree_list)        (tree_list) *		    |                  | *		    |                  | *		identifier_node    identifier_node */static voidsynth_module_prologue (){  tree expr_decl, temp_type;  /* defined in `objc.h' */  objc_object_id = get_identifier (TAG_OBJECT);  objc_object_reference = xref_tag (RECORD_TYPE, objc_object_id);  id_type = build_pointer_type (objc_object_reference);  objc_class_id = get_identifier (TAG_CLASS);    class_type = build_pointer_type (xref_tag (RECORD_TYPE, objc_class_id));  /* Declare type of selector-objects that represent an operation name.  */#ifdef OBJC_INT_SELECTORS  /* `unsigned int' */  selector_type = unsigned_type_node;#else  /* `struct objc_selector *' */  selector_type    = build_pointer_type (xref_tag (RECORD_TYPE,				    get_identifier (TAG_SELECTOR)));#endif /* not OBJC_INT_SELECTORS */  /* struct objc_object *objc_msgSend (id, SEL, ...); */  temp_type    = build_function_type (id_type,			   tree_cons (NULL_TREE, id_type,				      tree_cons (NULLT, selector_type, NULLT)));  _msg_decl = builtin_function ("objc_msgSend", temp_type, NOT_BUILT_IN, 0);  /* struct objc_object *objc_msgSendSuper (void *, SEL, ...); */  temp_type    = build_function_type (id_type,			   tree_cons (NULL_TREE, ptr_type_node,				      tree_cons (NULLT, selector_type, NULLT)));  _msgSuper_decl = builtin_function ("objc_msgSendSuper",				     temp_type, NOT_BUILT_IN, 0);  /* id objc_getClass (); */    temp_type = build_function_type (id_type, NULLT);  objc_getClass_decl    = builtin_function ("objc_getClass", temp_type, NOT_BUILT_IN, 0);  /* id objc_getMetaClass (); */  objc_getMetaClass_decl    = builtin_function ("objc_getMetaClass", temp_type, NOT_BUILT_IN, 0);  /* extern SEL _OBJC_SELECTOR_REFERENCES[]; */#ifdef OBJC_SELECTORS_WITHOUT_LABELS  _OBJC_SELECTOR_REFERENCES_decl    = create_builtin_decl (VAR_DECL, build_array_type (selector_type, NULLT),			   "_OBJC_SELECTOR_REFERENCES");#endif}/* * custom "build_string ()" which sets TREE_TYPE! */static treemy_build_string (len, str)     int len;     char *str;{  int wide_flag = 0;  tree aString = build_string (len, str);  /*   *  some code from "combine_strings ()", which is local to c-parse.y.   */  if (TREE_TYPE (aString) == int_array_type_node)    wide_flag = 1;  TREE_TYPE (aString) =    build_array_type (wide_flag ? integer_type_node : char_type_node,		      build_index_type (build_int_2 (len - 1, 0)));  TREE_CONSTANT (aString) = 1;	/* puts string in the ".text" segment */  TREE_STATIC (aString) = 1;  return aString;}/* Take care of defining and initializing _OBJC_SYMBOLS.  *//* Predefine the following data type:	struct _objc_symtab {		long sel_ref_cnt;		SEL *refs;		short cls_def_cnt;		short cat_def_cnt;		void *defs[cls_def_cnt + cat_def_cnt];	}; */static voidbuild_objc_symtab_template (){  tree field_decl, field_decl_chain, index;  objc_symtab_template = start_struct (RECORD_TYPE, get_identifier (_TAG_SYMTAB));  /* long sel_ref_cnt; */  field_decl = create_builtin_decl (FIELD_DECL,				    long_integer_type_node,				    "sel_ref_cnt");  field_decl_chain = field_decl;  /* SEL *refs; */  field_decl = create_builtin_decl (FIELD_DECL,				    build_pointer_type (selector_type),				    "refs");  chainon (field_decl_chain, field_decl);  /* short cls_def_cnt; */  field_decl = create_builtin_decl (FIELD_DECL,				    short_integer_type_node,				    "cls_def_cnt");  chainon (field_decl_chain, field_decl);  /* short cat_def_cnt; */  field_decl = create_builtin_decl (FIELD_DECL,				    short_integer_type_node,				    "cat_def_cnt");  chainon (field_decl_chain, field_decl);  /* void *defs[cls_def_cnt + cat_def_cnt]; */  index = build_index_type (build_int_2 (imp_count + cat_count - 1, 0));  field_decl = create_builtin_decl (FIELD_DECL,				    build_array_type (ptr_type_node, index),				    "defs");  chainon (field_decl_chain, field_decl);  finish_struct (objc_symtab_template, field_decl_chain);}/* Create the initial value for the `defs' field of _objc_symtab.   This is a CONSTRUCTOR.  */static treeinit_def_list (){  tree expr, initlist = NULLT;  struct imp_entry *impent;  if (imp_count)    for (impent = imp_list; impent; impent = impent->next)      {	if (TREE_CODE (impent->imp_context) == IMPLEMENTATION_TYPE)	  {	    expr = build_unary_op (ADDR_EXPR, impent->class_decl, 0);	    initlist = tree_cons (NULLT, expr, initlist);	  }      }  if (cat_count)    for (impent = imp_list; impent; impent = impent->next)      {	if (TREE_CODE (impent->imp_context) == CATEGORY_TYPE)	  {	    expr = build_unary_op (ADDR_EXPR, impent->class_decl, 0);	    initlist = tree_cons (NULLT, expr, initlist);	  }      }  return build_nt (CONSTRUCTOR, NULLT, nreverse (initlist));}/* Construct the initial value for all of _objc_symtab.  */static treeinit_objc_symtab (){  tree initlist;  /* sel_ref_cnt = { ..., 5, ... } */  if (sel_ref_chain)    initlist = build_tree_list (NULLT, build_int_2 (max_selector_index, 0));  else    initlist = build_tree_list (NULLT, build_int_2 (0, 0));  /* refs = { ..., _OBJC_SELECTOR_REFERENCES, ... } */#ifndef OBJC_SELECTORS_WITHOUT_LABELS  initlist = tree_cons (NULLT, build_int_2 (0, 0), initlist);#else  if (sel_ref_chain)    initlist = tree_cons (NULLT, _OBJC_SELECTOR_REFERENCES_decl, initlist);  else    initlist = tree_cons (NULLT, build_int_2 (0, 0), initlist);#endif  /* cls_def_cnt = { ..., 5, ... } */  initlist = tree_cons (NULLT, build_int_2 (imp_count, 0), initlist);  /* cat_def_cnt = { ..., 5, ... } */  initlist = tree_cons (NULLT, build_int_2 (cat_count, 0), initlist);  /* cls_def = { ..., { &Foo, &Bar, ...}, ... } */  if (imp_count || cat_count)    initlist = tree_cons (NULLT, init_def_list (), initlist);  return build_nt (CONSTRUCTOR, NULLT, 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_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 = 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 (NULLT, ridpointers[(int) RID_STATIC]);  _OBJC_SYMBOLS_decl = start_decl (get_identifier ("_OBJC_SYMBOLS"),				   tree_cons (NULLT, objc_symtab_template, sc_spec), 1);  finish_decl (_OBJC_SYMBOLS_decl, init_objc_symtab (), NULLT);}/* *	tree_node------->tree_node----->... *          |                | *          | (value)        | (value) *          |                | *	  expr             expr */static treeinit_module_descriptor (){  tree initlist, expr;  /* version = { 1, ... } */  expr = build_int_2 (OBJC_VERSION, 0);  initlist = build_tree_list (NULLT, expr);  /* size = { ..., sizeof (struct objc_module), ... } */  expr = build_int_2 (TREE_INT_CST_LOW (TYPE_SIZE (objc_module_template)) /		      BITS_PER_UNIT, 0);  initlist = tree_cons (NULLT, expr, initlist);  /* name = { ..., "foo.m", ... } */  expr = build_msg_pool_reference (				   add_objc_string (get_identifier (input_filename)));  initlist = tree_cons (NULLT, expr, initlist);  /* symtab = { ..., _OBJC_SYMBOLS, ... } */  if (_OBJC_SYMBOLS_decl)    expr = build_unary_op (ADDR_EXPR, _OBJC_SYMBOLS_decl, 0);  else    expr = build_int_2 (0, 0);  initlist = tree_cons (NULLT, expr, initlist);  return build_nt (CONSTRUCTOR, NULLT, 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).  */static char *build_module_descriptor (){  tree decl_specs, field_decl, field_decl_chain;  objc_module_template = start_struct (RECORD_TYPE, get_identifier (_TAG_MODULE));  /* long version; */  decl_specs = build_tree_list (NULLT, ridpointers[(int) RID_LONG]);  field_decl = get_identifier ("version");  field_decl = grokfield (input_filename, lineno, field_decl, decl_specs, NULLT);  field_decl_chain = field_decl;  /* long  size; */  decl_specs = build_tree_list (NULLT, ridpointers[(int) RID_LONG]);  field_decl = get_identifier ("size");  field_decl = grokfield (input_filename, lineno, field_decl, decl_specs, NULLT);  chainon (field_decl_chain, field_decl);  /* char  *name; */  decl_specs = build_tree_list (NULLT, ridpointers[(int) RID_CHAR]);  field_decl = build1 (INDIRECT_REF, NULLT, get_identifier ("name"));  field_decl = grokfield (input_filename, lineno, field_decl, decl_specs, NULLT);  chainon (field_decl_chain, field_decl);  /* struct objc_symtab *symtab; */  decl_specs = get_identifier (_TAG_SYMTAB);  decl_specs = build_tree_list (NULLT, xref_tag (RECORD_TYPE, decl_specs));  field_decl = build1 (INDIRECT_REF, NULLT, get_identifier ("symtab"));  field_decl = grokfield (input_filename, lineno, field_decl, decl_specs, NULLT);  chainon (field_decl_chain, field_decl);  finish_struct (objc_module_template, field_decl_chain);  /* create an instance of "objc_module" */  decl_specs = tree_cons (NULLT, objc_module_template,			  build_tree_list (NULLT, ridpointers[(int) RID_STATIC]));  _OBJC_MODULES_decl = start_decl (get_identifier ("_OBJC_MODULES"),				   decl_specs, 1);  finish_decl (_OBJC_MODULES_decl, init_module_descriptor (), NULLT);  /* Mark the decl to avoid "defined but not used" warning. */  DECL_IN_SYSTEM_HEADER (_OBJC_MODULES_decl) = 1;  /* Generate a constructor call for the module descriptor.      This code was generated by reading the grammar rules     of c-parse.y;  Therefore, it may not be the most efficient     way of generating the requisite code. */#ifndef NEXT_OBJC_RUNTIME  {    tree parms, function_decl, decelerator, void_list_node;    tree function_type;    char *buf;    char *global_object_name = 0;    tree t;    /* Use a global object (which is already required to be unique over       the program) rather than the file name (which imposes extra       constraints).  -- Raeburn@MIT.EDU, 10 Jan 1990.  */    /* Find the name of some global object defined in this file.  */    for (t = getdecls (); t; t = TREE_CHAIN (t))      if (TREE_PUBLIC (t) && !DECL_EXTERNAL (t) && DECL_INITIAL (t) != 0)	{	  global_object_name = IDENTIFIER_POINTER (DECL_NAME (t));	  break;	}    /* If none, use the name of the file.  */    if (!global_object_name)      {	char *p, *q;	global_object_name	  = (char *) alloca (strlen (main_input_filename) + 1);	p = main_input_filename;	q = global_object_name;	/* Replace any weird characters in the file name.  */	for (; *p; p++)	  if (! ((*p >= '0' && *p <= '9')		 || (*p >= 'A' && *p <= 'Z')		 || (*p >= 'a' && *p <= 'z')))	    *q++ = '_';	  else	    *q++ = *p;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产偷国产偷精品高清尤物| 精品一区二区三区在线观看国产| 午夜国产不卡在线观看视频| 国产专区欧美精品| 欧美日韩国产精品自在自线| 欧美猛男男办公室激情| 日韩欧美电影在线| 亚洲一区二区三区四区不卡| 成人午夜视频在线观看| 欧美成人精品二区三区99精品| 亚洲黄色片在线观看| 成人激情动漫在线观看| 精品久久人人做人人爽| 天天操天天干天天综合网| 91免费看视频| 亚洲国产成人一区二区三区| 麻豆国产一区二区| 欧美日韩电影在线| 亚洲国产精品久久不卡毛片| 91网站视频在线观看| 国产精品色在线| 国产精品自拍毛片| 亚洲精品在线一区二区| 精品一区二区三区在线视频| 欧美一区二区三区在线观看视频| 亚洲亚洲精品在线观看| 色欧美日韩亚洲| 亚洲美女精品一区| 91蝌蚪国产九色| 亚洲美女在线一区| 91久久精品一区二区三区| 综合自拍亚洲综合图不卡区| 99精品一区二区| 亚洲欧美日韩在线| 色屁屁一区二区| 亚洲二区在线视频| 欧美猛男gaygay网站| 亚洲成人自拍一区| 制服丝袜亚洲色图| 激情综合色综合久久| 26uuu亚洲| 成人h精品动漫一区二区三区| 国产精品久久久久久久第一福利 | 亚洲精品久久嫩草网站秘色| 在线一区二区视频| 亚洲成人av一区| 欧美va亚洲va香蕉在线| 国产精品99久久久久久久vr| 国产欧美日韩一区二区三区在线观看| 春色校园综合激情亚洲| 亚洲天天做日日做天天谢日日欢| 91论坛在线播放| 日韩电影在线免费看| 日韩你懂的电影在线观看| 国产麻豆精品在线观看| 欧美国产日韩一二三区| 在线中文字幕不卡| 九九国产精品视频| 国产精品成人免费在线| 欧美日韩一区二区不卡| 麻豆国产精品视频| 国产精品福利一区二区| 欧美日韩久久久一区| 国产麻豆精品视频| 一区二区三区在线视频播放| 欧美一区二区免费| 不卡视频免费播放| 日日夜夜免费精品| 国产亚洲欧洲一区高清在线观看| 色综合亚洲欧洲| 久久电影国产免费久久电影| 亚洲欧洲精品天堂一级| 欧美一区二区大片| 99综合电影在线视频| 日韩av电影天堂| 中文字幕在线不卡一区二区三区| 欧美猛男男办公室激情| 成人99免费视频| 久久爱www久久做| 一区二区三区高清在线| 日本一区二区免费在线观看视频 | 欧美日韩免费视频| 高清beeg欧美| 男人的天堂亚洲一区| 亚洲视频狠狠干| 精品女同一区二区| 欧美伦理影视网| 在线免费观看日本一区| 国产精品911| 麻豆精品在线播放| 亚洲国产综合人成综合网站| 日本一区二区电影| 精品少妇一区二区三区在线播放| 一本高清dvd不卡在线观看| 国产露脸91国语对白| 免费精品视频最新在线| 亚洲国产日韩一区二区| 中文字幕一区二区三区四区不卡| 精品久久久三级丝袜| 欧美一级艳片视频免费观看| 欧美综合久久久| 色综合天天综合网国产成人综合天| 狠狠色丁香婷综合久久| 免费在线看成人av| 免费看黄色91| 麻豆国产91在线播放| 婷婷丁香久久五月婷婷| 亚洲成人高清在线| 午夜伊人狠狠久久| 天堂成人国产精品一区| 日韩精品欧美精品| 丝袜美腿一区二区三区| 五月综合激情婷婷六月色窝| 亚洲成人免费看| 日精品一区二区| 伦理电影国产精品| 国内精品伊人久久久久av一坑| 久久电影网站中文字幕 | www国产精品av| 日韩欧美高清在线| 久久精品夜色噜噜亚洲a∨| 久久精品一区蜜桃臀影院| 国产亚洲成aⅴ人片在线观看 | 精品乱码亚洲一区二区不卡| 欧美一级国产精品| 久久久蜜桃精品| 国产女人18毛片水真多成人如厕 | 91麻豆免费看片| 在线观看日韩精品| 欧美日韩不卡在线| 2024国产精品视频| 欧美—级在线免费片| 一区精品在线播放| 亚洲成人第一页| 国内久久精品视频| 不卡的av在线| 欧美三级在线视频| 欧美本精品男人aⅴ天堂| 国产亚洲欧美激情| 一区二区中文字幕在线| 五月天婷婷综合| 国内精品不卡在线| 在线精品视频小说1| 欧美一级在线免费| 中文字幕一区二区三区精华液| 一区二区三区四区激情| 日韩电影在线免费观看| 国产999精品久久| 欧美在线视频不卡| 一本大道久久a久久精品综合| 欧美在线视频日韩| 欧美国产精品一区二区三区| 亚洲裸体在线观看| 另类欧美日韩国产在线| 91网址在线看| 久久综合久久综合九色| 亚洲三级免费电影| 精品一区二区三区的国产在线播放| 丁香激情综合五月| 欧美高清性hdvideosex| 国产精品护士白丝一区av| 日韩va欧美va亚洲va久久| 成人成人成人在线视频| 日韩午夜激情视频| 一区二区三区精品视频在线| 激情小说欧美图片| 欧美猛男gaygay网站| 欧美国产激情二区三区| 久久成人免费电影| 欧美亚洲丝袜传媒另类| 亚洲国产精品v| 久久精品国产99国产| 欧美三级韩国三级日本一级| 国产精品初高中害羞小美女文| 久久国产精品无码网站| 欧美另类一区二区三区| 一区二区三区91| 99视频精品全部免费在线| 久久久久久久国产精品影院| 丝袜亚洲另类欧美综合| 精品视频免费在线| 亚洲乱码精品一二三四区日韩在线| 国产福利不卡视频| 欧美电视剧在线看免费| 日韩主播视频在线| 欧美色图在线观看| 亚洲蜜桃精久久久久久久| av网站免费线看精品| 欧美激情在线免费观看| 国产成人自拍在线| 欧美va天堂va视频va在线| 免费成人结看片| 日韩一级在线观看| 日韩专区一卡二卡| 91精品视频网| 日本午夜一区二区| 日韩女同互慰一区二区| 久久精品99国产精品| 欧美一区二区三区男人的天堂| 日韩高清中文字幕一区|