File.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <malloc.h>
  4. //для открытия файла + флаги для этого
  5. #include <sys/stat.h>
  6. #include <fcntl.h>
  7. //для чтения
  8. #include <unistd.h>
  9. //для exit
  10. #include <stdlib.h>
  11. #include "QuadEq.c"
  12. /*https://jakeroid.com/ru/blog/sistemnyie-vyizovyi-dlya-rabotyi-s-faylami-v-linux/ */
  13. QuadraticEquation* readInputFile(char* nameFile)
  14. {
  15. QuadraticEquation* equation = malloc(sizeof(QuadraticEquation));
  16. //открытие дескрипторп
  17. int fileHandle = open(nameFile, O_RDONLY, S_IRUSR | S_IROTH);
  18. if(fileHandle == -1)
  19. {
  20. printf("Файла с иходными данными не существует. Создайте файл %s \n", nameFile);
  21. exit(ERROR_OPEN_FILE);
  22. }
  23. //чтение файла
  24. char* buffer = malloc(BUFFER);
  25. //memset(buff, 0, 64); //Заполняю буфер нулями
  26. int countRead = 0;
  27. countRead = read(fileHandle, buffer, BUFFER);
  28. if (countRead == 0)
  29. {
  30. printf("Файла с иходными данными пуст.\n");
  31. exit(ERROR_INPUT_DATA);
  32. }
  33. //чтеные данных из файла
  34. int resultReadData = sscanf(buffer, "%lf %lf %lf", &equation->a, &equation->b, &equation->c);
  35. if (resultReadData == 0)
  36. {
  37. printf("Не удалось корректно прочитать файл.\n");
  38. exit(ERROR_READ_DATA);
  39. }
  40. if (equation->a == 0 && equation->b == 0 && equation->c == 0)
  41. {
  42. printf("Все коэфициенты равны 0. Проверьте исходный файл.\n");
  43. exit(ERROR_READ_DATA);
  44. }
  45. if (equation->a == 0)
  46. {
  47. printf("Коэффициент а равен 0. Это не квадратное уравнение.\n");
  48. exit(ERROR_READ_DATA);
  49. }
  50. close(fileHandle);
  51. return equation;
  52. }
  53. void writeOutputFile(QuadraticEquation equation, char* nameFile)
  54. {
  55. int fileHandle = open(nameFile, O_WRONLY | O_CREAT, S_IRWXO | S_IRWXU);
  56. if(fileHandle == -1)
  57. {
  58. printf("Что-то пошло не так при открытии файла.\n");
  59. exit(ERROR_OPEN_FILE);
  60. }
  61. char* stringIn[6];
  62. for (size_t i = 0; i < 6; i++)
  63. {
  64. stringIn[i] = calloc(BUFFER, 1);
  65. }
  66. stringIn[0] = "Это решение файлами в си.\n";
  67. sprintf(stringIn[1], "Уравнение: %.3lf * x^2 + (%.3lf) * x + (%.3lf) = 0\n", equation.a, equation.b, equation.c);
  68. sprintf(stringIn[2], "Дискриминант = %.3lf\n", equation.discriminant);
  69. char* result = calloc(2000, 1);
  70. if (equation.countRoot == 0)
  71. {
  72. sprintf(stringIn[3], "Корней нет.\n");
  73. sprintf(result, "%s%s%s%s", stringIn[0], stringIn[1], stringIn[2], stringIn[3]);
  74. //printf("%s", result);
  75. }
  76. else if (equation.countRoot == 1)
  77. {
  78. sprintf(stringIn[3], "Уравнение имеет одно решение:\n");
  79. sprintf(stringIn[4], "x = %.3lf\n", equation.x1);
  80. sprintf(result, "%s%s%s%s%s", stringIn[0], stringIn[1], stringIn[2], stringIn[3], stringIn[4]);
  81. //printf("%s", result);
  82. }
  83. else if (equation.countRoot == 2)
  84. {
  85. sprintf(stringIn[3], "Уравнение имеет два решения:\n");
  86. sprintf(stringIn[4], "x1 = %.3lf\n", equation.x1);
  87. sprintf(stringIn[5], "x2 = %.3lf\n", equation.x2);
  88. sprintf(result, "%s%s%s%s%s%s", stringIn[0], stringIn[1], stringIn[2], stringIn[3], stringIn[4], stringIn[5]);
  89. //printf("%s", result);
  90. }
  91. else
  92. {
  93. printf("Что-то пошло не так при решении уравнений.");
  94. exit(ERROR_WRITE_DATA);
  95. }
  96. /*Запись данных в файл.*/
  97. int resWrite = write(fileHandle, result, strlen(result));
  98. if (resWrite == -1)
  99. {
  100. printf("Ошибка записи файла.\n");
  101. exit(ERROR_WRITE_DATA);
  102. }
  103. close(fileHandle);
  104. //printf("Решение записано в файл %s\n", FILE_OUT);
  105. }
  106. int startWorkWithFile()
  107. {
  108. QuadraticEquation* equation = readInputFile(FILE_IN);
  109. solutionQuadraticEquation(equation);
  110. writeOutputFile(*equation, FILE_OUT);
  111. return 0;
  112. }