|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Добрый день! Подскажите - предположим, есть готовое приложение с графическим интерфейсом пользователя. Или оно будет только писаться под WinForms или Net Framework. Есть ли какой-либо способ, используя только VS2019 CE например, (или плюс что-то бесплатное) чтобы, "отдав", подготовив наружу некоторые методы, переменные и прочее из основного приложение, сделать возможным, что бы пользователи писали свою обработку данных на языке, более-или менее совместимом с C# и его возможностями, что бы человек, который может что-то делать на С# в VS, смог работать и со скриптами? ... |
|||
:
Нравится:
Не нравится:
|
|||
16.06.2020, 21:16 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AleksVoronezh, Есть. И называется Windows Script Host ... |
|||
:
Нравится:
Не нравится:
|
|||
16.06.2020, 21:42 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
... |
|||
:
Нравится:
Не нравится:
|
|||
16.06.2020, 22:02 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
FastReports AleksVoronezh, Есть. И называется Windows Script Host Спасибо за ответ. Насколько я понимаю, Windows Script Host - это часть операционной системы, и этот "велосипед", хотя и очень мощный, тоже может сломаться в любой момент. Хотелось бы, в идеале, примерно так: некая версия .Net + откомпилированное приложение. И все. Примерно так же, как бывает, если в приложение на Delphi внедрить Pascal Script. Ну тут, понятное дело, все вообще обеспечивается в одном .exe файле. При этом, например, если изменился протокол обмена с прибором, не нужно перекомпилировать все приложения, достаточно подправить скрипт. А приложение, как и раньше, занимается визуализацией данных и прочее. Тут важен еще момент - по определенному событию может потребоваться передавать параметры в скрипт и дергать, так сказать, отдельные процедуры из него и получать обработанные данные. Како-то каждый раз запускаемый скрипт как единое целое не подходит конечно. Накже совсем нежелателен скрип с "главным циклом", это не Arduino :-) Смотрю, что за CodeDom... ... |
|||
:
Нравится:
Не нравится:
|
|||
16.06.2020, 22:50 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
у Олега Шило, видел вот такую хрень, не использовал но вроде практически как CodeDOM работает https://github.com/oleg-shilo/cs-script ... |
|||
:
Нравится:
Не нравится:
|
|||
16.06.2020, 22:59 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AleksVoronezh что бы пользователи писали свою обработку данных на языке, более-или менее совместимом с C# и его возможностями Выбирать язык C# для внедряемых скриптов -- оч. плохая идея. Берите самый простой язык. Например, Lua, или хотя бы VB. Не ошибётесь. https://github.com/NLua/NLua ... |
|||
:
Нравится:
Не нравится:
|
|||
16.06.2020, 23:50 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
hVostt, насчет NLUA очень интересно, спасибо. Бегло посмотрел (пока), надо думать, что он позволит, например, к уже готовому приложению на C# прикрутить и библиотеки с API по управлению конкретным прибором, если библиотеки, в свою очередь, были заточены изготовителем, как и примеры их использования, также под C#. ... |
|||
:
Нравится:
Не нравится:
|
|||
17.06.2020, 12:51 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AleksVoronezh Бегло посмотрел (пока), надо думать, что он позволит, например, к уже готовому приложению на C# прикрутить и библиотеки с API по управлению конкретным прибором, если библиотеки, в свою очередь, были заточены изготовителем, как и примеры их использования, также под C#. NLua позволяет обеспечить доступ к любым объектам из приложения. По сути вы на Lua делаете некий DSL, объектную модель для написания высокоуровневой логики. C# плохо, потому что он хорошо работает только в IDE со всеми его плюшками, и нужна высокая квалификация. Использование Lua или подобных скриптовых языков позволяет использовать квалифицированных специалистов предметной области, так как язык очень простой, там нужно 15 минут на изучение :) ... |
|||
:
Нравится:
Не нравится:
|
|||
17.06.2020, 13:21 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AleksVoronezh, если нужен именно C#-"скриптинг" - простой вариант делается элементарно и интеграция с остальным кодом практически бесшовная (указываются сборки, типы из которых "скрипт" может использовать. проблема только если только часть типов из сборки нужно "запретить" (или только часть членов типа) - конечно, и это можно решить). Примеры кода: 21674303 21675082 (в той теме было и какое-то обсуждение) "Скриптинг" в кавычках, потому что код "скрипта" превращается в обычную .NET-сборку (только уже в рантайме) и в итоге компилируется в машинные инструкции (как и весь остальной C#-код вашего проекта). ... |
|||
:
Нравится:
Не нравится:
|
|||
19.06.2020, 23:17 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
стоит учитывать, что при таком подходе можно инжектировать код, который выполнится, к примеру, с админскими правами, как по мне вариантом может быть ЭЦП к коду. как это вообще лучше организовать, знатоки, подскажите? ... |
|||
:
Нравится:
Не нравится:
|
|||
20.06.2020, 17:55 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Roman Mejtes ЭЦП к коду. Если имеется в виду электронная подпись, то правильно говорить ЭП. ЭП решает задачу только контроля изменений. Проблемы безопасности решаются только с помощью песочницы. Обычно внедряемые скрипты (как, например, Lua, или JS) содержат этот механизм из коробки. Но если кому угодно самостоятельно по...ться и реализовать свой велосипед с квадратными колёсами, конечно же велком :) ... |
|||
:
Нравится:
Не нравится:
|
|||
20.06.2020, 19:46 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
hVostt, ну если ограничить запуск только тех скриптов, которые имеют эп и есть корневой сертификат с помощью которого можно проверить этот скрипт. как в msoffice, грубо говоря ... |
|||
:
Нравится:
Не нравится:
|
|||
20.06.2020, 20:59 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Roman Mejtes hVostt, ну если ограничить запуск только тех скриптов, которые имеют эп и есть корневой сертификат с помощью которого можно проверить этот скрипт. как в msoffice, грубо говоря Грубо говоря, в таком случае лучше решать эти задачи профессиональным программистам, которые будут писать код, код будет проходить код ревью, затем он будет компилироваться, запускаться юнит-тесты, прогоняться регрессионные и авто-тесты, проверяться QA, подписывать подписью и выкладываться для деплоя. Нафига упали в таком случае скрипты, непонятно. Обычно встаиваемые скрипты приделывают, чтобы их писали не программисты и запускались в защищённой среде. А чтобы не получилось как у обезьяны с гранатой, код запускается в песочнице. Если сюда добавить ЭП, то по сути весь смысл будет похоронен и затоптан в грязь. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.06.2020, 21:37 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Roman Mejtes у Олега Шило, видел вот такую хрень, не использовал но вроде практически как CodeDOM работает https://github.com/oleg-shilo/cs-script Отлично работает, даже на Notepad++ можно установить плагин, руками написать в нотепаде++ минимальное приложение с формой и будет работать ... |
|||
:
Нравится:
Не нравится:
|
|||
29.06.2020, 08:55 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Зачем вся эта куча из lua? Ребят, .net позволяет писать скрипты на C# , на лету компилить в сборку, на лету дергать код из этой сборки. Reflection всё это делает. ... |
|||
:
Нравится:
Не нравится:
|
|||
29.06.2020, 14:50 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK на лету компилить в сборку, на лету дергать код из этой сборки. В этом есть проблема, кстати, и далеко не одна. ... |
|||
:
Нравится:
Не нравится:
|
|||
29.06.2020, 16:02 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK Зачем вся эта куча из lua? Ребят, .net позволяет писать скрипты на C# , на лету компилить в сборку, на лету дергать код из этой сборки. Reflection всё это делает. Мне удобнее писать код C# в IDE. Скрипты делаются для возможности описывать высокоуровневую логику не программистами. C# для не программистов очень сложен, код для описания сценариев и прикладной логики на C# довольно уродлив. Но хозяин барин, обычно в восторге от возможности писать скрипты на C# джуны, не понимая, что именно им потом с этими скриптами в итоге и еб****ь :) ... |
|||
:
Нравится:
Не нравится:
|
|||
29.06.2020, 18:03 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
hVostt в итоге и еб****ь :) fkthat и далеко не одна. Товарищи маги, вы тут столько порошка тратите на облако из ваших эмоций, что аргументов нащупать нельзя. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 10:33 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK hVostt в итоге и еб****ь :) fkthat и далеко не одна. Товарищи маги, вы тут столько порошка тратите на облако из ваших эмоций, что аргументов нащупать нельзя. Я объяснил какой сакральный смысл есть во встраиваемых скриптах. Именно из этого смысла вытекает тот факт, что язык должен быть максимально простым и заточен для того, чтобы быть встраиваемым. C# для этих целей не подходит. А вы о чём? Чего вы там щупаете? Какие ещё аргументы? ))) Вы говорите, .net позволяет компилить C# на лету... и что? Если у вас в рукаха молоток, то всё вокруг -- гвозди? ) ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 10:54 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
просто смысл в том, что на C# будут писать не пользователи, а программисты и им это нафиг не надо, им удобнее будет иметь возможность подгрузить готовую сборку в домен и не париться с какими то прокладками. обычный система plugin'ов или подобное, для расширяемости. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 11:09 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Roman Mejtes просто смысл в том, что на C# будут писать не пользователи, а программисты и им это нафиг не надо, им удобнее будет иметь возможность подгрузить готовую сборку в домен и не париться с какими то прокладками. обычный система plugin'ов или подобное, для расширяемости. Да и готовую сборку подгрузить тоже фиговая затея. В каких-то кривых наколеночных поделках, с качеством ниже плинтуса, может и покатит. Как бы хотелось бы, чтобы проходили тесты, QA, нафига этот манки патчинг ) ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 11:35 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK что аргументов нащупать нельзя. Вот тебе, например, аргумент: "скрипт" на шарпе однажды откомпилировавшись и загрузившись выгружен уже быть не может (CLR не может выборочно выгружать загруженную сборку). Еще, как и с любыми плагинами, возможные проблемы с версионностью зависимостей (Скрипт №1, например требует библиотеку версии 1.2.3.4, а скрипт №2 требует ту же библиотеку, но версии 2.3.4.5). ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 13:10 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
fkthat, создаешь домен, грузишь сборку в домен, выгружаешь домен, профит. тема уже избитая. между скриптом и кодом очень тонкая грань, особенно если сравнивать с высокоуровневыми языками программирования типа C#, который уже сам по себе ближе к скриптам. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 13:22 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
fkthat AlexeiK что аргументов нащупать нельзя. Вот тебе, например, аргумент: "скрипт" на шарпе однажды откомпилировавшись и загрузившись выгружен уже быть не может (CLR не может выборочно выгружать загруженную сборку). Еще, как и с любыми плагинами, возможные проблемы с версионностью зависимостей (Скрипт №1, например требует библиотеку версии 1.2.3.4, а скрипт №2 требует ту же библиотеку, но версии 2.3.4.5). Это не аргумент:) Это возмущение. Ну не может выгрузить и что? Если два плагина, должны работать в runtime то явно они будут уникальными. Просто подгружаешь два плагина и раскидываешь скрипт куда нужно. Чето вижу аргументов нету. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 13:28 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Roman Mejtes создаешь домен, грузишь сборку в домен, выгружаешь домен, профит. тема уже избитая. И имеешь весь гемморой с ремоутингом/маршаллингом и проч., как только тебе нужно что-то через границы домена вызвать. Кроме того в коре доменов уже нет и там все уже надо делать по-другому (через AssemblyLoadContext). ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 13:29 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
fkthat Roman Mejtes создаешь домен, грузишь сборку в домен, выгружаешь домен, профит. тема уже избитая. И имеешь весь гемморой с ремоутингом/маршаллингом и проч., как только тебе нужно что-то через границы домена вызвать. Кроме того в коре доменов уже нет и там все уже надо делать по-другому (через AssemblyLoadContext). Это можно поправить через WCF с помощью netnamedpipe . Чутка интерфейс вызова изменится. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 13:30 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK fkthat пропущено... И имеешь весь гемморой с ремоутингом/маршаллингом и проч., как только тебе нужно что-то через границы домена вызвать. Кроме того в коре доменов уже нет и там все уже надо делать по-другому (через AssemblyLoadContext). Это можно поправить через WCF с помощью netnamedpipe . Чутка интерфейс вызова изменится. Что-то мне всё это напоминает. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 13:41 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Сон Веры Павловны, Человек просто не понимает какую задачу решает, но уже решает. Плагины шмагины, WCF. Зачем это всё? -- Потому что могу ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 15:22 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
WCF для того, чтобы пользователь мог скрипт в полдюжины строк написать, это сила. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 16:13 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
fkthat WCF для того, чтобы пользователь мог скрипт в полдюжины строк написать, это сила. Да ладно? WCF, чтобы дергать плагины из другой сборки( которая конечно же в своем AppDomain сидит). Без всяких ухищрений с Marshal. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 16:45 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK fkthat пропущено... Вот тебе, например, аргумент: "скрипт" на шарпе однажды откомпилировавшись и загрузившись выгружен уже быть не может (CLR не может выборочно выгружать загруженную сборку). Еще, как и с любыми плагинами, возможные проблемы с версионностью зависимостей (Скрипт №1, например требует библиотеку версии 1.2.3.4, а скрипт №2 требует ту же библиотеку, но версии 2.3.4.5). Это не аргумент:) Это возмущение. Ну не может выгрузить и что? Если два плагина, должны работать в runtime то явно они будут уникальными. Просто подгружаешь два плагина и раскидываешь скрипт куда нужно. Чето вижу аргументов нету. 100%, совсем нету. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 16:46 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK fkthat WCF для того, чтобы пользователь мог скрипт в полдюжины строк написать, это сила. Да ладно? WCF, чтобы дергать плагины из другой сборки( которая конечно же в своем AppDomain сидит). Без всяких ухищрений с Marshal. Кстати, тут пробойчик, WCF - устаревшая фигня! надо что-то посовременнее ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 16:48 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK WCF, чтобы дергать плагины из другой сборки( которая конечно же в своем AppDomain сидит). Без всяких ухищрений с Marshal. WCF как бы подразумевает общение посредством жестко заданных интерфейсов. Произвольный скрипт (о котором речь шла изначально) подразумевает всё, что угодно. Или мы уже про откуда-то взявшиеся плагины? Ролг Хупин Кстати, тут пробойчик, WCF - устаревшая фигня! надо что-то посовременнее Ага, gRPC прикрутить. Будет вообще красота. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 17:48 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Сон Веры Павловны Произвольный скрипт (о котором речь шла изначально) подразумевает всё, что угодно. Или мы уже про откуда-то взявшиеся плагины? Что дальше мысль не развивается? Кидаем по WCF текст, скрипта, Там он компилится, и выполняется, результат в каком-то формате. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 18:14 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK Кидаем по WCF текст, скрипта, Да чо уж там - кидай сразу в какой-нибудь кастомный облачный сервис, а то у тебя как-то слишком просто получается. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 18:46 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK Что дальше мысль не развивается? Куда нам угнаться до мыслей Алёши ) ... |
|||
:
Нравится:
Не нравится:
|
|||
30.06.2020, 20:04 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK Сон Веры Павловны Произвольный скрипт (о котором речь шла изначально) подразумевает всё, что угодно. Или мы уже про откуда-то взявшиеся плагины? Что дальше мысль не развивается? Кидаем по WCF текст, скрипта, Там он компилится, и выполняется, результат в каком-то формате. концепция есть Теперь, главное, как говорят в немецких фильмах про сантехников - не останавливаться! ... |
|||
:
Нравится:
Не нравится:
|
|||
01.07.2020, 08:27 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK Сон Веры Павловны Произвольный скрипт (о котором речь шла изначально) подразумевает всё, что угодно. Или мы уже про откуда-то взявшиеся плагины? Что дальше мысль не развивается? Кидаем по WCF текст, скрипта, Там он компилится, и выполняется, результат в каком-то формате. Все логично, клиент шлет скрипт в WCF сервис, тот выполняет его и , в зависимости от результата - шлет ответку - свой скрипт(!) клиенту. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.07.2020, 08:29 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Читаю всё это и наводит на мысль, что автор хочет тоже самое, что я сейчас активно пишу. Сначала это было просто приложение WinForms, типо блокнотика для написания кода на VB/C#. Но в отличие от простого блокнота, здесь при вызове метода Main я передаю параметр SPA, в котором собрано большая куча объектов реализующие функций-прослоек для доступа к PostgreSQL, SQLite, Oracle, XML, Http, Soap, Ftp и т.д. Пользователь "не программист" может писать простые обработки (сразу бизнес-логику) с возможностью приостановки кода на паузу и остановку (об этом отдельный разговор). Конечно же всё работает с многопоточностью и доступна вся платформа .NET со всеми классами. Компиляция на лету работает на базе класса CodeDomProvider. . Спустя время понимаю, что есть неудобство, поэтому разделил приложение на ядро и визуальную часть. Сделал службу Windows, которая реализует простой REST интерфейс для приёма кода и выдачи статуса задачи пользователю. Пишу веб-страничку, где пользователь будет писать код/выбирать готовые обработки и отправлять через него. Да, это заработало. Теперь можно запускать задачи и вручную и планировать через службу (а серверов у нас не мало) Кто-то скажет велосипед, но так и есть, но он работает, его поддерживать легко, а главное люди пользуются и не надо особо им объяснять что и где менять в коде, чтобы решить их задачу. Конкретно про невыгрузку DLL из домена: действительно, жрёт память чуть-чуть, пока не критично. Служба будет рестартоваться довольно часто, поэтому совсем не критично. Читал статью, что можно создать отдельный домен и туда загружать сначала DLL, который будет реализовывать компиляцию. А оно уже будет загружать пользовательский скрипт (тоже DLL) в свой домен. Но пока класс компиляции не выносил в отдельную сборку, пока работает как есть. Итого: автору топика можно идти этим путём, потому как такие решения работают и на достаточно сложных задачах. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.07.2020, 22:00 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
VSVLAD, не уверен, что подобный код с импортами, классами, можно назвать как инструмент для "не программистов" :) очевидно, что .NET в виде c#/vb выставляют наружу программисты только потому что им удобней, о пользователях никто особо не думает. понятно, что пользователи как-то приспосабливаются, и даже привыкают. но сложнейшие сценарии в играх, например, описываются не на Cи, на котором игры пишутся, а на Lua или другом подобном языке. сам с этим сталкивался, и да "непрограммисты" конечно могут приспособиться и писать на C# или VB.net с помощью тех же программистов, свою работу надо делать, хотя бы и с адовыми интерфейсами от программистов. а интерфейсы от программистов -- адовые. за примерами далеко ходить не нужно :) ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 00:07 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
hVostt VSVLAD, не уверен, что подобный код с импортами, классами, можно назвать как инструмент для "не программистов" :) Короче, ребята, с вашей стороны только пыль в глаза) Маги и волшебники перфекционисткой эры. С нашей стороны, даже примеры есть. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 10:01 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK hVostt VSVLAD, не уверен, что подобный код с импортами, классами, можно назвать как инструмент для "не программистов" :) Короче, ребята, с вашей стороны только пыль в глаза) Маги и волшебники перфекционисткой эры. С нашей стороны, даже примеры есть. Кто-то скажет велосипед, но так и есть(ц) ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 14:10 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK Короче, ребята, с вашей стороны только пыль в глаза) Маги и волшебники перфекционисткой эры. С нашей стороны, даже примеры есть. Демонстрируете как вы гвоздь забили микроскопом и надуваете грудь. Как будто мы это не проходили. Вопрос, а что вы читали по этой теме? Может какие-то исследования проводили? Или как обычно, положили хрен и сделали как получилось, из говна и палок. Огого?! C# можно компилить в рантайм, всё, будет сисярп и неи....т. Отэто достижение ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 14:11 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Предлагаю почитать в образовательных целях. https://www.ibm.com/developerworks/ru/library/l-embed-lua/index.html https://www.coppeliarobotics.com/helpFiles/en/scripts.htm https://habr.com/ru/company/socialquantum/blog/428253/ https://ru.wikipedia.org/wiki/Сценарный_язык Одно из ключевых отличий встраиваемых языков -- они интерпретируемые. Чтобы пользователь мог отлаживать в рантайме, запуская бесчисленное количество раз. ЯП должен быть простым и заточен на прикладную область. Вот так примерно должна выглядеть минимальная программа типа Hello World Код: vbnet 1.
Никаких импортов, классов, методов. Это обычный императивный в доску сценарий. Такой, который легко транслируется на обычный русский язык из программы и обратно. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 14:27 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Твоя позиция с LUA ясна . Но это печаль. Максимум хукать код под события в движке. Дальше уже каша. print "hell" можно и на c# сделать. Придумать простой синтаксис и всё. А заниматься интеграцией LUA в любой движок, это ж кривости сплошные. Я то просто видел:) что это. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 15:02 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
hVostt, CSX на самом деле соответствует всем требования вышеперечисленным. там нет никаких пользовательских абстракций, классов и ненужного импорта, прочей фигни, точнее всё это можно не юзать. и будет не сильно от Lua отличаться. 2_AlexeiK, вы пришли за советом, вы его получили, развернуто, во всех отношениях, вместо того, чтоб прислушаться, вы пишите: "советы говно и я самый умный", тогда не понятно, зачем вы вообще эту тему создали, пилите как хотите, всем пофигу, на самом деле. хоть на Си скрипты пишите ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 15:10 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Roman Mejtes hVostt, 2_AlexeiK, вы пришли за советом, вы его получили, развернуто, во всех отношениях, вместо того, чтоб прислушаться, вы пишите: "советы говно и я самый умный", тогда не понятно, зачем вы вообще эту тему создали, пилите как хотите, всем пофигу, на самом деле. хоть на Си скрипты пишите Я не создавал:) КОсяк братишечка) ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 15:15 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AlexeiK Твоя позиция с LUA ясна . Lua как пример. На нём свет клином не сошёлся. AlexeiK Но это печаль. Максимум хукать код под события в движке. Дальше уже каша. Никаких проблем. AlexeiK print "hell" можно и на c# сделать. Придумать простой синтаксис и всё. Это уже будет не C#, а именно то, о чём я говорю. Придумаете синтаксис -- значит изобрели свой DSL, хороший DSL на вес золота. AlexeiK А заниматься интеграцией LUA в любой движок, это ж кривости сплошные. Я то просто видел:) что это. Ну речь идёт о конечной цели. Если ресурсов для внедрения скритов в ПО нехватает, лучше ограничиться обычным написанием кода. Не нужно лезть на рожон. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 20:38 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
Roman Mejtes CSX на самом деле соответствует всем требования вышеперечисленным. там нет никаких пользовательских абстракций, классов и ненужного импорта, прочей фигни, точнее всё это можно не юзать. и будет не сильно от Lua отличаться. Я ж не настаиваю на Lua, как может показаться, просто в этой сфере он самый распространённый. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 20:40 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
AleksVoronezh, А вариант с Roslyn в качестве скриптового движка никто не рассматривал? Там, вроде, даже мудохаться с доменами не надо... ... |
|||
:
Нравится:
Не нравится:
|
|||
06.08.2020, 17:10 |
|
Приложение на C# и внутри скрипты на C# ?
|
|||
---|---|---|---|
#18+
stomsky AleksVoronezh, А вариант с Roslyn в качестве скриптового движка никто не рассматривал? Там, вроде, даже мудохаться с доменами не надо... Рослин можно использовать, это работает. Там космос подводных камней, на которые обычно всем пофиг ровно до тех пор, когда это выйдет в прод. Смотрите, C# в рантайме компилится!? Огого!! Задача решена! Да-да. Наивно. Супер. ... |
|||
:
Нравится:
Не нравится:
|
|||
07.08.2020, 14:20 |
|
|
start [/forum/topic.php?all=1&fid=20&tid=1398497]: |
0ms |
get settings: |
10ms |
get forum list: |
16ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
150ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
75ms |
get tp. blocked users: |
1ms |
others: | 12ms |
total: | 286ms |
0 / 0 |