Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 1 / 0
Регистрация: 28.11.2017
Сообщений: 53

Рефакторинг лексера

10.03.2018, 00:52. Показов 606. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть код лексического анализа вида:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
Thread.CurrentThread.CurrentCulture = CultureInfo.InvariantCulture;
 
            #region Constant Regex
 
            const string DigitPattern = @"\d*\.?\d+(?:[eE][\-+]?\d+)?";
            const string IdentifierPattern = @"[A-Za-z]+";
            const string OperationPattern = @"[+\-*\/\^\(\)\,\!]";
 
            #endregion
 
            #region Token Init 
 
            bool afterOperand = false;
            var tokens = Regex.Matches("12    - 9 * 23.55 - (cos(2 * pi ^ 2) ) - e * 1.233E+3",
                // string.Join("|", OperationPattern, IdentifierPattern, DigitPattern)
                $"({OperationPattern})|({IdentifierPattern})|({DigitPattern})",
                RegexOptions.Compiled | RegexOptions.IgnoreCase)
                .Cast<Match>()
                .Where(m => !string.IsNullOrEmpty(m.Value))
                .Select(m =>
                {
                    string t = m.Value.Trim();
                    LexemType l;
                    Match next = m.NextMatch();
    
                    if (Regex.IsMatch(t, DigitPattern)) // 12 + - - - 11
                    {
                        if (afterOperand)
                        {
                            t.Insert(0, "-");
                            afterOperand = false;
                        }
                        
                        return (t.StartsWith("0x")) ? new Lexem(LexemType.HexNumber, t, m.Index) 
                                : (t.StartsWith("0b")) ? new Lexem(LexemType.BinaryNumber, t, m.Index)
                                : new Lexem(LexemType.Number, t, m.Index);
                    }
                    else if (Regex.IsMatch(t, IdentifierPattern))
                        return (next.Value == "(") // next.Value.In("(", "[", "{")
                                ? new Lexem(LexemType.Function, t, m.Index)
                                : new Lexem(LexemType.Variable, t, m.Index);
                    else if (Regex.IsMatch(t, OperationPattern))
                        return new Lexem()
                        {
                            Type = LexemType.Operator,
                            Value = t,
                            Position = m.Index
                        };
                    else if (Regex.IsMatch(t, IdentifierPattern))
                    {
                        string nextValue = next.Value;
                        if (nextValue == "+" ||
                            nextValue == "-")
                        {
                            next.Result("");
                            afterOperand = true;
                        }
 
                        switch (t)
                        {
                            case "+":
                                if (nextValue == "-")
                                {
                                    l = LexemType.Minus;
                                    break;
                                }
                                l = LexemType.Plus;
                                break;
                            case "-":
                                if (nextValue == "-")
                                {
                                    l = LexemType.Plus;
                                    break;
                                }
                                l = LexemType.Minus;
                                break;
                            case "*":
                                l = LexemType.Star;
                                break;
                            case "/":
                                l = LexemType.Slash;
                                break;
                            case "**":
                                l = LexemType.StarStar;
                                break;
                            case "^":
                                l = LexemType.Pow;
                                break;
                            case "!":
                                l = LexemType.Exclamation;
                                break;
                            default:
                                l = LexemType.Comma;
                                break;
                        }
 
                        return new Lexem()
                        {
                            Type = l,
                            Value = t,
                            Position = m.Index
                        };
                    }
                    // если токен не определен, возвращаем пустой токен
                    
                    return new Lexem();
                })
                .OrderBy(l => l.Position)
                .ToList();
 
            #endregion
 
            foreach (Lexem token in tokens)
            {
                Console.WriteLine(token);
            }
собственно что тут можно упростить? Получилось оч нагроможденно нмвз

Добавлено через 5 минут
Забыл добавить
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
public enum LexemType
    {
        Variable,
        Function,
        Identifier,
        Number,
        HexNumber,
        BinaryNumber,
        OpenSub,
        CloseSub,
        Comma,
        Plus,
        Minus,
        Star,
        Slash,
        Pow,
        StarStar,
        Exclamation,
        None
    }
 
    public class Lexem
    {
        public LexemType Type { get; set; }
        public string Value { get; set; }
        public int Position { get; set; }
        public bool Empty => this.Type == LexemType.None;
 
        public Lexem()
        {
            Type = LexemType.None;
            Value = string.Empty;
            Position = -1;
        }
 
        public Lexem(LexemType type, string value, int position)
        {
            this.Type = type;
            this.Value = value;
            this.Position = position;
        }
 
        public override string ToString()
        {
            return $"{Type} : {Value,2} {Position,2}";
        }
    }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.03.2018, 00:52
Ответы с готовыми решениями:

Рефакторинг
собственно есть два(пока что) таких кусочка кода public class MainFormController { //... public bool ValidateParameterValue(string...

Рефакторинг кода
Подскажите пожалуйста сервисы для онлайн рефакторинга кода на c# и да вообще такие есть??

Рефакторинг кода и тестов
Привет. Помогите мне. Разработать необходимые интерфейсы, классы, модули без реализации Запустить разработанные тесты. Ни один тест...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.03.2018, 00:52
Помогаю со студенческими работами здесь

Рефакторинг большого количества ветвлений кода
Есть здоровый фрагмент кода, состоящий из одних ветвлений, анализируются разные поля иерархии объектов. Вопрос: как его лучше...

Рефакторинг кода функции с графикой
Здравствуйте, есть функция private void draw() { if (color2_bt0.IsChecked == true) { ...

Рефакторинг кода
Вообщем изучаю в C# методы и массивы (практикуюсь). Программировать, то есть писать программный код правильно толком не умею, не знаю как...

Рефакторинг кода
Всем известно, что методы должны содержать 5-7 операторов, лучше 3. Но если я в методе обрабатываю исключения и их много (5 к примеру), то...

Рефакторинг кода
Здравствуйте, есть функция private void draw() { if (color2_bt0.IsChecked == true) { drawingBrush = Brushes.Black; ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru