Топ, покупайте идею
https://youtu.be/wCllU4YkxBk
https://youtu.be/wCllU4YkxBk
YouTube
Jonathan Blow plays Visual Studio
While we all wait for our savior JAI I thought it wouldn't hurt to remind ourselves of the great pain Jon has had to go through to make this language a reality.
Made as a light-hearted video.
If you're Jonathan and would like this to be taken down, pm me…
Made as a light-hearted video.
If you're Jonathan and would like this to be taken down, pm me…
Аналог ADT на кложуре, разумеется ADT тут нет, как и типов, но эммулируют его просто наличием создавая в хешмапе поле type и свитча по нему, ожидая что в зависимости от одного значения этого поля, какими будут другие.
функция somefunction возвращает либо хешмап со статусом error либо success
(:status r) получает значение status, дальше по нему матчится, если error то выводим message, если success выводим result
#Clojure
функция somefunction возвращает либо хешмап со статусом error либо success
(:status r) получает значение status, дальше по нему матчится, если error то выводим message, если success выводим result
#Clojure
👍1👎1
gavr_sas
Аналог с свифтом
Такс, давно собирался сильнее влица в кложу, думаю самое время. Цель написать такую простую CLI штучку которая читает из json пары англ ру слов, и затем тебя опрашивает. Буду веси репортаж с места событий.
Первое задание, придумать схему json, считать из файла, считывать ввод пользователя в цикле.
#Clojure
Первое задание, придумать схему json, считать из файла, считывать ввод пользователя в цикле.
#Clojure
gavr_sas
Такс, давно собирался сильнее влица в кложу, думаю самое время. Цель написать такую простую CLI штучку которая читает из json пары англ ру слов, и затем тебя опрашивает. Буду веси репортаж с места событий. Первое задание, придумать схему json, считать из…
Поставить json либу и считать файл, десериализовать в json оказалось супер просто, одна команда slurp(почему slurp???) считывает файл в строку, json/read-str превращает в нативный для кложи формат вложенных мап.
Теперь пытаюсь избавиться от этих надоедливых варнингов, def создает глобальную для неймспейса переменную, и нужно использовать let, но у let некрасивый синтаксис, вместо
(def sas 42)
(let [sas 42] используй тут sas, дальше его не будет)
отдает def x in {} из мл окамлов, но это же будет неудобно, благо можно объявлять сразу несколько (let [a 1 b 2] юзаем b и a)
Похожа кложа отучает от привычного подхода объявления переменных на каждую функцию и заставляет быть более функциональным, уже очевидно что тут конеш лучше использовать пайп оператор вместо промежуточных let'ов
Теперь пытаюсь избавиться от этих надоедливых варнингов, def создает глобальную для неймспейса переменную, и нужно использовать let, но у let некрасивый синтаксис, вместо
(def sas 42)
(let [sas 42] используй тут sas, дальше его не будет)
отдает def x in {} из мл окамлов, но это же будет неудобно, благо можно объявлять сразу несколько (let [a 1 b 2] юзаем b и a)
Похожа кложа отучает от привычного подхода объявления переменных на каждую функцию и заставляет быть более функциональным, уже очевидно что тут конеш лучше использовать пайп оператор вместо промежуточных let'ов
gavr_sas
Поставить json либу и считать файл, десериализовать в json оказалось супер просто, одна команда slurp(почему slurp???) считывает файл в строку, json/read-str превращает в нативный для кложи формат вложенных мап. Теперь пытаюсь избавиться от этих надоедливых…
Забавная ситуация, циклы тут этакие рекурсионные, отдает ерленгом эликсиром, делаешь loop, а потом в разных местах делаешь recur, то есть loop создает точку рекурсии, и его можно вызывать с аргументами которые могли бы быть в том массивчике после loop
Вторая забавная фигня это отсутствие синтаксических областей видимости(как и синтаксиса), изза чего для веток if else приходится делать do блоки.
[]Вторая забавная фигня это отсутствие синтаксических областей видимости(как и синтаксиса), изза чего для веток if else приходится делать do блоки.
👍2👎1
gavr_sas
Забавная ситуация, циклы тут этакие рекурсионные, отдает ерленгом эликсиром, делаешь loop, а потом в разных местах делаешь recur, то есть loop создает точку рекурсии, и его можно вызывать с аргументами которые могли бы быть в том массивчике после loop []…
Штош, вот и вся программа, с итерацией по ключам значениям вышла история, значит есть функция seq которая принимает мапу и выдает лист массивов из пар ключ значение.
>(seq {:foo 1 :bar 2})
([:foo 1] [:bar 2])
Есть макрос doseq который проходится циклом по каждому такому массиву keyvalue из списка созданного из мапы
И воот чтобы не распаковывать эти массивы из двух kw значений внутри итерации, можно распаковать их сразу
Вот тут k, v уже первый и второй элементы каждого массива, вот и получается итерация по ключам и значениям.
В ифе остался только второй дублок, потому что на одно действие он не нужен, линтер clj-kondo встроенный в ls очень не плохо работает, жаль исправления сам не предлагает.
>(seq {:foo 1 :bar 2})
([:foo 1] [:bar 2])
Есть макрос doseq который проходится циклом по каждому такому массиву keyvalue из списка созданного из мапы
> (doseq [keyval map] (prn keyval))
[:subprotocol "mysql"]
[:username "usr"]
[:classname "com.mysql.jdbc.Driver"]
[:subname "//100.100.100.100:3306/clo"]
[:password "pwd"]
И воот чтобы не распаковывать эти массивы из двух kw значений внутри итерации, можно распаковать их сразу
(doseq [[k v] db] (println k v))Вот тут k, v уже первый и второй элементы каждого массива, вот и получается итерация по ключам и значениям.
В ифе остался только второй дублок, потому что на одно действие он не нужен, линтер clj-kondo встроенный в ls очень не плохо работает, жаль исправления сам не предлагает.
👍2