⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mix_eval.c

📁 汇编语言编程源代码
💻 C
字号:
/* -*-c-*- -------------- mix_eval.c : * Implementation of the functions declared in mix_eval.h * ------------------------------------------------------------------ *  Last change: Time-stamp: "01/02/20 00:23:58 jose" * ------------------------------------------------------------------ * Copyright (C) 2000 Free Software Foundation, Inc. *   * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. *   * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. *   * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *   */#include "xmix_eval.h"static const gchar *errors_[] = {  N_("Successful evaluation"),  N_("Syntax error in expression"),  N_("Out of range F-specification"),  N_("Mismatched parenthesis"),  N_("Undefined symbol"),  N_("Internal error")};/* create a new evaluator */mix_eval_t *mix_eval_new (void) {  mix_eval_t *result = g_new (mix_eval_t, 1);  result->table = mix_symbol_table_new ();  if (result->table == NULL) {    g_free (result);    return NULL;  }  result->towner = TRUE;  result->value = MIX_WORD_ZERO;  result->errpos = 0;  return result;}/* create a new evaluator with an external symbol table */mix_eval_t *mix_eval_new_with_table (mix_symbol_table_t *table){  mix_eval_t *result = g_new (mix_eval_t, 1);  result->table = table;  result->towner = FALSE;  result->value = MIX_WORD_ZERO;  result->errpos = 0;  return result;}/* delete */voidmix_eval_delete (mix_eval_t *eval){  g_return_if_fail (eval);  if (eval->table && eval->towner) {    mix_symbol_table_delete (eval->table);  }  g_free (eval);}/* eval an expression */mix_eval_result_tmix_eval_expression_with_loc (mix_eval_t *eval, const gchar *expr,			      mix_short_t loc){  mix_eval_data_ data;    if (expr == NULL || eval == NULL)    return MIX_EVAL_INTERN;  data.expr = g_strdup_printf ("%s\n", expr);  data.table = eval->table;  data.errpos = eval->errpos;  data.value = eval->value;  data.loc = loc;  eval->result = mix_eval_expr (&data);  if (eval->result == MIX_EVAL_OK) {    eval->value = data.value;    eval->errpos = -1;  } else {    eval->errpos = data.errpos;  }  g_free (data.expr);      return eval->result;}/* get the result of the last evaluation */mix_word_tmix_eval_value (const mix_eval_t *eval) {  g_return_val_if_fail (eval != NULL, MIX_WORD_ZERO);  return eval->value;}/* get the last eval result code */mix_eval_result_t mix_eval_last_error (const mix_eval_t *eval) {  g_return_val_if_fail (eval != NULL, MIX_EVAL_INTERN);  return eval->result;}/* get the last error string */const gchar*mix_eval_last_error_string (const mix_eval_t *eval) {  g_return_val_if_fail (eval != NULL, errors_[MIX_EVAL_INTERN]);  return errors_[eval->result];}/* get the position of last error */guintmix_eval_last_error_pos (const mix_eval_t *eval){  g_return_val_if_fail (eval != NULL, 0);  return eval->errpos;}/* add, or redefine, a symbol. see mix_symbol_table.h for   possible outcomes. */gintmix_eval_set_symbol (mix_eval_t *eval, const gchar *symbol,		     mix_word_t value){  g_return_val_if_fail (eval != NULL && eval->table != NULL,			MIX_SYM_FAIL);  return mix_symbol_table_insert (eval->table, symbol, value);}voidmix_eval_remove_symbol (mix_eval_t *eval, const gchar *symbol){  g_return_if_fail (eval != NULL && eval->table != NULL);  mix_symbol_table_remove (eval->table, symbol);}voidmix_eval_use_symbol_table (mix_eval_t *eval,			   mix_symbol_table_t *table){  g_return_if_fail (eval != NULL);  if (eval->table != NULL && eval->towner)    mix_symbol_table_delete (eval->table);  eval->table = table;  eval->towner = FALSE;}const mix_symbol_table_t *mix_eval_symbol_table (const mix_eval_t *eval){  g_return_val_if_fail (eval != NULL, NULL);  return eval->table;}gbooleanmix_eval_set_symbols_from_table (mix_eval_t *eval,				 const mix_symbol_table_t *table){  g_return_val_if_fail (eval != NULL, FALSE);  if (eval->table != NULL)    return mix_symbol_table_merge_table (eval->table, table);  else    return FALSE;}gbooleanmix_eval_remove_symbols_from_table (mix_eval_t *eval,				    const mix_symbol_table_t *table){  g_return_val_if_fail (eval != NULL, FALSE);  if (eval->table != NULL)    return mix_symbol_table_substract_table (eval->table, table);  else    return FALSE;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -