Feature #3121
closed
Нужно проверять имена атрибутов на соответствие правилам JavaScript
Added by Viktoria Kopach over 12 years ago.
Updated almost 12 years ago.
Published in build:
0.14.173
Description
Нужен чекер, который не даст создать атрибут с некорректным именем (или изменить имя на некорректное). В окне создания/изменения атрибута должен появляться красный "флажок" с соответствующими пояснениями. И кнопка ОК должна становиться неактивной до тех пор, пока не будет введено корректное имя.
На данный момент обрабатываются не все возможные ситуации.
По правилам JavaScript
1. длина идентификатора - не меньше 1 символа (но у нас это уже проверяется в окне создания/изменения атрибута).
2. первый символ: буква, '_' или '$'.
3. в знаках, кроме первого, допустимы: буквы, цифры, знаки '_' и '$'.
4. Вообще запрещены: пробелы и спец. символы, отличные от '_' и '$'.
- Subject changed from Нужен чекер для проверки имен атрибутов на соответствие правилам JavaScript to Нужен проверять имена атрибутов на соответствие правилам JavaScript
- Description updated (diff)
- Assignee set to Alexey Khoroshilov
Нужно еще как-то обрабатывать ситуацию, в которой json меняется вручную. Там тоже могут указать некорректное имя атрибута. Чекер?
- Target version set to 0.14
- Subject changed from Нужен проверять имена атрибутов на соответствие правилам JavaScript to Нужно проверять имена атрибутов на соответствие правилам JavaScript
- Assignee changed from Alexey Khoroshilov to Denis Kildishev
- Status changed from New to Resolved
- % Done changed from 0 to 100
Applied in changeset r3071.
- Status changed from Resolved to Open
- Published in build deleted (
0.13.158)
Более адекватный паттерн для регулярных выражений:
static final Pattern valid_inner_name_pattern = Pattern.compile("[A-Za-z0-9а-яА-Я_[$]]+");
static final Pattern valid_name_pattern = Pattern.compile("[A-Za-z0-9а-яА-Я]+[A-Za-z0-9а-яА-Я_[$]]*");
return inner ? valid_inner_name_pattern.matches(name) : valid_name_pattern.matches(name);
- Status changed from Open to Resolved
Applied in changeset r3072.
Работа с DOORS processor протестирована?
- Status changed from Resolved to Open
Для DOORS нужно менять предикаты
- Status changed from Open to Resolved
Applied in changeset r3077.
- Published in build set to 0.14.173
А символ "-", который минус, разрешен, получается?
Да, мы вроде как особых последствий этого не вспомнили. Или что-то забыли?
- Status changed from Resolved to Verified
- Status changed from Verified to Closed
Also available in: Atom
PDF