Автоматизация от А до Я. Практика применения языка ДРАКОН

19.04.16

Разработка - Математика и алгоритмы

Я хочу вам показать практическую методику работы с языком ДРАКОН, пришедшим из космической отрасли. Его название расшифровывается как «дружелюбный российский алгоритмический язык, который обеспечивает наглядность». Этот язык придумали в 1986 году в рамках космической программы «Буран». В 1996 году язык ДРАКОН приобрел законченную форму, и с тех пор это – стандарт ФГУП «НПЦАП» им. академика Н. А. Пилюгина, где разрабатывают различные ракетные системы – ракеты - носители «Ангара», разгонные блоки для «Фрегата» и пр.

Основные плюсы языка ДРАКОН для компании

Язык ДРАКОН используется для:

  • описания бизнес-процессов компании и их аудит,
  • разработки решений на базе 1С для их автоматизации,
  • хранение кода этих решений,
  • организация обучения сотрудников работе в рамках бизнес – процессов,
  • запись и хранение инструкций пользователей – как работать в рамках бизнес - процесса.

Его основная изюминка в том, что в результате мы получаем полную бизнес-модель, которая не ограничивается только схемой и инструкцией для пользователя. В рамках этой бизнес-модели мы вместе с логикой разработки можем хранить и ее код – это дает нам возможность:

  • проводить его аудит,
  • вспомнить самому – что делали,
  • передать другой команде программистов,
  • обучать и поддерживать персонал Заказчика.

Чем язык ДРАКОН для описания бизнес-процесса лучше, нежели другие нотации?

  • Он понятный – легко воспринимается визуально на практике.
  • Он простой – там только три вида схем и около пяти реально используемых значков, которые позволяют описывать всю эту логику, не плодя очередные диаграммы.
  • Ну и плюс ко всему – другие нотации не имеют средств, которые могут хранить код разработки.

И сегодня мы поговорим про технологию применения языка ДРАКОН при внедрении и последующей эксплуатации продуктов 1С на конкретном примере.

Теоретическая основа построения бизнес-модели

При подготовке к презентации я связывался с людьми, которые профессионально занимаются разработкой бизнес-моделей, в частности, с Кузнецовым Михаилом Анатольевичем. Он ведет проектную разработку в ARIS (это нотация, которая используется в основном при внедрении системы SAP).

Согласно его наработкам, бизнес-модель состоит из следующих компонентов:

  • Смысловой уровень, который показывает цели и задачи компании.
  • Эти цели спускаются вниз в виде управляющих документов, которые характеризуют процессы (этот блок обозначен здесь как «Модель процессов»).
  • В этих процессах задействованы объекты бизнеса (иными словами, ресурсы);
  • И все это сходится в отчеты (квартальные или за другой какой-то период), по которым топ-менеджмент понимает, достигли они каких-то своих поставленных целей или нет (здесь этот блок обозначен как «Панель управления»)

Такое представление бизнес-модели используется в основном для внедрения систем KPI, но также может использоваться и для других целей – в системах менеджмента качества и пр.

Пример использования ИС Дракон для выбора решения по автоматизации бизнес-процессов заказчика

Давайте перейдем от теории к практике. Для примера я взял рабочий проект автоматизации мебельной фабрики у нас в городе. В проекте участвует две стороны – Заказчик и Исполнитель. Заказчик – это владелец мебельной фабрики, а Исполнитель – это я. Мы с Заказчиком встретились и обсудили его задачи. В результате я составил «Дракон-схему» его модели бизнеса.

Посмотрим, что получилось.

Слева обозначена так называемая схема «Гном» (такой тип схем используется в основном для заметок), в которой описан каталог целей компании:

  • Самый первый элемент на ней - это заголовок схемы.
  • Далее, желтым цветом выделена миссия компании на рынке.
  • А еще ниже находится элемент типа «Вставка», по которому происходит навигация по этим схемам.

Все это работает в среде ИС Дракон, автор живет в г. Северодвинске, – Тышов Геннадий Николаевич.

Сами схемы интерактивны: например, на элементе типа «Вставка» вы можете нажать стрелку «влево» и сразу попадаете на нужную схему. Так происходит декомпозиция. Это позволяет сложную логику разложить на более простые блоки.

Из каталога целей мы переходим к схеме типа «Силуэт», в которой записаны цели компании (тип схем «Силуэт» применяется для алгоритмов, состоящих из нескольких смысловых частей). Каждый заголовок (они выделены в красный овал) обозначает цепочку понятных для пользователя действий, которые расшифровываются в этой ветке.

Для каждой Цели Заказчика разрабатывается Концепция - укрупненный бизнес-процесс, который позволяет достичь этой Цели так, как это видится руководству. В первой ветке этой схемы мы будем работать с Целью, которая пытается усилить Вертикальную интеграцию: по схеме «Вставка» мы переходим к схеме Концепции вертикальной интеграции – нашему укрупненному плану, по достижению этой Цели.

На схеме Концепции вертикальной интеграции в виде конструкции «Цикл ДЛЯ» показан Жизненный цикл продаж (начало цикла – икона №5 и конец – икона №7).

  • Обратите внимание, что на этой схеме есть не закрашенные области – элементы типа «Вывод» (они находятся между действиями, закрашенными зеленым цветом) – это управляющие документы, которые спускаются вниз (например, для отдела продаж это может быть план продаж на год, и т.д.).
  • Соответственно, следующий за ним процесс руководствуется этим управляющим документом и т.д.
  • Желтым цветом здесь обозначен наиболее важный этап цикла продаж – это так называемый «драйвер», основная задача, которую двигают все остальные задачи. Через эту «вставку» мы можем перейти на отдельную схему, детализирующую эту задачу-драйвер жизненный цикл производства мебели.

Итак, здесь показана схема жизненного цикла производства мебели:

  • Сначала вы приходите в мебельный салон и заказываете кухню.
  • Там вам ее обсчитывают,
  • Потом изготавливают,
  • Привозят к вам,
  • Вы расплачиваетесь,
  • Подписываете акт о принятых работах (согласны вы или нет), и всё.

Описав основной бизнес-процесс, который хочет автоматизировать заказчик, мы можем приступить к выбору подходящей конфигурации – той, у которой есть максимальный функционал, отвечающий нашим требованиям. Желательно, чтобы ее не нужно было дорабатывать – изменения могут быть, но они должны быть минимальными.

Как видите, при начале работы над проектом, язык ДРАКОН позволяет вам получить представление о бизнес-модели Заказчика, чтобы оптимально выбрать коробочный продукт для комплексного решения его задач, хотя мебель вы до этого не продавали и не собирали.

Подведем итог первых этапов нашего проекта-примера:

  • Мы обсуждаем бизнес-процесс напрямую с Заказчиком (не программистом, не внедренцем) – он лучше знает, как у него продается и собирается мебель. И получаем информацию – что из себя представляет его бизнес.
  • А потом, составив на основании его информации детализированную схему, уже легко проанализировать, что мы можем автоматизировать, а что нет.
  • И на основании этого мы вместе выбираем коробочное решение для проекта.

Соответственно, язык ДРАКОН нужен на старте любого проекта внедрения программных продуктов компании 1С.

Пример использования ИС Дракон для поддержки и обновления  программных продуктов на базе 1С

Какие преимущества в использовании языка ДРАКОН на этапе владения информационной системы на базе 1С, при ее обновлении и доработке?

  • Если мы имеем бизнес-модель, мы можем её менять и развивать дальше.
  • Уменьшается зависимость от персонала. Потому, что если от нас внезапно уходит человек и не успевает передать дела, мы можем взять «Дракон-схему» его действий и передать ее новому сотруднику, чтобы он с ней поработал и выучил. После этого человек готов встать в наши стройные ряды и дальше работает.
  •  «Дракон-схемы» позволяют описывать «реальные» технические задания, когда бухгалтеры уже обсудили, что им нужно, и сами составили для программиста окончательную схему: «мы хотим, чтобы делалось вот так вот».
  • Плюс ко всему, так как схема хранит одновременно и код, и логику разработки, вы можете легко менять команды программистов, разработчиков – передавать им эти схемы.
  • А поскольку там уже есть готовый код и список метаданных, которые были созданы для этой доработки, то на дальнейшие обновления вы тратите уже в разы меньше времени.

Давайте подробнее разберем тему обновления конфигурации 1С.

Представьте себе, вы поставили типовую конфигурацию, внесли в нее какие-то доработки по техническому заданию, а потом прошло обновление, и часть ваших доработок стерлась. Такое бывает, если в фирме, допустим, нет своего программиста, или он заболел, уволился. Приходится поднимать старый бэкап, смотреть, что он изменял в метаданных, восстанавливать эти изменения и т.д. Хорошо еще, если данные не есть.

Для упрощения обновления своих доработок я обычно составляю «Дракон-схему», например, такую, как показана на слайде. Здесь есть специальные переходы (элементы типа «Вставка»), которые интерактивно переносят меня на листы разработок. Они представляют собой дракон-схемы, где описаны:

  • метаданные, которые создавались; 
  • логика разработки – для чего они создавались;
  • и код который там выполняется.

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

Пример использования ИС Дракон в процессе разработки

Переходим к третьей части. Зачем нужен язык ДРАКОН в процессе разработки?

  • Я могу видеть логику создаваемого кода и проводить его аудит. С помощью «Дракон-схем» мы можем понять, что работает, а что нет, увидеть, что где-то надо убрать лишний код и т.д.
  • Про смысловую передачу другой команде разработчиков я уже упоминал – зависимость от программистов уменьшается.

Чем составлять дракон-схем? Бумага, линейка, карандаш и ластик?

Схемы, которые я вам показывал, были сделаны в программе «ИС Дракон». Это, на мой взгляд, сейчас самый продвинутый инструмент для работы с этим языком. Простой и дешевый.

Еще есть «DRAKON Editor» и «Фабула».

Как дракон-схема хранит код и как использовать его при программировании в 1С.

Транслятор кода из ИС Дракон в Конфигуратор 1С использует метод программирования по GOTO. Не буду вдаваться в дискуссии по поводу правильно его использовать или нет. Статей в интернете на эту тему достаточно. Остановимся на том, что он есть. И вот как это работает.

Для наглядности немного расскажу о том, какие изменения мы вносили в программу 1С для Заказчика на примере оформления заказа производства мебели.

Как вы видите, в этой «Дракон-схеме» оформления заказа для каждого действия проставлены роли конкретных исполнителей. Например, указано, что первоначально заказ покупателя в конфигурацию УНФ вводит бухгалтер, а потом на основании этого заказа снабженец оформляет заказ на производство.

И тут в бизнес-процессе возникает «узкое место», я его выделил красным овалом. В чем суть? У заказчика в одной базе работает две разные фирмы, и материалы могут приходить на обе из них, а когда мы собираем кухню, нам нужно, чтобы эти материалы оказались на складе одной фирмы. Если это делать вручную, то кладовщик у нас должен сидеть, набивать расходы на недостающие материалы с одной фирмы на другую. Поэтому мы предложили заказчику сделать «волшебную кнопку», которая автоматизирует этот процесс.

На скриншоте показано техническое задание на разработку этой «волшебной кнопки»

Что она делает? Ищет недостающие товары фирмы-продавца, формирует на найденные позиции расходные и приходные документы. Дальше уже идет «вставка» для перехода на саму разработку с кодом.

Вот весь комплекс этих схем:

Каждая схема – это процедура или функция для модуля документа «Заказ поставщику». Именно они и автоматизируют эту «Волшебную кнопку».

Черные точки в заголовке схемы являются индикаторами того, что схема является процедурой и содержит код. В этих точках автоматически формируются заготовки, в которых описаны начало и конец процедуры (их текст показан на скриншоте внизу).

В «черных точках» конкретных действий пишется исполняемый код, в данном случае задаются параметры метаданных.

Так выглядит тип элемента «Цикл» (конструкции языка 1С «Для каждого … Цикл …»), зеленым цветом обозначены его границы (начало и конец). Между ними – исполняемый код для этого цикла.

А вот так выглядит тип элемента «Если». Вы здесь просто пишете условие: для «Да» такая ветка, для «Нет» – другая. А программа уже сама при генерации кода добавляет в модуль конструкцию «Если… Тогда» и метки, на которые происходит переход.

Для множественного «Если» используется другой тип элемента «Дракон-схемы»: «Переключатель».

В схеме мы также можем описывать изменения в метаданных. Например, на скриншоте слева, в схеме типа «Гном» указано, какие регистры сведений необходимо создать для работы этого функционала.

И, наконец, выделенный элемент – это результирующие доработки модуля. В его третьей «черной точке» я обычно пишу контактную информацию и суть разработки.

А четвертая «черная точка» – это уже сам итоговый код. Он собирается автоматически, и потом я его просто копирую из этого окна и вставляю в конфигуратор.

Как вы видите, сюда в виде комментариев также попадают и заметки, указывающие, в схеме под каким номером этот код находится.

Как производить отладку такого кода? У каждой схемы есть уникальный номер, который нигде не повторяется. Например, на скриншоте показано условие «Если» с номером 26.

И по комментариям в конфигураторе можно найти этот код. Как вы видите, здесь находится оператор «Перейти», который является аналогом GOTO в 1С. По нему производится переход на метку. Это не нужно писать вручную, все формируется автоматически.

Как вы видите, по метке 41 мы переходим на сообщение пользователю, которое возвращает текст ошибки, и после этого происходит конец процедуры. Так реализуется проверка логики разработки.

Работа с GOTO («Перейти» - в 1С) – это дело привычки. Мне нравится, потому что так нагляднее анализировать код в схеме после определенной практики.

 Если вам не хочется работать с GOTO – просто вставляйте текст условия в действия, и он сформирует код в процедуре так, как вы его там написали. 

Элементы схемы можно использовать просто как контейнеры для хранения текстовой информации кода.

Конечно, предварительную разработку я веду не в среде ИС Дракон, а в конфигураторе. У меня открыт конфигуратор, где я накидываю, например, логику запроса, который мне нужно разработать. Там доступен синтакс-помощник, автоподстановка кода, в пользовательском режиме можно запустить консоль запросов, все это протестировать, посмотреть, что у меня получается, какие параметры подставить. А после того, как у меня сформируются предварительные заготовки для каждого действия, я этот код из конфигуратора копирую и вставляю в нужные места схемы. Это особенно удобно делать, если вы работаете на двух экранах.

Программирование в ИС Дракон – как сбор паззла. В результате вы собираете всю мозаику, по которой видно код разработки целиком. Причем, код модуля, который автоматически получается на выходе, можно просто скопировать и поместить в конфигуратор. Протестировать, конечно, проверить, чтобы логика нигде не была нарушена.

Заключение

Язык ДРАКОН удобно использовать и для обучения персонала, и для общения с заказчиком, а также при разработке и поддержке конфигураций на 1С.

Что касается разработки, то работаю на многих проектах, где периодически приходится восстанавливать какой-то функционал, что-то доделывать, разбирать какие-то сложные чужие коды и т.д. И, сколько я работал, не встречал кода, написанного программистом, который я не смог бы описать на языке ДРАКОН.

ИС Дракон – это коробочный продукт с поддержкой разных языков. Я работаю с 1С, но там поддерживается также C++, язык микроконтроллеров, и некоторые другие языки. Сам продукт продается автором. Его полноценная версия весит очень мало и стоит недорогоЕсть бесплатная демо-версия, которая может использоваться как просмотровая.

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

 

************

Данная статья написана по итогам доклада, прочитанного на конференции INFOSTART EVENT 2015 CONNECTION 15-17 октября 2015 года

Приглашаем вас на новую конференцию INFOSTART EVENT 2019 INCEPTION.

См. также

Математика и алгоритмы Программист Платформа 1C v8.2 Конфигурации 1cv8 Россия Абонемент ($m)

На написание данной работы меня вдохновила работа @glassman «Переход на ClickHouse для анализа метрик». Автор анализирует большой объем данных, много миллионов строк, и убедительно доказывает, что ClickHouse справляется лучше PostgreSQL. Я же покажу как можно сократить объем данных в 49.9 раз при этом: 1. Сохранить значения локальных экстремумов 2. Отклонения от реальных значений имеют наперед заданную допустимую погрешность.

1 стартмани

30.01.2024    4621    stopa85    12    

39

Математика и алгоритмы Бесплатно (free)

Разработка алгоритма, построенного на модели симплекс-метода, для нахождения оптимального раскроя.

19.10.2023    9526    user1959478    52    

36

Математика и алгоритмы Разное Платформа 1С v8.3 Конфигурации 1cv8 Россия Абонемент ($m)

Расширение (+ обработка) представляют собою математический тренажер. Ваш ребенок сможет проверить свои знание на математические вычисление до 100.

2 стартмани

29.09.2023    4498    maksa2005    8    

26

Математика и алгоритмы Инструментарий разработчика Программист Платформа 1С v8.3 Мобильная платформа Россия Абонемент ($m)

Что ж... лучше поздно, чем никогда. Подсистема 1С для работы с регулярными выражениями: разбор выражения, проверка на соответствие шаблону, поиск вхождений в тексте.

1 стартмани

09.06.2023    12086    8    SpaceOfMyHead    19    

61

Математика и алгоритмы Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Три задачи - три идеи - три решения. Мало кода, много смысла. Мини-статья.

03.04.2023    5726    RustIG    9    

25

Механизмы платформы 1С Математика и алгоритмы Программист Платформа 1С v8.3 Россия Бесплатно (free)

В статье анализируются средства платформы для решения системы линейных уравнений в 1С. Приводятся доводы в пользу некорректной работы встроенных алгоритмов, а значит потенциально некорректного расчета себестоимости в типовых конфигурациях.

23.11.2022    4854    gzharkoj    14    

25

Математика и алгоритмы Программист Платформа 1С v8.3 Россия Абонемент ($m)

Обычно под распределением понимают определение сумм пропорционально коэффициентам. Предлагаю включить сюда также распределение по порядку (FIFO, LIFO) и повысить уровень размерности до 2-х. 1-ое означает, что распределение может быть не только пропорциональным, но и по порядку, а 2-ое - это вариант реализации матричного распределения: по строкам и столбцам. Возможно вас заинтересует также необычное решение этой задачи через создание DSL на базе реализации текучего интерфейса

1 стартмани

21.03.2022    9289    7    kalyaka    11    

44
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. AlexWhite 194 20.04.16 09:11 Сейчас в теме
Статья интересная, но остались вопросы.
1) Код пишется в конфигураторе, потом копированием переносится в схему. Какой в этом бизнес-смысл?
2) Произошло изменение в схеме, как оно отразится на изменении кода в конфигураторе?
3) Чем эти схемы лучше аналогичных многим известных диаграмм?
21. flex81 70 21.04.16 16:16 Сейчас в теме
(1) AlexWhite,
1) Код пишется в конфигураторе, потом копированием переносится в схему. Какой в этом бизнес-смысл?
Из практики: в конфигураторе я пишу куски и фрагменты, часто не связанные с собой. Например отлаживаю запросы и т.д.. В дракон-схеме, уже собираю их в нужный нам бизнес-функционал. :) В финале у меня код в конфигураторе и код в дракон-схеме идентичен.

2) Произошло изменение в схеме, как оно отразится на изменении кода в конфигураторе?
Никак, пока мы не скопируем весь текст целиком в модуль конфигуратора из схемы.
Прямой взаимосвязи нет между ИС Дракон и Конфигуратором.

3) Чем эти схемы лучше аналогичных многим известных диаграмм?
Дракон лучше воспринимается, меньше объектов, он генерит код для 1С - тоесть пригоден для программирования.

Конечно каждый сам выбирает для себя инструменты для решения поставленных задач. Я просто рассказал про свой. :)
29. AlexWhite 194 21.04.16 16:57 Сейчас в теме
(21)
В финале у меня код в конфигураторе и код в дракон-схеме идентичен.
- до момента, пока вы поменяете код в конфигураторе. При отсутствии связи с дракон-схемой вам надо постоянно помнить, поменяли код в конфигураторе - надо актуализировать код в дракон-схеме (и обратно). Думаю, это совершенно лишний процесс, добавленная сложность в виде нового инструмента в дополнение к конфигуратору ни как не влияющая на работоспособность и качество кода. Или у вас при моделировании создается действующий программный код, который остается скопировать в конфигуратор? Как в этом случае определить, в какое место в конфигураторе этот код вставить?

он генерит код для 1С - тоесть пригоден для программирования.
- а можно тут увидеть пример, какой код генерится и насколько он пригоден в конфигураторе?
30. flex81 70 21.04.16 17:00 Сейчас в теме
(29) AlexWhite,
да генериться код... :) Да вы код вставляите в конфигуратор.
31. flex81 70 21.04.16 17:01 Сейчас в теме
(29) AlexWhite,
Код представлен на слайде в моей статье и на презентации. Сообщите, я пришлю вам пример на почту. Сможем обсудить.
32. flex81 70 21.04.16 17:04 Сейчас в теме
(29) AlexWhite,

Место - куда код вставляется, я пишу в дракон-схеме, удобным для себя образом. И этот код вставляю туда.
2. vec435 17 20.04.16 09:37 Сейчас в теме
Даешь дракон-схема! Даешь импортозамещение IDEFаф, ARISам!
olegmedvedev; +1 Ответить
3. palsergeich 20.04.16 10:33 Сейчас в теме
На сколько я помню использование GoTo является моветоном. Слабо себе представляю поддержку модуля хотя бы на пару тысяч строк, который весь покрыт GoTO.
10. Геннадий Тышов 20.04.16 16:20 Сейчас в теме
(3) palsergeich, Вы сгущаете краски.
Модуль на 2 тысячи строк содержит несколько процедур и GoTo не связывают строки всего модуля, а распределены по процедурам.

"GoTo является моветоном" - устаревший миф для программистов, повод для религиозных войн, то чему Вас кое как учили.
Goto, это основа в любой программе, до ассемблера доводится программа при трансляции в машинный код.

Зададимся вопросом - что главное в программе? Главным является полный комментарий, программный код может содержать ошибки, но они исправляются при отладке, выявляются при эксплуатации. При отсутствии же полного комментария и при изменении требований к программе, программу придется выкинуть и писать вновь.

Программа, созданная в ИС Дракон, гарантированно содержит полный комментарий с описанием логики в терминах прикладной области. Программный код не является 2-я тысячами строк модуля, он разбит и привязан к иконе (элементу) блок схемы. Нет необходимости обозревать 2-е тысячи строк модуля, а достаточно видеть блок схему в целом и разбираться с описанием отдельной иконы и реализующим функциональность программным кодом размером в 1..5 строк.
InExSu; fzt; +2 4 Ответить
11. starik-2005 3097 20.04.16 21:19 Сейчас в теме
(10) dragonedit, оператор безусловного перехода имеет смысл только тогда, когда нет другого решения. Да, моветоном он не является, но если есть простое иное решение - то однозначно моветон. Я за 20 лет ни разу не употреблял оператор безусловного перехода. Даже на ассемблере пришлось его употреблять только при выходе из блока аля CASE. Если кто-то приведет пример, где данный оператор будет уместен - буду рад.
12. caponid 21.04.16 09:50 Сейчас в теме
(11) starik-2005,
Если кто-то приведет пример, где данный оператор будет уместен - буду рад

В тексте Выполнить() гораздо проще использовать оператор Перейти для перехода в конец блока, чем городить многоуровневые условия.
14. Геннадий Тышов 21.04.16 10:59 Сейчас в теме
(12) caponid, Отвлечемся от Дракона.
Строго структурированный текст смотрится, как лунная поверхность с глубокими кратерами. В нем уровень вложенности может быть большим, строка оператора "Если" оторвана от строки "КонецЕсли" так далеко, что надо прокручивать текст и связи между ними совсем не видно.
При ограниченном использовании операторов Перейти, Продолжить, Прервать, Возврат уровень вложенности в тексте значительно уменьшается. Смотрите http://forum.oberoncore.ru/viewtopic.php?p=35027#p35027.

Вернемся к Дракону.
Программист сам не пишет Goto. Он создает Дракон-схему (блок-схему) с иконами (элементами). Икона содержит несколько полей для различных комментариев и поле программного кода. Программный код модуля формируется путем сборки программного кода из икон и помещается программистом в конфигуратор. В программном коде уровень вложенности нет вложенности сведен до минимума.
15. cool.vlad4 2 21.04.16 11:03 Сейчас в теме
(14) dragonedit,
Программист сам не пишет Goto.
ага, Дракон прям вшит в платформу 1С и анализирует весь код, код управляемых форм, код событий, взаимосвязи модулей и т.п. код это не код в сферическом вакууме. обычную простыню кода без всяких сложных внешних взаимосвязей любой программист средней руки напишет и без Дракона.
16. Геннадий Тышов 21.04.16 11:36 Сейчас в теме
(15) cool.vlad4, Выбор и освоение инструмента зависит от Вас.
Если нет инструмента, то это самое простое решение,

ИС Дракон можно скачать - https://cloud.mail.ru/public/ecbde70c784a/%D0%98%D0%A1%20%D0%94%D1%80%D0%B0%D0%­BA%D0%BE%D0%BD
17. Геннадий Тышов 21.04.16 12:02 Сейчас в теме
(15) cool.vlad4,
Дракон ведь не только средство программирования. Это еще универсальное средство общения.

Если вы в Драконе напишите программу, то можете показать ее заказчику, пользователю или начальнику, которые не понимают язык программирования, но они поймут как Ваша программа работает, почему она такая, как ее пользоваться - они все это увидят в Ваших блок-схемах.
Как результат - к Вам не будет вопросов.

Потом заказчик, пользователь или начальник будут обращаться к Вам уже с готовой Дракон-схемой - сделай пожалуйста. Вы же просто в нее впишите программный код.
flex81; cool.vlad4; +2 Ответить
18. cool.vlad4 2 21.04.16 13:18 Сейчас в теме
(17) dragonedit, с этой точки зрения вполне, возможно, что подобный инструмент нужен. mindmap + код. с другой стороны в самой 1С можно сделать подобное, привязав к графической схеме возможность ввода кода в виде текста.
69. starik-2005 3097 23.04.16 10:53 Сейчас в теме
(12) caponid, не вижу примера. Вот есть, допустим, что-то типа: результат = запрос.выполнить(). Дальше у нас проверка результата на пустое место и тут, как я понял, Вы предлагаете какое-то "гоу ту" в конец обработки результата. Или я неверно Вас понял? Минус "гоу ту" тут очевиден - также нужно смотреть, где метка. Если она одна - полбеды, а если их понатыкано полным полно? С другой стороны, условия надо выделять отступами, тогда вложенность будет вполне обозначима и доступна для понимания. Более того, если в программе множественные ветвления, то, исходя из "тру" методологии (например, Макконнелл, "Совершенный код"), необходимо работать над структурой программы, выделяя часть кода в процедуры и функции. Т.е. понижать общую сложность кода. "Гоу ту" сложность кода не повышает, конечно, но из-за отсутствия отступов весьма проигрывает в читаемости перед if/while/for.
71. Геннадий Тышов 23.04.16 11:30 Сейчас в теме
(69) starik-2005,
Минус "гоу ту" тут очевиден - также нужно смотреть, где метка.
В программном коде, собранном в ИС Дракон, не нужно смотреть Goto и метки - смотрите Дракон-схемы.

необходимо работать над структурой программы, выделяя часть кода в процедуры и функции.
Так же поступайте и при использовании ИС Дракон.
13. cool.vlad4 2 21.04.16 10:50 Сейчас в теме
(10) dragonedit, goto однозначно моветон в языках высокого уровня(потому что это компьютеру начихать на эти goto, он миллион раз сделает goto и ничего ему не будет, а человек после 10 перехода при чтении программы ошизеет, особенно если код не он писал), поскольку убивает читаемость. сравнивать 1С и ассемблер, ну это круто, че. и это не его кое как учили(я бы как кстати не писал бы в подобном тоне , если бы не хамское "кое как учили"), это подобные комментарии (ниже), вызывают недоумение
Зададимся вопросом - что главное в программе? Главным является полный комментарий, программный код может содержать ошибки, но они исправляются при отладке, выявляются при эксплуатации. При отсутствии же полного комментария и при изменении требований к программе, программу придется выкинуть и писать вновь.

ну правильно. в программе важен не код, а всякая писанина, которая ни черта не выполняется и в итоге не влияет на программу вообще. код , конечно, может содержать ошибки, но комментарии они , конечно, безошибочны, они всегда сами по себе обновляются с изменением программы и вообще содержат в себе кучу полезной информации, как например как зовут программиста, что он сегодня ел и куда ходил. а код бесполезная фигня, зачем читать код. что еще за чушь.
vano-ekt; itriot11; Ta_Da; premierex; +4 Ответить
23. flex81 70 21.04.16 16:29 Сейчас в теме
(13) cool.vlad4,

Читать код без его дракон-схемы сложно но можно. Но обычно, все дракон-схемы есть. В дракон-схемах GoTo нету - и понимание кода повышается в разы. :)
93. AlexanderKai 30.12.16 16:41 Сейчас в теме
(13)
Вы же не читаете байт-код после того как написали код на 1С? Потому и не шизеете.
24. AlexWhite 194 21.04.16 16:32 Сейчас в теме
(10) dragonedit,
Главным является полный комментарий
- а что вкладывается в понятие "полный комментарий"?
В ИС Дракон разработка алгоритма в виде блок-схем может производиться одновременно с разработкой программного кода
- какой, все-таки, в этом бизнес смысл? Насколько я понял, изменение блок-схемы ни как не влияет на изменение модулей программы? То есть, выбран просто еще один инструмент для графического представления бизнес-процессов, с добавлением интерактивности?
Но, по-моему, сейчас для этих целей более применим продукт 1С:СППР, который, как минимум, способен импортировать изменения структуры конфигурации, сделанные в конфигураторе, а в умелых руках вполне заменяет средства для коллективной разработки с хранилищами, ветвлениями, связи с требованиями, полуавтоматического создания документации и пр.
26. flex81 70 21.04.16 16:43 Сейчас в теме
(24) AlexWhite,

Изменение блок-схемы изменяет код, который генерит транслятор в итоге. Просто вы его вручную копируите в конфигуратор.
Чем лучше 1С:СППР? Не знаю. Не могу сравнить. 1С:СППР может переносить свой код в Конфигуратор - ну хорошо, еще один инструмент. Лучше когда их много, чем ни одного. :)
ИС Дракон закрывает в этом плане все мои потребности от документации до кода. Встречу хороший мануал по 1С:СППР - можно будет попробовать сравнить.
27. flex81 70 21.04.16 16:46 Сейчас в теме
(24) AlexWhite,
Полный комментарий...
Думаю каждый хочет понять логику разработки когда читает комментарий в коде? :) Когда есть дракон-схема к коду - логику разработки видно сразу. Комментарий - штука вспомогательная.
35. AlexWhite 194 21.04.16 17:16 Сейчас в теме
(27)
Думаю каждый хочет понять логику разработки когда читает комментарий в коде?
Лишние комментарии сильно усложняют процесс чтения и понимания кода. У нас, например, в комментарии приведены номера задач, по которым сделаны изменения, а задачи связаны с первичными требованиями. Видишь код, легко увидеть, для чего это было сделано.

1С:СППР может переносить свой код в Конфигуратор
- сомневаюсь. Вообще, я сторонник использования инструментов по прямому назначению. Для кода - конфигуратор, для описания бизнес-требований - система управления требованиями. За почти 25 лет моего опыта программирования и управления программными проектами мне ни разу не удалось графическое моделирование поставить на службу программированию. Причины:
1. Рубеж "аналитик vs заказчик": аналитик, договаривается с клиентом - "так должно быть?" клиент соглашается, но не может проверить, какой результат будет получен в итоге?
2. Рубеж "аналитик vs разработчик": аналогично. Потом тяжба - "ну, я сделал, как на схеме"/"нет, на схеме заявка слева, а у тебя вверху"/"заявка слева платформой не поддерживается" и т.д.
То есть, графические схемы годятся для визуализации какой-то, достаточно малой части проекта и, по-моему, добавляют сложность на том этапе, где используются. Недавно встречал формулировку "доработать, согласно описанию бизнес-процесса", а это описание выполнено в схеме - как по ней вообще можно программировать, мне не понятно. Схема годится для выявления пользователей, которым нужно задать правильные вопросы и выявить первичные требования в "поведенческой" терминологии. А для этого гораздо больше подходит Gherkin, чем любой другой инструмент графического моделирования :-)
38. Геннадий Тышов 21.04.16 18:44 Сейчас в теме
(35) AlexWhite,
Недавно встречал формулировку "доработать, согласно описанию бизнес-процесса", а это описание выполнено в схеме - как по ней вообще можно программировать, мне не понятно.
Использование Дракон-схем зависит от назначения схемы и уровня детализации. Назначением схемы может быть ТЗ, инструкция пользователю и алгоритм программы (модуля).
Использование ИС Дракон позволяет выполнять преобразование схем - выполнять декомпозицию, т.е. выполнять разделение на более мелкие. составные части.

AlexWhite, встреченная Вами формулировка вполне может быть отправной позицией для доработки.
39. flex81 70 21.04.16 18:47 Сейчас в теме
(35) AlexWhite,
1. Заказчик хочет выполнения бизнес-процесса с наименьшими усилиями. Если полученный в итоге процесс это обеспечивает - то все довольны. Дракон-схемы в итоге сводят все к "Инструкции пользователя" - то есть, скажем бухгалтера, чем меньше усилий занимает то или иное действие - при нужном результате, тем лучше. Аналитик - человек который должен придумать этот процесс и убедить или доказать это Заказчику. Мне это удается с помощью Дракона.

2. Если написанный функционал разработчиками - не выполняет дракон-схему "Инструкция пользователя" - то он не годиться. Тут тоже все просто. И проверено на практике.

Опять скажу, на практике проблемы встают в общем одинаковые у всех разрабов, на каком бы проекте они не работали и сколько бы они не занимались этим по времени. Просто я эти проблемы решаю дракон-схемами, и это работает. :)
4. IgorS 43 20.04.16 10:50 Сейчас в теме
Когда докладчик начинает презентацию со слайда, на котором написано "Объединяет специалистов из различных специалистов для решения "пограничных задач", то с уровнем его подготовки всё понятно.
jONES1979; +1 Ответить
33. flex81 70 21.04.16 17:10 Сейчас в теме
(4) IgorS,
Кто ничего не делает, тот не ошибается.
5. KurganPX 20.04.16 11:03 Сейчас в теме
Все здорово, но "Перейти" ....
28. flex81 70 21.04.16 16:54 Сейчас в теме
(5) KurganPX,
Еще раз повторюсь. Если есть дракон-схема к коду - то читают ее, а там видно наглядно что и как делает код. Без "Перейти". Не надо ломать голову, куда этот переход ведет.
6. comptr 35 20.04.16 11:28 Сейчас в теме
Так этот ДРАКОН - конструктор блок-схем? А в чём его преимущество по сравнению с другими аналогичным ПП? Хранение кода в элементах схемы и его автоматическая сборка в один модуль? А если нужно часть процедур\функций поместить в общий модуль? Несколько взаимосвязанных модулей форм?
ilya.don; +1 Ответить
7. Геннадий Тышов 20.04.16 14:38 Сейчас в теме
(6) borodatii, Программа ИС Дракон предназначена для общего применения, не является специальной для 1С. Возможность совместного применения с 1С зависит от степени освоения и наработки личной практики.

Материалы для пользователей 1С подготовленный в ИС Дракон хорошо принимаются пользователями.
8. comptr 35 20.04.16 15:15 Сейчас в теме
(7) dragonedit, мой вопрос не был связан с 1С, хоть так и выглядит отчасти.
25. flex81 70 21.04.16 16:33 Сейчас в теме
(6) borodatii,

Конечно в презентации показан пример создания одной кнопки. Реальный проект состоит из большого количества дракон-схем. Обычно в дракон-схеме я указываю где этот код находиться, в каком объекте метаданных он расположен.
34. flex81 70 21.04.16 17:11 Сейчас в теме
(6) borodatii,
В программе работает интерактивный переход между схемами. Так осуществляется связь. :)
9. СергейК 51 20.04.16 15:39 Сейчас в теме
Спасибо автору за пример применения языка Дракон.
Для, тех, кто не знаком с Драконом, на мой взгляд необходимо сначала хотя бы пролистать книгу автора языка Паронджанова В.Д. "Дружелюбные алгоритмы...". После этого только можно идти дальше...

А сам пытаюсь (заставляю себя) описывать на нем логику разрабатываемого ПО.
Пока получается плохо из-за лени, и в т.ч. явной не очевидности данного процесса составления описания программы.
Т.е. пока ведешь разработку ты и так все помнишь и схема не нужна. А вот через 3-6-12 мес. когда (если)
буду дорабатывать свой же код, была бы очень полезна освежить память.
Но я не стремлюсь зайти так глубоко, как автор статьи. Считаю пока для себя достаточным делать функциональное описание программы, что бы был понятен смысл кода, процедур и их общая взаимосвязь.
oninfostart; LexSeIch; +2 Ответить
79. Геннадий Тышов 26.04.16 04:46 Сейчас в теме
(9) СергейК,
Спасибо автору за пример применения языка Дракон.
Для, тех, кто не знаком с Драконом, на мой взгляд необходимо сначала хотя бы пролистать книгу автора языка Паронджанова В.Д. "Дружелюбные алгоритмы...". После этого только можно идти дальше...

Действительно, мы ничего не сказали о книгах Владимира Даниэловича Паронджанова.
Говоря о применении языка Дракон, надо быть знакомым с его книгами.

Все изданные книги и еще не изданные книги В.Д. Паронджанов выложил для свободного и бесплатного скачивания - http://drakon.su/knigi_vladimira_parondzhanova._skachat
1. ~ 2000 г. История создания языка "ДРАКОН" - http://transhumanism-russia.ru/content/view/331/62
2. 1998 г., 2000 г., 2008 г. Занимательная информатика ... - http://drakon.su/_media/biblioteka_1/zanim_inf_optimizacija1_.pdf
3. 2001 г. Как улучшить работу ума. ... - http://drakon.su/_media/biblioteka_1/parondzhanov_v.d._kak_uluchshit_rabotu_uma_.pdf
4. 2007 г. Почему мудрец похож на обезьяну, ... - http://drakon.su/_media/biblioteka_1/parondzhanov_-_pochemu_mudrec_poxozh_na_obezjanu_-_2007.djvu
5. 2009 г. Язык Дракон. Краткое описание. - http://drakon.su/_media/biblioteka/drakondescription.pdf
6. 2010 г., 2014 г. Дружелюбные алгоритмы, понятные каждому. ... - http://drakon.su/_media/biblioteka_1/03._2010_druzheljubnye_algoritmy_1.pdf
7. 2012 г., 2014 г. Учись писать, читать и понимать алгоритмы. ... - http://drakon.su/_media/biblioteka_1/01._2012_uchis_chitat_new_end_podlinnik.pdf
8. 2016 г. Почему врачи убивают и калечат пациентов ... http://drakon.su/_media/pochemu_vrachi_ubivajut_i_kalechat_pacientov_.pdf

Первый выпуск программы ИС Дракон выложен 06.04.2008, программа постоянно развивается с участием В.Д. Паронджанова и пользователей, рекомендуется в книгах 6,7,8. - http://drakon.su/programma_is_drakon , http://drakon.su/drakon-sxemy_aleksandra_araptanova , http://drakon.su/aleksandr_shilin._ehnciklopedija_programmy_is_drakon
19. palsergeich 21.04.16 13:22 Сейчас в теме
Но, есть VISIO и куча других программных продуктов, как платных так и нет, которые умеют делать понятные блок схемы, которые не стыдно показать заказчику, даже встроенный конструктор бизнес процессов в 1с может это сделать.
Да, решение необычное, но вы никогда не пройдете 1С совместимо с данным кодом, пока генерация идет через GoTo. А зачем делать то, что в широкой массе не оценится и явно не будет плюсом к резюме.
Не зря же есть стандарты написания кода и стандартные инструменты, для того что бы любой другой, обладающий достаточной квалификацией человек, мог продолжить и ориентироваться в разработке.
Проблема с избыточностью условных операторов можно и нужно решать переосмыслением архитектуры.
Это мне напоминает один старый случай - один маленький но гордый украинский франч прокачал бухию еще на 7.7 и хранил кеш данных всей базы на локальном диске в виде DBF файла, и продавал данное изделие клиентам, можно так сделать - да запросто, но стоимость поддержки была в 5 раз выше.
В тех же названиях процедур и функций можно перейти к определению по F12, в GoTo как минимум еще 3 лишних движения в конфигураторе, пока нет EDT.
А самый сок, это когда вашу команду по тем или иным причинам отстранят от проекта и другой исполнитель будет явно недоволен.
20. Геннадий Тышов 21.04.16 13:47 Сейчас в теме
(19) palsergeich,
Но, есть VISIO и куча других программных продуктов, как платных так и нет, которые умеют делать понятные блок схемы, которые не стыдно показать заказчику, даже встроенный конструктор бизнес процессов в 1с может это сделать.
Буду краток. Ориентированных на язык Дракон - нет. С такой функциональность как в ИС Дракон - нет. Все другие, в т.ч. VISIO, служат для рисования одного конечного варианта, т.е. они не рассчитаны для разработки и отладки алгоритма с отображением на всех этапах в блок-схемах, В Драконе все схемы взаимосвязаны. В ИС Дракон разработка алгоритма в виде блок-схем может производиться одновременно с разработкой программного кода. Предусмотрены средства трассировки при выполнении.

А самый сок, это когда вашу команду по тем или иным причинам отстранят от проекта и другой исполнитель будет явно недоволен.
Все должны уметь пользоваться ИС Дракон, при разработке должно быть обязательно использование ИС Дракон.
Тогда не будут возникать проблемы при смене программистов или увольнении.
22. flex81 70 21.04.16 16:24 Сейчас в теме
(19) palsergeich,

Я работаю на внутренних проектах Газпрома. Уж так сложилось. Координирую работу разных подрядчиков - и когда доходит дело до реальных задач, не было случая чтобы подрядчики что то не поняли или были не довольны кодом или бизнес-логикой в представлении дракон-схем. Чаще наоборот. Удается двигать даже очень "застарелые" задачи. :)

Что касается 1С совместимо. Это стандарт, а если он мешает продуктивной работе - то его надо менять. Для моего руководства важен результат. :)
51. palsergeich 21.04.16 21:00 Сейчас в теме
(22) В составе какой структуры ОАО Газпром? Там их просто нереальная куча. Я в свое время немало поработал как и в свечке, так и в разношерстных дочках, везде порядки разные. Где то важен результат, где то исполнение.
В свое время я в составе никому неизвестного франча, который нанял более крупный франч, копался в конфе синхронизации контрагентов от Акселота, для того же Газпрома, которая до этого пережила только одно внедрение и из коробки не работала.
Опять же на работе в смежной с 1с области, я часто бывал в подразделении Транснефти, которое вело собственную разработку на САП, и видел блок схемы во всю стену(более 30 метров), по одному бизнес процессу, и ничего, все у них получалось .
Мое мнение достаточно компетентно?
Дракон в нынешнем виде не является серебряной пулей, да, интересно, но не более, возможно выльется и во что то большее. Но как быть с модной асинхронностью? Много комментариев тоже плохо.
Мне например проще, и я успешно это делаю, раскопать код по стеку, быстро передвигаться по F12 к определениям. Комментарии да, интересно, но при таком обилии мусорного текста проще алгоритм понять без комментариев. Вот например что значит строчка //***********Шампур? Зачем мне знать емейлы разработчиков, к тому времени как я туда полезу этих людей по этим емейлам возможно не будет. Абсолютные пути в комменнтариях, а если будет переезд всего и вся на другой диск, а то и на другой сервер?
Конечно я понимаю, что вы болеете за свое детище, но поймите правильно, если я, при всей наглядности языка ДРАКОН, сгенерирую данный код, меня в этот же день выгонят, потому что времени осваивать данный механизм всем остальным разработчикам нет, это неоправданные расходы как на обучение так и на поддержку, а потом вы проект свернете, по тем или иным причинам,и что делать с текущими наработками?
Что касается 1С совместимо. Это стандарт, а если он мешает продуктивной работе - то его надо менять. Для моего руководства важен результат. :)

Задели за больное, а мы потом после одного такого продуктивного ..овнокод уже 6 месяц разгребаем. Да написано быстро, хорошо, но любое изменение требует перекопки просто всего ранее им же написаного, потому что для скорости и результата все сделано на костылях и граблях, строго в рамках решаемой задачи на текущий момент, механизм расширения функционала даже не предусматривался. Для того и введены стандарты что бы разработка была гибкой и поддерживаемой, а не сдавать механизм за механизмом, которые потом поддерживать сложнее, чем написать с нуля, перенести данные и снова сдать заказчику.
veretennikoff; dabu-dabu; zqzq; +3 Ответить
52. Геннадий Тышов 21.04.16 22:31 Сейчас в теме
(51) palsergeich,
видел блок схемы во всю стену(более 30 метров), по одному бизнес процессу, и ничего, все у них получалось .
Это уникальное произведение, навряд ли оно хранится в электронном виде и можно напечатать еще экземпляр. Изменения в него вносятся путем аппликаций, наклеиванием новых кусков.
В ИС Драконе проект разбит на файлы Дракон-листов, изменения вносятся выполнением стандартных операций - создать, копировать, вырезать, вставить, заменить, переместить. Операции выполняются над графическими объектами.

Много комментариев тоже плохо.
Мне например проще, и я успешно это делаю, раскопать код по стеку, быстро передвигаться по F12 к определениям. Комментарии да, интересно, но при таком обилии мусорного текста проще алгоритм понять без комментариев.
Комментариев не много, есть поля для заполнения, заполнение всех не обязательно. Поле видимого текста иконы - для описания назначения иконы в терминах проблемной области, невидимое поле программного кода. Остальные поля не являются обязательными. Видимое поле описания для бизнес процессов - исполнитель. Невидимые поля произвольного назначения: А-, Б-текст. - к примеру сюда пользователь или постановщик могут поместить свои замечания к программисту, программист может помещать обоснования и соображения.

Задели за больное, а мы потом после одного такого продуктивного ..овнокод уже 6 месяц разгребаем.
Сделавшему человеку, надо сказать спасибо, он вчера сделал необходимое и это позволило безболезненно всем перейти в сегодняшний день.
При выполнении этой работы в ИС Дракон сегодня имели бы полностью комментированные, визуальные и обозримые Дракон-схемы для дальнейшего развития.

53. palsergeich 21.04.16 22:43 Сейчас в теме
(52) Я то только за и более того согласен.
Надеюсь на дальнейшее развитие, и удачи Вам в Ваших начинаниях. Более того я давненько уже посматриваю за ДРАКОНом.
При обсуждении Дракона на форуме www.mista.ru был такой встречный вопрос: "Что вы скажите о шахматисте который не играет конем?".

В моем понимании GoTo это вырубить оппонента с вертушки и переставить фигуры на доске в нужном себе порядке)
60. flex81 70 22.04.16 08:33 Сейчас в теме
(51) palsergeich,
А сколько ..внокода я из 1С совместимо вытащил... . Просто Дракон не мешает вам писать по 1С совместимо, кроме Goto.
61. flex81 70 22.04.16 08:46 Сейчас в теме
(51) palsergeich,

Мне например проще, и я успешно это делаю, раскопать код по стеку, быстро передвигаться по F12 к определениям. Комментарии да, интересно, но при таком обилии мусорного текста проще алгоритм понять без комментариев. Вот например что значит строчка //***********Шампур? Зачем мне знать емейлы разработчиков, к тому времени как я туда полезу этих людей по этим емейлам возможно не будет.


Может случиться все что угодно... Но если проект делался правильно, у Заказчика должна остаться документация, то есть искомые дракон-схемы. У нас в сейфе на флешке с журналом с ответсвенными МОЛ. Тут все зависит от подхода. Тоже самое с абсолютными путями. Где хранить файлы - это уже другая история.
62. flex81 70 22.04.16 08:49 Сейчас в теме
(51) palsergeich,

Мне например проще, и я успешно это делаю, раскопать код по стеку, быстро передвигаться по F12 к определениям. Комментарии да, интересно, но при таком обилии мусорного текста проще алгоритм понять без комментариев. Вот например что значит строчка //***********Шампур? Зачем мне знать емейлы разработчиков, к тому времени как я туда полезу этих людей по этим емейлам возможно не будет.


Даже если вы решите внедрить не 1с а принципиально другое решение, дракон-схемы с бизнес-процессами у вас есть - уже готовые задания для разработчиков. Какая экономия средств и времени?

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

Шампур - означает начало отдельной ветки в схеме "Силует".

Спасибо на добром слове и за обратную связь. :)
36. AlexWhite 194 21.04.16 17:20 Сейчас в теме
В любом случае, за доклад, статью и пояснения спасибо! Вашу бы энергию, да в правильное русло! :-)
max1c; flex81; KurganPX; +3 Ответить
37. KurganPX 21.04.16 17:58 Сейчас в теме
По поводу внутренних проектов газмяса, видели - знаем, не удачный пример.
Есть такие понятия как сложности потока управления программы, советую почитать про граф управления и почему о нем надо знать программистам.
Притенении к Дракону (в аспекте 1С):
Неконтролируемый рост сложности потока управления: возможность возникновения паразитных переменных используемых в отдельных блоках, неконтролируемая информационная сложность кода и как следствие - неожиданные результаты связанные с производительностью + полное отсутствие понимания внутренних процессов, таких как управление блокировками и так далее.
Даже напрягаться не надо, чтобы написать "программу" которая будет отвечать всем критериям дракона, быть красивой и интересной, но вешающей машину, на которой она будет выполняться.
Притенении к автору:
Человек использующий go to в 1С, как в процедурном языке сразу перечеркивает любые доводы о профессионализме.
Но даже без учета написанного ранее: если вы говорите о том, что код с подобными конструкциями появляется автоматически, то будте любезны опишите процесс обратного построения схемы драконовской по сгенерированному им же коду. А то как понять, соответствует ли код схеме, а если схемы две, использующие пересекающиеся блоки, они-то корректно реализованы?А если вдруг надо внести правки в пересекающиеся блоки, а там go to?

Извините, слишком высокие накладные расходы, касательно 1С.
40. flex81 70 21.04.16 18:59 Сейчас в теме
(37) KurganPX,

Дракон - помогает программисту, но не заменяет его. Если вы об этом. И у Дракона нет критериев - он описывает логику - это язык. А на языке можно ругаться а можно стихи писать. :)

Изначально код копируют из дракон-схемы в Конфигуратор, поэтому проверять соответствие не имеет смысла. Источник то дракон-схема и ее траслятор. Если вы пишите в конфигураторе и этот код в дракон-схеме не отражаете, то это на ваш страх и риск.

Как собрать код, если нет дракон-схем? По коментариям из схемы - они там подробные... .
А если я разбираю стандартный код в дракон-схему, а делаю я это часто, т.к. надо понять, что же там до меня написано. Разработчик не доступен, а его код надо разобрать. Тогда я трассирую и составляю дракон-схему с переносом кода. Вот и все. К концу трассировки становиться понятна логика, ошибки, и способы решения, локализованы вопросные моменты, связи между процедурами и метаданными... . В общем действенный способ.

Про goto писать не буду - мне оно не мешает. :)
41. KurganPX 21.04.16 19:01 Сейчас в теме
(40)
Очень печально, что вы не прочитали то, что я написал.
Тогда ответьте на вопрос хотя бы: что делать если в модуле пересекаются две дракон-схемы?
43. flex81 70 21.04.16 19:04 Сейчас в теме
(41) KurganPX,
Такого не бывает. На то она и логика разработки без пересечений и повторений.
Бывает переход из разных дракон-схем в одну. Типа как общая функция или процедура.)
44. Геннадий Тышов 21.04.16 19:12 Сейчас в теме
(41) KurganPX,
что делать если в модуле пересекаются две дракон-схемы?
Не понял Вас. Две Дракон-схемы - это не две линии которые пересекаются.

Возможно, Вы имени ввиду Дракон-схему, отображающую процедуру, которая вызывается из разных мест. Тогда никаких проблем не возникнет, как и при любом использовании процедуры.
46. KurganPX 21.04.16 19:18 Сейчас в теме
(44) dragonedit,
Ещё раз, код двух схем пересекаться не может?

Если я не могу описать информационную систему схемой целиком, а для, например, бухгалтерии предприятия это справедливо, то использовать один и тот же документ в двух разных схемах я не могу? А модуль, могу или нет?
47. Геннадий Тышов 21.04.16 19:33 Сейчас в теме
(46) KurganPX,
Ещё раз, код двух схем пересекаться не может?
Не может.

Что страхов не было, надо перейти к освоению и наработке опыта, перешагните начального освоения.
42. Геннадий Тышов 21.04.16 19:04 Сейчас в теме
(37) KurganPX,
как следствие - неожиданные результаты связанные с производительностью + полное отсутствие понимания внутренних процессов, таких как управление блокировками и так далее.
Ваша Дракон-схема должна отображать Ваши знания о "понимания внутренних процессов, таких как управление блокировками и так далее". Если знаний нет, то никакая ИС Дракон не поможет, ИС Дракон нужна для визуализации Ваших решений.

Человек использующий go to в 1С, как в процедурном языке сразу перечеркивает любые доводы о профессионализме.
При обсуждении Дракона на форуме www.mista.ru был такой встречный вопрос: "Что вы скажите о шахматисте который не играет конем?".

будте любезны опишите процесс обратного построения схемы драконовской по сгенерированному им же коду.
Для чего это нужно?
Я гарантирую соответствие собранного (сгенерированного) программного кода Дракон-схеме и содержащему в ней написанному Вами коду.
Если есть сомнения, тогда проверьте, при наличии навыков программировать это не потребует много труда.
45. KurganPX 21.04.16 19:15 Сейчас в теме
(42) dragonedit,
Поговорки отношения к программированию не имеют, простите.

Все, что вы написали в статье и комментариях подразумевает единичную реализацию некой информационной системы в вакууме, то есть ни о каком развитии системы, ветвлении версий, слияния версий и так далее речи вообще не идет. Это не плохо для бурана, когда один код генерируется один раз, но не для информационных систем, которые подразумевают развитие.
Для того, чтобы внести изменения в функционал мне необходимо используя комментарии собрать схему, переформатировать её потом опять сгенерировать и тестировать не конкретные изменения в конкретном блоке, а всю схему целиком, так? не слишком ли дорого?
(43)
То есть. для верификации программы первоначальной схемой все модули участвующие в схеме надо дублировать для каждой новой схемы, так? Или изменения в этих модулях не влекут изменения функциональности схем? Как решаются конфликты в смежном коде?
48. flex81 70 21.04.16 19:38 Сейчас в теме
(45) KurganPX,

Все эти схемы и прочее используются в итерациях -- то есть изначально подразумевается развитие системы. Вся технология, что описана в статье служит для исключения вакуума разработки. То есть любой код и его изменение - это четко осознанная реализация бизнес-процесса программными методами.
Про пересечения - документы и модули можете конечно использовать сколько хотите, но в схеме вы указываете ссылку на этот документ или код. Которая и приводит вас к одной схеме. Без дублирования и повторений.
49. Геннадий Тышов 21.04.16 19:44 Сейчас в теме
(45) KurganPX,
то есть ни о каком развитии системы, ветвлении версий, слияния версий и так далее речи вообще не идет.
Есть средства копирования и вставки Дракон-схем между различными Дракон-листами. Для сравнения версий Дракон-листа, предусмотрено формирование для версии листинга (текстового файла), а потом сравнивайте листинги средствами 1С.
50. flex81 70 21.04.16 19:47 Сейчас в теме
(49) dragonedit,
В общем стандартный подход... Сравнить объединить... :)
54. Геннадий Тышов 22.04.16 04:22 Сейчас в теме
http://event.infostart.ru/2015/agenda/agenda.php#item373054

О докладе при заявке на конференцию:
Применение языка ДРАКОН и программы «ИС Дракон» на проекте внедрения 1С.
1. Как выбрать оптимальную конфигурацию 1С для приобретения?
2. Как сформировать техническое задание для "реальных" процессов компании?
3. Как получить то, что заказывали, от программистов?
4. Как обучить сотрудников, "старичков" и быстро "запустить" "новичков"?
5. Как сэкономить на обслуживании и доработке?
6. Как не попасть в "зависимость" от программистов?
P.S: Все примеры рассмотрим на реальном проекте.
55. Геннадий Тышов 22.04.16 05:13 Сейчас в теме
О методике Scrum
Основатель методики Scrum Джефф Сазерленд 21 апреля 2016г. в 22:54 рассказывает
https://roem.ru/21-04-2016/222932/loss-is-a-crime/

Использование ИС Дракон позволяет работать по Scrum.
В частности: всегда видеть, выделить и заняться одной проблемой из всего множества:
Многозадачность отупляет.
Если делать одновременно несколько дел, получится и медленно, и плохо. Не поступайте так.
Если вы считаете, что вас это не касается, то вы ошибаетесь — это относится и к вам.




56. Геннадий Тышов 22.04.16 07:10 Сейчас в теме
http://infostart.ru/public/19635/

"1С + Дракон?" - обсуждение ИС Дракон в 2009 году
57. andreymongol82 22.04.16 07:48 Сейчас в теме
Есть уже давно такой язык как UML. И куча сред для него. в том числе и с генерацией объектной модели. Не вижу особых преимуществ, если честно.
58. fzt 22.04.16 08:17 Сейчас в теме
Где скачать? Где кряк? =)
59. flex81 70 22.04.16 08:31 Сейчас в теме
(58) fzt,
Кряка нет. :) Стоит не дорого (Этож не среда для UML). Ставить и работать можно сразу - есть период ознакомления. Ключ покупается пожизненный.
Скачать можно отсюда: https://cloud.mail.ru/public/ecbde70c784a/%D0%98%D0%A1%20%D0%94%D1%80%D0%B0%D0%­BA%D0%BE%D0%BD
63. Steelvan 307 22.04.16 13:36 Сейчас в теме
И как уже было много сказано :

-ДЕРЕВО
ДЕРЕВО
ДЕРЕВО
+ДЕРЕВО

Без дерева вложенных диаграмм печаль это хранить в каждом файле на диске.

Очень надеюсь, что уважаемый Геннадий меня услышит и реализует.
64. Геннадий Тышов 22.04.16 14:01 Сейчас в теме
(63) Steelvan,
Я. знаю и помню Ваше желание видеть ДЕРЕВО.
Программа развивается и возможно будет ДЕРЕВО.

Сейчас же программа пригодна для практического применения.

Приходится выбирать: использовать сейчас или подождать, когда будет все желаемое.

В первом варианте, уже сейчас будет нарабатываться ваш опыт и опыт вашего окружения.
65. flex81 70 22.04.16 14:47 Сейчас в теме
(63) Steelvan,
Да дерево хорошо. И дерево, надеюсь, будет.
Но и сейчас через "Файл-открыть папку" открываются все файлы в папке. То есть - храня файлы схем проекта в структуре папок файловой системы эта проблема частично снимается. Всегото и надо организовать папки на диске по отдельному проекту. Переключение между листами тоже худо бедно реализовано. :)
66. kote 537 23.04.16 00:31 Сейчас в теме
Всё это очень хорошо - и даже goto не пугает - при условии, что в 1С будет встроен редактор этих Дракон-схем..
В противном случае (не обозревая схемы) - в этих goto быстро утонешь и скорость разработки характерная для 1С сойдёт на нет..
Второй вопрос - как эти схемы версионировать и, особенно, удобно сравнивать версии в истории изменений?
Жизнь, все же, показала, что лучше текстовых форматов пока ничего нет..

Надеюсь, даже, что управляемые формы скоро можно будет текстом писать - как HTML - и даже генерировать.. но это я, что-то, отвлёкся...

В общем, пока, по моему скромному, место Дракон-схем - разве что в документах по проекту - и то, если они действительно так понятны заказчикам..
Рисовать схемы и потом кодировать.. нет - быстрее, сразу кодировать.. а рисовать - вот разве что заказчику на подпись.
67. Геннадий Тышов 23.04.16 08:33 Сейчас в теме
(66) kote,
Рисовать схемы и потом кодировать.. нет - быстрее, сразу кодировать.. а рисовать - вот разве что заказчику на подпись.
Правильно будет так:
сначала разработать алгоритм в ИС Дракон, потом там же выполнить кодирование.
68. starik-2005 3097 23.04.16 10:41 Сейчас в теме
(67) Геннадий Тышов, тогда уж лучше в ARIS, чтобы эпичнее было и методологичнее.
70. Геннадий Тышов 23.04.16 11:18 Сейчас в теме
(68) starik-2005,
тогда уж лучше в ARIS, чтобы эпичнее было и методологичнее.
В ARIS имеется объединение блок-схем с программным кодом?
Если нет, тогда не лучше!.
72. starik-2005 3097 23.04.16 11:41 Сейчас в теме
(70) Геннадий Тышов, есть. Там даже скрипты есть, чтобы схемы плодить и размножать. Т.е. как от схемы можно создать код или его прототип, так и обратно - скриптом можно сгенерировать схему.
73. Геннадий Тышов 23.04.16 12:20 Сейчас в теме
(72) starik-2005,
ARIS и ИС Дракон имеют различные назначение и функциональность. Выбирайте.
В докладе хорошо показана технология использования ИС Дракон.

Там даже скрипты есть, чтобы схемы плодить и размножать. Т.е. как от схемы можно создать код или его прототип, так и обратно - скриптом можно сгенерировать схему.
Необходимости в скриптах нет.
ИС Дракон настраивается для программирования на различные языки, в т.ч. на JavaScript.
84. caponid 26.04.16 14:43 Сейчас в теме
(72) starik-2005,
caponid, не вижу примера. Вот есть, допустим, что-то типа: результат = запрос.выполнить().

хм, по моему я уже описывал довольно простой и понятный пример, но если Вам нужен код.. ))
итак, есть глобальная функция Выполнить(Текст), ей передается аргументом код текстом..
вот сам текст...
Если Ссылка.Пустая() Тогда Перейти ~Конец; КонецЕсли;
// тут отрабатываем ссылку если не пустая

Если Ссылка2.Пустая() Тогда Перейти ~Конец; КонецЕсли;
// тут отрабатываем ссылку2 если не пустая

Если Ссылка3.Пустая() Тогда Перейти ~Конец; КонецЕсли;
// тут отрабатываем ссылку3 если не пустая

 ~Конец:
Показать

сколько вложенных "Если" у вас получится? - а так простой и понятный код....
74. webester 26 23.04.16 18:17 Сейчас в теме
Задумка, забавная мягко говоря. Если говорить прямо - вполне себе веселая, я люблю такие штуки, но использовать можно, строго для документации. А если вдруг программисту у которого нет под рукой этих самых схем, или нет возможности их посмотреть, надо будет поправить логику серьезного приложения в нескольких местах? Вы будете отвечать за его психику? Я бы не хотел с ним встречаться после такого. Порадовала фраза, что качество кода неважно, важно комментирование. А тут везде гуру говорят, что качественный код комментировать не надо, он сам по себе читается хорошо.
75. Геннадий Тышов 23.04.16 20:03 Сейчас в теме
(74) webester,
Многое зависит от организации личной работы, от готовности работать с заказчиком и пользователем, от ориентации на качество и на перспективу дальнейшего развития программного продукта.
76. webester 26 24.04.16 05:43 Сейчас в теме
(75)Если проект будет чуть сложнее чем на 200, то код без этих схем становится не читаемым, чуть более, чем полностью и если вдруг этот дракон никому кроме тебя не окажется нужным, то обратно уже никак. Переписать в удобоваримый вид? Проще написать заново. Ты хочешь потом продать результат своей работы, еще кому нибудь? Не выйдет. Учить работать со схемами дракон будущих покупателей - это надо отдельную линию техподдержки заводить.
77. Геннадий Тышов 24.04.16 07:23 Сейчас в теме
(76) webester,
если вдруг этот дракон никому кроме тебя не окажется нужным, то обратно уже никак.
Продуктом работы программиста является работающая программа. Для пользователя ПО, текст программы не представляет интерес, программисты как правило, не предоставляют (за исключением 1С) исходные тексты, т.к. считают их интеллектуальной собственностью.

Нет никаких ограничений передачи ИС Дракон другим лицам. Если же Вы, что то создали на ИС Дракон, то передавайте файлы Дракон-листов вместе с ИС Драконом. Программа в одном маленьком файле, не требует установки, не требует размещения в специальных папках на диске С:, может находится на одном из компьютеров в локальной сети для общего и одновременного использования несколькими пользователями.

Учить работать со схемами дракон будущих покупателей - это надо отдельную линию техподдержки заводить.
Пользоваться для просмотра Ваших Дракон-схем не сложнее Блокнота. Стандартная операция, в меню пункт "Файл/Открыть лист".
"отдельную линию техподдержки" заводить не надо, в программе есть пункт меню "Справка/Письмо автору", есть пункт "Справка/Получить обновление".

Для покупателя Вашего ПО, получение от Вас ИС Дракон будет подарком, бонусом. Обратите внимание: программа называется "интегрированной средой" для пользователя, а не "интегрированной средой разработки" для программиста. Ваши Дракон-листы могут содержать сопровождающую информацию, содержать интернетовские ссылки, содержать имена различных файлов, содержать адреса эл. почты, создает каталог для размещения сопровождающих файлов, иконы могут содержать ссылки на сопровождающую информацию с ее контекстным открытием. Производиться открытие приложений в соответствии с установленной ассоциацией расширений имен файлов.

Автор статьи выбрал для 1С реальный инструмент, предложил работоспособную и прогрессивную технологию.
78. webester 26 26.04.16 04:21 Сейчас в теме
(77)Обратите внимание, я не в одном месте не обсуждал функционал. Он может и хорош и пользоваться им просто. Но код читать без него никак. А это настораживает. Хотя штука довольно интересная. Это как заменить ноги электропротезами, не устают, бегают быстрее и тд но обратно уже никак!
80. flex81 70 26.04.16 06:22 Сейчас в теме
(78) webester,
Да все нормально. Три года уже код пишу в Драконе - и туда и обратно можно все делать. Немного практики и все.
82. fzt 26.04.16 12:01 Сейчас в теме
(80) есть какая-то внешняя обработка посмотреть?
83. flex81 70 26.04.16 12:59 Сейчас в теме
(82) fzt,
Посмотреть код? Как работать? :) Уточните вопрос пожалуйста.
Есть публикация с прошлого места работы.
Выкладывал для примера. http://infostart.ru/public/311020/
Или более большая работа, с доработкой закрытия месяца: http://infostart.ru/public/310271/

Если это не пойдет, дайте знать, пороюсь в архивах. Найду свежую внешку. :)
81. Геннадий Тышов 26.04.16 07:25 Сейчас в теме
(78) webester,
Но код читать без него никак. А это настораживает.


О практике программирования рассказано - http://forum.easyelectronics.ru/viewtopic.php?p=327540#p327540
Комментарии Владимира Паронджанова
85. утюгчеловек 41 26.04.16 16:08 Сейчас в теме
Насколько я понял дракон умеет переводить схему в код. А обратно? Это было бы полезно. И решило бы проблему аудита состояния текущего кода конфигурации.

Не верю, что нельзя было генерировать что-то адекватнее, чем goto переходы. Но, повторюсь, если бы можно было гонять код из схемы и обратно - в принципе пофигу на метки
86. Геннадий Тышов 26.04.16 17:21 Сейчас в теме
(85) утюгчеловек,
Насколько я понял дракон умеет переводить схему в код. А обратно? Это было бы полезно.
Обратно, нет такой возможности.
Преобразовать любой 1С программный код в Дракон-схемы очень сложно. Да и задача эта совсем другая.
Полагаю, что ценность не будет большой, т.к. проблемное описание в иконах программно не сформировать.

Не верю, что нельзя было генерировать что-то адекватнее, чем goto переходы.
Преобразование Дракон-схем в 1С код, при всех возможных построениях, возможно только с goto.
Полученный 1С программный код предназначен для выполнения.
Программный код смотрим в редких случаях: для нахождения иконы с ошибочным кодом.
94. AlexanderKai 30.12.16 16:56 Сейчас в теме
(86)
Преобразование Дракон-схем в 1С код, при всех возможных построениях, возможно только с goto.
Полученный 1С программный код предназначен для выполнения.
Программный код смотрим в редких случаях: для нахождения иконы с ошибочным кодом.

Справедливости ради замечу, что ДРАКОН используется в паре с Erlang - где вообще нет оператора goto, но видимо в этом случае идет сразу преобразование в байт-код виртуальной машины.
Или есть какое-то другое объяснение?
95. flex81 70 09.03.17 10:09 Сейчас в теме
(94) Не совсем понял вопрос. :) Я готовил доклад по опыту работу с программой-редактором ИС Дракон и 1С. Именно в этой связке. Как проходит работа в среде Erlang - не могу сказать. Думаю на этот вопрос могут ответить на форуме http://forum.oberoncore.ru/viewforum.php?f=62
На этом форуме думаю есть пользователи, использующие язык ДРАКОН для работы с Erlang. Вполне возможно - пользуются другими программами-редакторами языка.
96. flex81 70 16.05.17 16:25 Сейчас в теме
(94)
Кажется вот тут есть ответ на Ваш вопрос http://lurkmore.to/GOTO
Точнее тут http://lurkmore.to/_/120016#mws_tnuWEOF

На самом деле, GOTO — это единственный оператор, который используется для управления выполнением кода этими вашими центральными процессорами. Для всякого ЦП есть в сущности два способа управлять кодом: условный оператор (если да, то выполнить следующую команду, иначе выполнить послеследующую) и перейти на другой участок кода (GOTO). Всё. И все эти ваши процедурное программирование, функциональное программирование, ООП, ААП, замыкания, циклы и прочая синтаксическая ересь — после компиляции превращается в сотни, тысячи, миллионы GOTO (а точнее, в JMP, JE, JLE, JGE, JNE, etc.), я гарантирую это! Несогласные goto 30


Подводя итог - GOTO есть во всех языках. Даже если вы думаете, что его нет, так как это оператор процессора)).
87. flex81 70 26.04.16 21:23 Сейчас в теме
(85) утюгчеловек,
А что за проблема с аудитом текущего кода конфигурации?
88. flex81 70 26.04.16 21:29 Сейчас в теме
(85) утюгчеловек,
Гонять из кода в схему...
Если опустить все возражения типа "а зачем это надо?" то вот какая мысль есть по реализации этой идеи.
Исходя из того, что при конвертации схемы в код мы получаем текст с определенным строгим форматом. Тоесть у нас есть номера икон, начало и конец Шампуров и т.д. Что, теоретически позволяет нам написать алгоритм, который по такому форматированному тексту кода вполне мог бы нарисовать/сравнить дракон-схему.
89. flex81 70 26.04.16 21:32 Сейчас в теме
Но из-за ограниченности ресурсов, и неясной пользы, я бы не стал этим заморачиваться.
Думаю написать такой функционал придеться как нибудь. Ведь в каждом обсуждении этот вопрос задают. :)
90. LexSeIch 212 29.04.16 07:55 Сейчас в теме
Мир Вашему дому!
Что бы разобраться с "Драконами" - лучше всего, как уже указывалось выше, предварительно ознакомиться с книгами например этими. Там приведено много примеров построения схем алгоритмов. В чем польза такого подхода - можно общаться с людьми предметной области (не программистами) на одном, понятном языке. А это уже не мало. Стоит ли использовать это в 1С? Наверное стоит. Тем более, что в этом форуме есть люди, которые этим пользуются. И большое им спасибо за то, что делятся своим опытом.
91. Геннадий Тышов 21.06.16 16:11 Сейчас в теме
В Облаке Mail есть папка - "ИС Дракон".
Ссылка для доступа и скачивания - здесь.

В папке выложены файлы для скачивания:
1. ИС Дракон, выпуск от 20.06.2016 - Dragon_2016_06_20.rar
2. Dragon_Изменения.txt

Прошу сообщать Ваши отзывы, замечания и предложения.
----
Из файла Dragon_Изменения.txt:

1. В схеме Гном добавлена икона Конец.
2. Функциональность П-,С-текста схемы перенесены в иконы Заголовок.
Для ранее созданных листов П-текст схемы переноситься в текст иконы Заголовок при загрузке.
3. При изменении текста икон Заголовок и Ветка, выдается предупреждение и устанавливаются закладки.
4. Для отображаемого текста икон, при вводе по клавише TAB вводится пробел. При этом в окне редактирования используется шрифт листа. Это позволяет (хотелось бы) в иконках Комментариях вводить текст таблиц с выравненными колонками.
6. Внесены другие незначительные изменения.

Доработки п. 3, 4 сделаны по предложениям программистов 1С.
92. flex81 70 09.10.16 15:44 Сейчас в теме
Вот ссылки на видеодоклады с прошлого Infostart 2015. И мой доклад там есть.
http://infostart.ru/journal/news/mir-1s/videozapisi-dokladov-infostart-event-2015-teper-v-svobodnom-dostupe%E2%80%94553243/
или на Ютубе:
Доклад: https://www.youtube.com/watch?v=jrvrXcUXNrM
Обсуждения: https://www.youtube.com/watch?v=odUCRfrQ8wI
97. v3rter 16.05.17 17:00 Сейчас в теме
<SARCASM MODE>

Я понял. Это что-то вроде религии. Берём обыкновенные бизнес-процессы, добавляем элементы алгоритмических блок-схем, заворачиваем в красивую и убедительную упаковку легенду и вуаля, бизнес готов.

Человек - существо идеологически уязвимое, тем более, что советская эпоха привила среднему и старшему сверхдоверие к наукообразной подаче информации. А идеи, как известно не только "успешно овладевают массами", но и оставляют широкие прорехи в ее узких кошельках )

Есть, кстати, "такая же, но с перламутровыми пуговицами" для врачей, вдохновляйся и "евангелизируйся", %username% !
http://cito03.ru/books/pochemu.pdf

Мысль, кстати. Возьму, например, заначку, схожу к знакомому психологу, попрошу (небезвозмездно) набросать заметки о пользе бега на костылях, закажу копирайтерам с десяток текстов, сеошникам раскрутку, открою юрлицо и готово: "ИННОВАЦИОННАЯ МЕТОДИКА ОЗДОРОВЛЕНИЯ ВЕРТИНСКОГО БЕГОМ НА КОСТЫЛЯХ" ) До 30% населения можно убедить в полезности чего угодно, методики давно и широко известны в узких кругах. Так что (далее следует слоган):

Бег на костылях уравнивает! Костыльный спорт в массы! Даёшь всемирную Костылиаду!

</SARCASM MODE>

П.С. А ведь всего лишь погуглил...
98. flex81 70 17.05.17 15:11 Сейчас в теме
(97)
:)) Без коментариев. Тролей не кормим.
99. Геннадий Тышов 27.06.17 14:42 Сейчас в теме
Оставьте свое сообщение