/* * Copyright (C) 2009 Rich Burridge * * 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. See http://www.gnu.org/copyleft/gpl.html the full text of the * license. */ #include #include #include #include #include #include #include "mp-equation.h" #include "mp-serializer.h" #define MAXLINE 1024 static MpSerializer *result_serializer; static void solve(const char *equation) { int ret; MPEquationOptions options; MPNumber z; gchar *result_str = NULL; memset(&options, 0, sizeof(options)); options.base = 10; options.wordlen = 32; options.angle_units = MP_DEGREES; ret = mp_equation_parse(equation, &options, &z, NULL); if (ret == PARSER_ERR_MP) fprintf(stderr, "Error %s\n", mp_get_error()); else if (ret) fprintf(stderr, "Error %d\n", ret); else { result_str = mp_serializer_to_string(result_serializer, &z); printf("%s\n", result_str); } g_free(result_str); } /* Adjust user input equation string before solving it. */ static void str_adjust(char *str) { int i, j = 0; str[strlen(str)-1] = '\0'; /* Remove newline at end of string. */ for (i = 0; str[i] != '\0'; i++) { /* Remove whitespace. */ if (str[i] != ' ' && str[i] != '\t') str[j++] = str[i]; } str[j] = '\0'; if (j > 0 && str[j-1] == '=') /* Remove trailing '=' (if present). */ str[j-1] = '\0'; } int main(int argc, char **argv) { char *equation, *line; size_t nbytes = MAXLINE; /* Seed random number generator. */ srand48((long) time((time_t *) 0)); setlocale(LC_ALL, ""); result_serializer = mp_serializer_new(MP_DISPLAY_FORMAT_AUTOMATIC, 10, 9); equation = (char *) malloc(MAXLINE * sizeof(char)); while (1) { printf("> "); line = fgets(equation, nbytes, stdin); if (line != NULL) str_adjust(equation); if (line == NULL || strcmp(equation, "exit") == 0 || strcmp(equation, "quit") == 0 || strlen(equation) == 0) break; solve(equation); } free(equation); return 0; }