ДТ
Даниил ТетеринDec. 4, 2018, 1:42 a.m.

#define, редактирование текста

Qt, text

Приветствую. Учусь на первом курсе, и к сессии получил такое задание:
Необходимо сделать программу, которая открывает какие-либо .cpp файлы, ищет в них #define, в которых описаны некоторые константы (например k = 5), если находит, то далее программа проходится по всему коду, и заменяет встреченные константы k на число 5 (т.е. for (int i = 0; i < k; ++i) просто превратится в for (int i = 0; i < 5; ++i)). Собственно таким образом и работает сам #define, а мне необходимо повторить. Вот только проблема в том, что я совершенно не имею понятия, как это сделать. То есть, открыть файл и найти в нем эту константу я еще смогу, но каким образом потом заменять? Спасите

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

17
Ruslan Polupan
  • Dec. 4, 2018, 2:28 a.m.

Как вариант читаешь построчно и меняешь, записываешь в файл

    Evgenii Legotckoi
    • Dec. 4, 2018, 5:52 a.m.

    Добрый день!

    Можно считать файл, весь или построчно, как предложили выше, использовть регулярку и заменить с помощью неё интересующие места в тексте. А потом записать всё в новый файл.

    Например, так

    #include <QFile>
    #include <QRegularExpression>
    #include <QRegularExpressionMatch>
    #include <QRegularExpressionMatchIterator>
    #include <QTextStream>
    
    int main(int argc, char *argv[])
    {
        QFile data("D:/check.cpp");
        data.open(QIODevice::Text | QIODevice::ReadOnly);
        QString dataText = data.readAll();
    
        QRegularExpression re("k");
        QString replacementText("5");
    
        dataText.replace(re, replacementText);
    
        QFile newData("D:/new_check.cpp");
        if(newData.open(QFile::WriteOnly | QFile::Truncate)) {
            QTextStream out(&newData);
            out << dataText;
        }
        newData.close();
    
        return 0;
    }

      Taishel73
      • Dec. 4, 2018, 2:11 p.m.

      Доброго времени суток, Евгений! Думаю, что они на 1м курсе проходят visual studio. Наверняка код, написанный с помощью библиотек Qt ему не поможет. В ВУЗах,насколько мне известно, Qt изучают в разделе прикладного программирования.

        Evgenii Legotckoi
        • Dec. 4, 2018, 2:21 p.m.
        • (edited)

        Добрый день!

        Я бы с вами согласился, но человек задал вопрос в разделе Qt, а помимо этого ещё и тег Qt добавил, если с разделом можно ошибиться, то думаю, что с тегом уже вряд ли. Так что мой ответ в данном контексте вполне уместен должен быть.

          Taishel73
          • Dec. 4, 2018, 2:31 p.m.

          Упс, прошу прощения, перепутал разделы и на тег не глянул..))

            ДТ
            • Dec. 5, 2018, 1:48 a.m.
            • (edited)

            Ну, не знаю как у других, но у меня на первом курсе идет Qt, и вот такая вот ерунда

              Эх, если бы все было так просто. Штука же не в том, чтобы просто заменить текст, а заменить именно ту константу и только её. А в вашей реализации заменяются вообще любые символы 'k' на 5. В том и заключается сложность, чтобы каким-то образом отделить обычные буквы 'k', например, в названии функции, от нашей константы
                Evgenii Legotckoi
                • Dec. 5, 2018, 2:57 a.m.
                • (edited)

                Я полагал, что всё будет гораздо сложнее, но это уже будет зависеть от вашей конкретной реализации, конкретного кода, который нужно обработать, и сложности регулярного выражения, которое будете использовать. Для парсинга нет универсального решения в принципе. А что касается дефайнов, то они хотя бы стандартизированы в рамках языка программирования, поэтому парсер линковщика с ними справляется, а что касается констант, то тут уж вам нужно будет продумывать отдельные случаи, или отталкиваться от синтаксиса и конструкций языка. По сути нужно написать синтаксический анализ, как в IDE. Увы, но здесь уложиться простым парсингом не выйдет, если только у вас нет ограниченного набора случаев, но просто константа k .... На простое задание в университете это не похоже, если нужно парсить константы, имя которых состоит из одной лишь буквы. Это курсовая?

                  Если бы курсовая. Нет, просто дело в том, что мой преподаватель очень меня любит, потому, собственно, первая же моя сессия переменилась с обычных ответов на вопросы с билетов на вот это..
                  А что всё-таки по теме можете сказать? Есть идеи? Я постараюсь сегодня узнать, на сколько строги условия (возможно, константа всегда будет описана на какой-нибудь 6 строке, или типа того)

                    Если по теме, то по максимуму уточняйте информацию о задании. Честно, найти букву и заменить - это значит тыкаться в эту букву везде и проверять не является ли она частью имени атрибута, класса или ещё неизвестно чего.

                    Уточните важный момент. Из того кода, что вы привели, я вижу, что k и kkk объявлены в define, если нужно искать именно текстовые значения, которые объявлены в данных секциях, то задача сужается. Возможно, хватит анализа дефайнов и попытке нахождения совпадений.

                    Тогда задача будет состоять из нескольких шагов.

                    1. Анализ дефайнов
                    2. Постороения списка на замену
                    3. Анализ cpp файла и замена - это самое сложное. Нужно будет проверять всё построчно и каким-то образом понять, что это именно подставленный дефайн, а не часть текста и т.д.

                    Спросите преподавателя, обрисуйте ему эти шаги, как вы это "понимаете" и возможно он даст вам дополнительную информацию и кое-какие подсказки.



                      Да, точно. вы уточняли про дефайны в вопросе, я не обратил внимания. Ну сути это не меняет. Обрисуйте шаги преподавателю, уточните, правильно ли вы поняли задание в соответсвии с шагами, которы я вам написал. Уточните, достаточно ли будет использовать для этого регулярные выражения.

                        Главное, чтобы ваш преподаватель также не был пользователем этого сайта :D

                        А то влетит вам потом )) Как никак это практически единственный достаточно активный и живой русскоязычный ресурс по Qt

                          Собственно, ничего нового он не сказал. Define могут находиться в любом месте, задание я понял правильно, из подсказок никаких нормальных не дал, только то, о чем я думал и сам - проверять, чтобы символы слева и справа входили в перечень допустимых (типа скобки, знаки равенства\неравенства, и все такое).

                            Ну смотрите, первый шаг - это считать дефайны.

                            Считать нужно будет построчно, сделать это можно так, если это файл.

                            QFile inputFile(fileName);
                            if (inputFile.open(QIODevice::ReadOnly))
                            {
                               QTextStream in(&inputFile);
                               while (!in.atEnd())
                               {
                                  QString line = in.readLine();
                                  ...
                               }
                               inputFile.close();
                            }


                            Если это QTextEdit или QPlainTextEdt, то можно считать всё и разбить на строки

                            QString plainTextEditContents = ui->plainTextEdit->toPlainText()
                            QStringList lines = plainTextEditContents.split("\n");

                            Дальше регуляркой проходитесь по каждой строке и ищите там этот самый дефайн, выбираете его значение и сохраняете в какой-нибудь QVector<QString>, это будет пул дефайнов на замену.

                            А вторым шагом с помощью регулярок, как я изначально написал пробуете заменить всё в тексте с учётом допустимых символов. Попробуйте сами написать соответствующие регулярные выражения.


                              ДТ
                              • Dec. 8, 2018, 2:16 a.m.

                              Ну. Часть работы сделано. Меня почти похвалили. Главная проблема - что он не читает макросы. То есть, если будет запись вида #define max(x,y) (x>y)?x:y , то при встрече в коде участка типа max(a,2444), оно должно заменить (a>2444)?a:2444. А как - не понятно. Ну и еще я не могу сделать замену дефайна по строкам, то есть оно меняет сразу через весь текст, а если делать через QStringList - почему-то умирает

                                Ruslan Polupan
                                • Dec. 8, 2018, 2:42 a.m.

                                Имхо. надо искать исходник компилятора и брать код оттуда :-)

                                  ДТ
                                  • Dec. 8, 2018, 5:51 a.m.

                                  Но если серьезно, то действительно помощь нужна. Мне по-хорошему нужно сдать это в понедельник

                                    Comments

                                    Only authorized users can post comments.
                                    Please, Log in or Sign up
                                    AD

                                    C ++ - Test 004. Pointers, Arrays and Loops

                                    • Result:50points,
                                    • Rating points-4
                                    m

                                    C ++ - Test 004. Pointers, Arrays and Loops

                                    • Result:80points,
                                    • Rating points4
                                    m

                                    C ++ - Test 004. Pointers, Arrays and Loops

                                    • Result:20points,
                                    • Rating points-10
                                    Last comments
                                    i
                                    innorwallNov. 15, 2024, 3:27 p.m.
                                    Release of C++/Qt and QML application deployment utility CQtDeployer v1.4.0 (Binary Box) optionally substituted alkoxy, optionally substituted alkenyloxy, optionally substituted alkynyloxy, optionally substituted aryloxy, OCH, OC H, OC H, OC H, OC H, OC H, OC H, O C CH, OCH CH OH, O…
                                    i
                                    innorwallNov. 15, 2024, 10:26 a.m.
                                    Qt/C++ - Lesson 031. QCustomPlot – The build of charts with time buy generic priligy We can just chat, and we will not lose too much time anyway
                                    i
                                    innorwallNov. 15, 2024, 8:03 a.m.
                                    Qt/C++ - Lesson 060. Configuring the appearance of the application in runtime I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                                    i
                                    innorwallNov. 15, 2024, 1:07 a.m.
                                    Circuit switching and packet data transmission networks Angioedema 1 priligy dapoxetine
                                    i
                                    innorwallNov. 15, 2024, 12:42 a.m.
                                    How to Copy Files in Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                                    Now discuss on the forum
                                    i
                                    innorwallNov. 14, 2024, 4:39 p.m.
                                    добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                                    i
                                    innorwallNov. 11, 2024, 11:55 p.m.
                                    Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                                    9
                                    9AnonimOct. 25, 2024, 9:10 p.m.
                                    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                                    Follow us in social networks