LINUX.ORG.RU
Ответ на: комментарий от monk

В SBCL при попытке использовать многопоточный hunchentoot + postgresql я узнал, что такое LDB.

Интересно. А можно подробности? Интересно, что там может быть не так?

anonymous
()
Ответ на: комментарий от anonymous

Во-первых, не от гугла, гугл ее только купил, во-вторых - какая именно часть там написана на CL?

anonymous
()
Ответ на: комментарий от anonymous

А можно подробности? Интересно, что там может быть не так?

Сложно сказать. Использовал hunchentoot, cl-sql, postgresql. В среднм раз в 2-3 дня sbcl падал с ошибкой.

Сейчас попробую раскопать архив и спровоцировать ошибку

monk ★★★★★
()
Ответ на: комментарий от anonymous

Во-первых, не от гугла, гугл ее только купил, во-вторых - какая именно часть там написана на CL?

Раз купил значит от Google. И по крайней мере один из разработчиков SBCL имеет адрес, заканчивающийся на @google.com. Значит уже и SBCL от Google. Я не знаю какая там часть на CL, но та часть, что есть - является реальной программой на Common Lisp. Поэтому не надо балаболить про отсутствие реальных систем на CL. Вот ещё одна большая программа на CL http://www.ncbi.nlm.nih.gov/pubmed/26182406. Называется elPrep. Просто для того, чтобы создавать программы на CL руки должны быть не из задницы, и голова должна быть на плечах.

anonymous
()
Ответ на: комментарий от anonymous

Раз купил значит от Google.

Ну не надо фантазировать-то.

Я не знаю какая там часть на CL

Тогда и говорить не о чем.

Поэтому не надо балаболить про отсутствие реальных систем на CL.

Пока что сбалаболил только ты, причем дважды (про гугл и про то, что оно написано на CL).

Вот ещё одна большая программа на CL http://www.ncbi.nlm.nih.gov/pubmed/26182406.

Ссылка на пейпер по никому не нужной и неизвестной тулзе? Ну это вообще лол. Напоминаю, что речь шла про «широко используемые программы».

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

Видимо, по этой причине никаких широко используемых программ на CL мы никогда и не увидим, да?

anonymous
()
Ответ на: комментарий от anonymous

Поймал:

[2015-08-31 20:55:51 [ERROR]] :UTF-8 c-string decoding error:
                                the octet sequence #(183) cannot be decoded.
Backtrace for: #<SB-THREAD:THREAD "hunchentoot-worker-192.168.2.3:55657" RUNNING
 {1002F596A3}>
0: (TRIVIAL-BACKTRACE:PRINT-BACKTRACE-TO-STREAM #<SB-IMPL::STRING-OUTPUT-STREAM 
{100BCAD193}>)
1: (HUNCHENTOOT::GET-BACKTRACE)
2: ((FLET #:LAMBDA778 :IN HUNCHENTOOT:HANDLE-REQUEST) #<SB-INT:C-STRING-DECODING
-ERROR {100BCAD053}>)
3: (SIGNAL #<SB-INT:C-STRING-DECODING-ERROR {100BCAD053}>)
4: (ERROR SB-INT:C-STRING-DECODING-ERROR :EXTERNAL-FORMAT :UTF-8 :OCTETS #(183))
5: (SB-INT:C-STRING-DECODING-ERROR :UTF-8 #.(SB-SYS:INT-SAP #X00653180) 111 1)
6: (SB-IMPL::READ-FROM-C-STRING/UTF-8 #.(SB-SYS:INT-SAP #X00653180) CHARACTER)
7: ((:METHOD CLSQL-SYS:DATABASE-QUERY (T CLSQL-POSTGRESQL:POSTGRESQL-DATABASE T 
T)) "SELECT JOBS_ACTIVE.END_DATE,JOBS_ACTIVE.BEG_DATE,JOBS_ACTIVE.PAID,JOBS_ACTI
VE.HOURS,JOBS_ACTIVE.JOB,JOBS_ACTIVE.ORG,JOBS_ACTIVE.ID FROM JOBS_ACTIVE ORDER B
Y JOBS_ACTIVE.BEG_DATE" #<CLSQL-POSTGRESQL:POSTGRESQL-DATABASE localhost/monk/mo
nk OPEN {1008101E53}> :AUTO T) [fast-method]
8: ((SB-PCL::EMF CLSQL-SYS:DATABASE-QUERY) #<unavailable argument> #<unavailable
 argument> "SELECT JOBS_ACTIVE.END_DATE,JOBS_ACTIVE.BEG_DATE,JOBS_ACTIVE.PAID,JO
BS_ACTIVE.HOURS,JOBS_ACTIVE.JOB,JOBS_ACTIVE.ORG,JOBS_ACTIVE.ID FROM JOBS_ACTIVE 
ORDER BY JOBS_ACTIVE.BEG_DATE" #<CLSQL-POSTGRESQL:POSTGRESQL-DATABASE localhost/
monk/monk OPEN {1008101E53}> :AUTO T)
9: ((:METHOD CLSQL-SYS:QUERY (STRING)) "SELECT JOBS_ACTIVE.END_DATE,JOBS_ACTIVE.
BEG_DATE,JOBS_ACTIVE.PAID,JOBS_ACTIVE.HOURS,JOBS_ACTIVE.JOB,JOBS_ACTIVE.ORG,JOBS
_ACTIVE.ID FROM JOBS_ACTIVE ORDER BY JOBS_ACTIVE.BEG_DATE" :DATABASE #<CLSQL-POS
TGRESQL:POSTGRESQL-DATABASE localhost/monk/monk OPEN {1008101E53}> :RESULT-TYPES
 :AUTO :FLATP NIL :FIELD-NAMES T) [fast-method]
10: (CLSQL-SYS::FIND-ALL (JOBS::РАБОТЫ) :RESULT-TYPES :AUTO :REFRESH T :INSTANCE
S ((#<JOBS::РАБОТЫ {100A35ECA3}>) (#<JOBS::РАБОТЫ {100A35ECC3}>) (#<JOBS::РАБОТЫ
 {100A35ECE3}>) (#<JOBS::РАБОТЫ {100A35ED03}>) (#<JOBS::РАБОТЫ {100A35ED23}>)) :
ORDER-BY (#<CLSQL-SYS:SQL-IDENT-ATTRIBUTE JOBS_ACTIVE.BEG_DATE>))
11: (CLSQL-SYS::FIND-ALL (JOBS::РАБОТЫ) :RESULT-TYPES :AUTO :REFRESH T :INSTANCE
S ((#<JOBS::РАБОТЫ {100A35ECA3}>) (#<JOBS::РАБОТЫ {100A35ECC3}>) (#<JOBS::РАБОТЫ
 {100A35ECE3}>) (#<JOBS::РАБОТЫ {100A35ED03}>) (#<JOBS::РАБОТЫ {100A35ED23}>)) :
ORDER-BY (#<CLSQL-SYS:SQL-IDENT-ATTRIBUTE JOBS_ACTIVE.BEG_DATE>)) [more,optional
]   
12: (CLSQL-SYS::FIND-ALL (JOBS::РАБОТЫ) #<unknown> #<unknown> #<unknown> #<unkno
wn> #<unknown> #<unknown> #<unknown> #<unknown>) [tl,external]
13: (CLSQL-SYS:SELECT JOBS::РАБОТЫ :ORDER-BY #<CLSQL-SYS:SQL-IDENT-ATTRIBUTE JOB
S_ACTIVE.BEG_DATE> :REFRESH T)
14: (JOBS::WWW-LIST #<WWW:SITE {10084B5A93}>)
15: ((:METHOD HUNCHENTOOT:HANDLE-REQUEST (HUNCHENTOOT:ACCEPTOR HUNCHENTOOT:REQUE
ST)) #<HUNCHENTOOT:EASY-ACCEPTOR (host *, port 4242)> #<HUNCHENTOOT:REQUEST {100
BCA8E73}>) [fast-method]
16: ((:METHOD HUNCHENTOOT:PROCESS-REQUEST (T)) #<HUNCHENTOOT:REQUEST {100BCA8E73
}>) [fast-method]
17: (HUNCHENTOOT::DO-WITH-ACCEPTOR-REQUEST-COUNT-INCREMENTED #<HUNCHENTOOT:EASY-
ACCEPTOR (host *, port 4242)> #<CLOSURE (LAMBDA NIL :IN HUNCHENTOOT:PROCESS-CONN
ECTION) {100BCA8E3B}>)
18: ((:METHOD HUNCHENTOOT:PROCESS-CONNECTION (HUNCHENTOOT:ACCEPTOR T)) #<HUNCHEN
TOOT:EASY-ACCEPTOR (host *, port 4242)> #<USOCKET:STREAM-USOCKET {1002CA5723}>) 
[fast-method]
19: ((:METHOD HUNCHENTOOT:PROCESS-CONNECTION :AROUND (HUNCHENTOOT:ACCEPTOR T)) #
<HUNCHENTOOT:EASY-ACCEPTOR (host *, port 4242)> #<USOCKET:STREAM-USOCKET {1002CA
5723}>) [fast-method]
20: ((LAMBDA NIL :IN HUNCHENTOOT:CREATE-REQUEST-HANDLER-THREAD))
21: ((LAMBDA NIL :IN BORDEAUX-THREADS::BINDING-DEFAULT-SPECIALS))
22: ((FLET #:WITHOUT-INTERRUPTS-BODY-1120 :IN SB-THREAD::INITIAL-THREAD-FUNCTION
-TRAMPOLINE))
23: ((FLET SB-THREAD::WITH-MUTEX-THUNK :IN SB-THREAD::INITIAL-THREAD-FUNCTION-TR
AMPOLINE))
24: ((FLET #:WITHOUT-INTERRUPTS-BODY-537 :IN SB-THREAD::CALL-WITH-MUTEX))
25: (SB-THREAD::CALL-WITH-MUTEX #<CLOSURE (FLET SB-THREAD::WITH-MUTEX-THUNK :IN SB-THREAD::INITIAL-THREAD-FUNCTION-TRAMPOLINE) {7FFFF2906C4B}> #<SB-THREAD:MUTEX "thread result lock" owner: #<SB-THREAD:THREAD "hunchentoot-worker-192.168.2.3:55657" RUNNING {1002F596A3}>> NIL T NIL)
26: (SB-THREAD::INITIAL-THREAD-FUNCTION-TRAMPOLINE #<SB-THREAD:THREAD "hunchentoot-worker-192.168.2.3:55657" RUNNING {1002F596A3}> #S(SB-THREAD:SEMAPHORE :NAME "Thread setup semaphore" :%COUNT 0 :WAITCOUNT 0 :MUTEX #<SB-THREAD:MUTEX (free) {1002F59713}> :QUEUE #<SB-THREAD:WAITQUEUE  {1002F59743}>) #<CLOSURE (LAMBDA NIL :IN BORDEAUX-THREADS::BINDING-DEFAULT-SPECIALS) {1002F5962B}> NIL NIL NIL NIL)
27: ("foreign function: call_into_lisp")
28: ("foreign function: new_thread_trampoline")

monk ★★★★★
()
Ответ на: комментарий от monk

Не LDB, но тоже загадочная ошибка. Добился нагрузочным тестированием на одну и ту же страницу. Если в один поток, то этот код прекрасно работает и из SQL данные выдаёт корректно.

monk ★★★★★
()
Ответ на: комментарий от anonymous

Ещё один вариант ошибки:

CORRUPTION WARNING in SBCL pid 10056(tid 140737272018688):
Memory fault at f7522260 (pc=0x7ffff6567c5e, sp=0x7ffff31ad220)
The integrity of this image is possibly compromised.
Continuing with fingers crossed.
192.168.2.3 monk [2015-08-31 21:10:22] "GET /jobs/finished HTTP/1.1" 200 - "-" "
Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Firefox/38.0 Iceweasel/3
8.2.0"
[2015-08-31 21:10:22 [ERROR]] While accessing database #<POSTGRESQL-DATABASE loc
alhost/monk/monk OPEN {10060C7983}>
  with expression "SELECT JOBS_ACTIVE.END_DATE,JOBS_ACTIVE.BEG_DATE,JOBS_ACTIVE.
PAID,JOBS_ACTIVE.HOURS,JOBS_ACTIVE.JOB,JOBS_ACTIVE.ORG,JOBS_ACTIVE.ID FROM JOBS_ACTIVE ORDER BY JOBS_ACTIVE.BEG_DATE":
  Error NIL / ошибка SSL: bad decompression
  has occurred.
Backtrace for: #<SB-THREAD:THREAD "hunchentoot-worker-192.168.2.3:55689" RUNNING {1002F64323}>

monk ★★★★★
()
Ответ на: комментарий от monk

В обоих трейсах видно, что проблемы в кишках SBCL. Пробуй на последнем SBCL, a также друг х реализациях. Какбы CL, как яп здесь не причем — все проблемы в библиотеках и конкретных реализациях. В твоей ракете библиотеки может больше отполированны, так как из коробки да и с одной реализацией.

Oxdeadbeef ★★★
() автор топика
Ответ на: комментарий от Oxdeadbeef

Пробуй на последнем SBCL, a также друг х реализациях.

Пробовал. На том сервере SBCL уже раз шесть обновлялся. Других — это каких?

Какбы CL, как яп здесь не причем — все проблемы в библиотеках и конкретных реализациях.

Разумеется. В данном конкретном случае cl-sql-postgresql при многопоточной работе портит сам SBCL (может, так как FFI).

В твоей ракете библиотеки может больше отполированны, так как из коробки да и с одной реализацией.

В ракете за счёт другого подхода к многопоточности выстрелить себе в ногу намного сложнее. И в place и в thread нельзя случайно запортить переменную из чужого потока. FFI внутри thread из-за кооперативной многозадачности с точки зрения внешней библиотеки выполняется в одном потоке. Например, делая биндинг к GTK в SBCL мне явно приходилось выделять отдельный поток для GTK и следить, чтобы из других потоков ни одна функция GTK не вызывалась. А в Racket без проблем делаю thread, который пишет напрямую в значение прогресс-бара, пока основная программа заполняет остальные элементы в той же форме.

То есть все функции (и библиотеки!) в Racket по-умолчанию thread-safe. А в CL наоборот. Если разработчик библиотеки явно не озаботился блокировками вокруг всех setf и вызовов FFI, то будет плохо.

monk ★★★★★
()
Ответ на: комментарий от monk

Других — это каких?

Из наиболее активных: Clozure CL. Из коммерческих можно даже взять LispWorks personal edition для тестирования, хотя не уверен, работает ли там CL-SQL.

Oxdeadbeef ★★★
() автор топика
Ответ на: комментарий от monk

Если разработчик библиотеки явно не озаботился блокировками вокруг всех setf и вызовов FFI, то будет плохо.

Конечно все должно быть документировано по правильному. Например в LispWorks довольно хорошая документация, где оговариваются эти моменты.

Oxdeadbeef ★★★
() автор топика
Ответ на: комментарий от Oxdeadbeef

Какбы CL, как яп здесь не причем — все проблемы в библиотеках и конкретных реализациях.

С такими рассуждениями можно зайти дальше и вспомнить, что ANSI Common Lisp, как язык, вообще не поддерживает многопоточность. Поэтому, каким бы красивым или навороченным язык не был, вся реальная сила именно в реализациях. Поэтому для тех, кто делает реальный софт на CL, лучшим выбором является LispWorks или ещё более дорогущий Allegro.

anonymous
()
Ответ на: комментарий от monk

И в place и в thread нельзя случайно запортить переменную из чужого потока.

Ну так правильно, ведь place - весьма ограниченная возможность параллелизма (в терминологии рэкетиров), а thread в Racket - это просто «green thread», а потому, это не настоящие трэды. Т.е. это действительно другой подход - с помощью «кастрации» :-)

То есть все функции (и библиотеки!) в Racket по-умолчанию thread-safe. А в CL наоборот. Если разработчик библиотеки явно не озаботился блокировками вокруг всех setf и вызовов FFI, то будет плохо.

Ну, как бы, да. И в C и в C++ такая же ситуация, как и в CL. Racket берёт на себя больше, чем вышеупомянутые языки. Может быть, в большинстве случаев, это удобно, но не всегда. Руки должны быть развязаны, если они, как говорилось, растут не из задницы :-)

anonymous
()
Ответ на: комментарий от Oxdeadbeef

Например в LispWorks довольно хорошая документация, где оговариваются эти моменты.

Но всё равно приходится использовать внешние библиотеки. Не верю я, что в составе Lispworks будут биндинги к GTK, Oracle и MongoDB.

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

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

(define _callback (_fun #:async-apply enqueue
                        _pointer -> _pointer))

(define _pthread (_cpointer 'pthread))

(define pthread-create
  (get-ffi-obj 'pthread_create #f
               (_fun (t : (_ptr o _pthread))
                     (_pointer = #f)
                     _callback
                     (_pointer = #f)
                     -> (r : _int)
                     -> (if (zero? r)
                            t
                            (error "thread create failed")))))

(define done (make-semaphore))
(define t (pthread-create (lambda ignored 
                            (printf "running\n")
                            (semaphore-post done)
                            #f)))
(sync done)
monk ★★★★★
()
Ответ на: комментарий от anonymous

Руки должны быть развязаны, если они, как говорилось, растут не из задницы :-)

Интересно, почему же тогда в CL так противятся добавлению call/cc. Его отсутствие связывает руки гораздо сильнее.

С точки зрения Racket (и Scheme вообще) если что-то можно сделать надёжно, то лучше делать надёжно, а не предоставлять опасные возможности «на всякий случай». Также, если что-то делается, то оно должно иметь документированные однозначные последствия для любого ввода.

Вот, например, почему я не стал делать iterate для Racket (было такое желание):

* (iter (for i in '(1 2 3)) (collecting i) (when (> 1 2) (finally (princ "o"))))
o
(1 2 3)

Несмотря на то, что (> 1 2) явно ложь, finally выполняется. Причём из документации явно это не следует.

monk ★★★★★
()
Ответ на: комментарий от anonymous

CL-SQL на Postmodern поменять не пробовали

Нет. Когда до сайта дошли руки, то я уже ушёл на Racket (в основном из-за call/cc и нормальных модулей). Соответственно, и сайт переписал на Racket.

monk ★★★★★
()
Ответ на: комментарий от anonymous

И в C и в C++ такая же ситуация, как и в CL. ... Руки должны быть развязаны, если они, как говорилось, растут не из задницы :-)

Кстати, если брать именно Racket, то руки развязаны полностью благодаря нормальному FFI. То есть я могу выполнять любые функции Си, причём free после malloc можно заставить выполнять сборщик мусора. А также можно, например, передать в Сишный qsort любую функцию вида (lambda (x y) ...).

monk ★★★★★
()
Ответ на: комментарий от monk

Интересно, почему же тогда в CL так противятся добавлению call/cc. Его отсутствие связывает руки гораздо сильнее.

Я думаю, что противится то некому, потому что никому не нужно перерабатывать стандарт. Никому. И тем, кто реально может это сделать (т.е. у кого есть большие деньги), и тем, что только лишь является фонатами. Попробуй скажи какому-нибудь известному в сообществе лисперов персонажу о том, что стандарт уже устарел. Попробуй скажи, что обновление стандарта поспособствует привлечению новых пользователей и приближению Common Lisp к мэйнстриму (как это произошло с выходом C++11. Ведь до его выхода, C++ утрачивал свою популярность. Поэтому абсолютно правильным было решение о выпуске новых стандартов каждые 4 года.) Так вот, любой лиспер-бородач испытает батхёрт и ответит одно заветное слово: «ненужно». Он будет рассказывать тебе о Quicklisp, о куче библиотек, о SLIME о куче реализаций, но только не о том, что стандарт Common Lisp нуждается в переработке. Поэтому Racket выглядит более современным, чувствуется, что над ним работают. Но от того же складывается впечатление, что Racket - это большой академический эксперимент, полигон для пробы новых идей.

опасные возможности «на всякий случай».

Руки, руки прямые надо иметь :-)

anonymous
()
Ответ на: комментарий от monk

Кстати, если брать именно Racket, то руки развязаны полностью благодаря нормальному FFI. То есть я могу выполнять любые функции Си, причём free после malloc можно заставить выполнять сборщик мусора.

Ну вот, опять же, хороший пример того, насколько важна качественная реализация, а не красивые теоретические выкладки. LispWorks, судя по доке, всё это умеет. В CCL тоже хороший FFI, причём в обе стороны.

А также можно, например, передать в Сишный qsort любую функцию вида (lambda (x y) ...).

А вот в SBCL с этим проблемы. По крайней мере, в официальной доке сказано что «Calling Lisp functions from C is sometimes possible, but is extremely hackish and poorly supported as of SBCL 0.7.5.»

Так что на месте автора, вместо банального обзора библиотэк, которыми он называет «экосистему Common Lisp», и которые может самостоятельно исследовать любой проф. программист, лучше бы сделал обзор реализаций Common Lisp и призывал бы к объединению усилий для создания единой, но качественной реализации. Чего умалчивать удручающее состояние реализаций с кучей нерешённых проблем?

anonymous
()
Ответ на: комментарий от monk

Не верю я, что в составе Lispworks будут биндинги к GTK, Oracle и

Зачем гтк, когда у LispWorks есть крутой кроссплатформенный CAPI? И да, на юниксах они рисуют с помощью гтк.

Из коробки есть CommonSQL, с которого лепили пародию — CL-SQL. Поддерживаются oracle, MySQL, Postgres, microsoft sqlserver и odbc из коробки. Полная поддержка ORM, на которой также базируется экспертная система с прологом — knowledgeworks.

MongoDB.

Сейчас начали перебираться назад на SQL+SSD. Nosql стали менее нужны.

Oxdeadbeef ★★★
() автор топика
Последнее исправление: Oxdeadbeef (всего исправлений: 1)
Ответ на: комментарий от anonymous

С sbcl вообще беда, вроде пилят активно, но с каждой фичей вносят кучу багов. Притом основные нужные фичи, озвученные выше, отсутствуют. Дрочат на перформанс ценой стабильности рантайма :). Clozure CL более аккуратный что ли.

Oxdeadbeef ★★★
() автор топика
Ответ на: комментарий от Oxdeadbeef

С sbcl вообще беда, вроде пилят активно, но с каждой фичей вносят кучу багов.

Пилят, пилят, никак не выпилят. Попробуй сделать что-то вроде grep 'FIXME' -R * или grep 'KLUDGE' -R * в корневом каталоге исходников SBCL. Удивишься :-)

Притом основные нужные фичи, озвученные выше, отсутствуют. Дрочат на перформанс ценой стабильности рантайма :). Clozure CL более аккуратный что ли.

Не знаю как в CCL, но главная беда с SBCL, на мой взгляд в том, что там нет плана разработки. Вернее, там план такой: фиксить баги, зарегистрированные на launchpad (порой, десять лет тому назад) и делать «улучшения» по личному усмотрению (либо для личного фана, либо для конкретного продакшена). Если взглянуть на коммиты, там полно всяких «micro optimization». Как будто «micro optimization» это важнее тысяч 'FIXME' и 'KLUDGE'. Т.е. SBCL - это какой-то хакерский продукт для тех, кто хочет возиться с реализацией снова и снова и снова и снова и снова. Те, кто просто хочет выражать свои идеи на Common Lisp лучше использовать LispWorks. Не даром тот же Edi Weitz наплодил хороший софт именно на LispWorks, попутно став профессором математики. Время не тратил на хакинг SBCL, а работал с хорошим продуктом. Коммерческим, каким и должен быть, по сути, хороший софт. :-)

anonymous
()
Ответ на: комментарий от anonymous

лучше использовать LispWorks

Вот давно и пользуемся :)

Oxdeadbeef ★★★
() автор топика
Ответ на: комментарий от anonymous

в CL так противятся добавлению call/cc

Попробуй скажи какому-нибудь известному в сообществе лисперов персонажу о том, что стандарт уже устарел.

При чём тут стандарт? Вот есть sb-thread:make-thread — его нет в стандарте. Или тот же FFI. Для реализации call/cc необходима только поддержка со стороны реализации создать замыкание от текущей точки программы.

Так вот, любой лиспер-бородач испытает батхёрт и ответит одно заветное слово: «ненужно».

Ну да. Я пытался поднимать вопрос про call/cc и слышал в ответ именно это. Мол есть cl-cont и потоки, а всё остальное от лукавого. При том, что cl-cont ужасно тормозит, а потоки глючат в половине библиотек.

стандарт Common Lisp нуждается в переработке

Есть https://common-lisp.net/project/cdr/final.html

А в остальном, смысла менять именно Стандарт нет. Синтаксис меняется библиотекой. Возможности (потоки, FFI, продолжения, отладчик, ...) реализуются на уровне реализаций платформы.

Но от того же складывается впечатление, что Racket - это большой академический эксперимент, полигон для пробы новых идей.

Не сказал бы, что там идеи особо новые. http://docs.racket-lang.org/release/HISTORY.txt показывает скорее эволюционное развитие. Фактически, отличие от старой Scheme (которая ненамного моложе Common Lisp'а) только в быстром компиляторе и достаточно большом количестве библиотек.

monk ★★★★★
()
Ответ на: комментарий от Oxdeadbeef

Зачем гтк, когда у LispWorks есть крутой кроссплатформенный CAPI?

http://www.lispworks.com/documentation/lw70/CAPI-M/html/capi-m.htm

Что-то оно очень CLIM напоминает... Как на этом чуде простейший TreeView сделать с тремя колонками? Наподобие такого: http://www.kksou.com/php-gtk2/sample-codes/display-directory-tree-using-GtkTr...

monk ★★★★★
()
Ответ на: комментарий от Oxdeadbeef

Nosql стали менее нужны.

Опять «ненужно». Вот поэтому я и ушёл на Racket. Там в качестве ответов либо «сделай: метод такой-то» либо «так делать нельзя, ибо вредно» с обоснованием (например, на предложение сделать аналог safety=0).

monk ★★★★★
()
Ответ на: комментарий от Oxdeadbeef

крутой кроссплатформенный CAPI

Ржали всем стартапом.

anonymous
()
Ответ на: комментарий от anonymous

А вот в SBCL с этим проблемы. По крайней мере, в официальной доке сказано что «Calling Lisp functions from C is sometimes possible, but is extremely hackish and poorly supported as of SBCL 0.7.5.»

Это было давно. Основная проблема в том, что в CL нельзя передать произвольную лямбду. Надо писать

(defcallback f (x y)
 ....)

А потом передавать (callback f).

В CCL тоже хороший FFI, причём в обе стороны.

Та же фигня. Произвольную функцию не передать.

http://ccl.clozure.com/docs/ccl.html#m_defcallback

LispWorks, судя по доке, всё это умеет.

Не умеет выполнять произвольные функции

http://www.lispworks.com/documentation/lw70/FLI/html/fli-25.htm#25458

Судя по http://www.lispworks.com/documentation/lw70/FLI/html/fli-18.htm пункт 3.1.3, не умеет создавать указатели на объект, который можно собрать сборщиком мусора. Должно быть так: bytes в Racket — я могу этот массив передавать в любую функцию на Си, но при этом сам массив под управлением сборщика мусора. Мне не надо явно вызывать foreign-free. В CL в таких случаях приходится копировать из array в foreign-array и обратно. Ну или отслеживать время жизни данных как в Си.

monk ★★★★★
()
Ответ на: комментарий от monk

При чём тут стандарт? Вот есть sb-thread:make-thread — его нет в стандарте. Или тот же FFI. Для реализации call/cc необходима только поддержка со стороны реализации создать замыкание от текущей точки программы.

Потому что только стандарт может обязать разработчиков реализации сделать описываемую стандартом возможность языка. Это во-первых. А во-вторых, современный стандарт делает возможным писать переносимые программы, которые с меньшей вероятностью будут тормозить или глючить. То, что make-thread нет в стандарте - это беда т.н. «экосистемы» Common Lisp. В C++ трэды появились в C++11, в C11 появились, а в Common Lisp - нет. В третьих, обновленный стандарт вызывает куда больше чувство, что язык живой и современный, чем стопицотная статейка про «экосистему» и те же самые доморощенные библиотэчки. После выхода C++11 все запомнили фразу Страуструпа «C++ сейчас ощущается как новый язык». Потом был C++14, потом будет C++17 и т.д. И это вносит ощущение стабильности и уверенности, что язык будет развиваться и это развитие будет контролироваться не шайкой олдфагов с IRC, комитетом по стандартизации. Так что стандарт - это большая сила. :-)

anonymous
()
Ответ на: комментарий от monk

А в остальном, смысла менять именно Стандарт нет. Синтаксис меняется библиотекой. Возможности (потоки, FFI, продолжения, отладчик, ...) реализуются на уровне реализаций платформы.

Пойми, пока определённой возможности не будет в стандарте, тебе так и будут отвечать «ненужно». И будут правы, потому что того, чего нет в стандарте - «ненужно» по определению. То, что в конкретных реализациях есть конкретные возможности является заслугой конкретных разработчиков, которые реализовали эти возможности по собственной прихоти, а не потому, что это было «нужно». :-)

anonymous
()
Ответ на: комментарий от monk

Не сказал бы, что там идеи особо новые.

Да ладно. Вот свеженькая идея/возможность, опубликованная 21 мая сего года - http://www.cs.utah.edu/~mflatt/scope-sets-5/ Судя по мэйллисту, идей там много. Более того, уже мечтают о Racket 2 https://github.com/jeapostrophe/racket2/blob/master/scribblings/racket2/racket2.scrbl :-) Но меня вот что-то отталкивает от Racket. Вроде отличный язык, новый, а душа не лежит. А вот CL привлекает :-)

anonymous
()
Ответ на: комментарий от Oxdeadbeef

Как на этом чуде простейший TreeView сделать с тремя колонками?

http://i62.tinypic.com/2hg4k0l.png

Ага. http://www.lispworks.com/documentation/lw70/CAPI-M/html/capi-m-654.htm

Ну и сравни с GTK. В CAPI tree-view многоколоночсти нет, раскраски горизонтальных полосок нет, поиска нет... Вот для этого и нужен биндинг к GTK. Чтобы если чего-то не хватило в кросс-платформенном GUI, то можно было вытащить из него указатель на объект GTK и использовать всю мощь тулкита.

monk ★★★★★
()
Ответ на: комментарий от monk

Что-то оно очень CLIM напоминает... Как на этом чуде простейший TreeView сделать с тремя колонками? Наподобие такого:

А чего же ты пример с TreeView на Racket не привёл? :-) Неужто потому, что TreeView в гуишной либе Racket попросту нет? А вот в LispWorks CAPI TreeView как раз есть :-) Вообще говоря, гуишная либа Racket примитивненькая. У LispWorks намного богаче. А в Qt - ещё богаче :-)

anonymous
()
Ответ на: комментарий от anonymous

только стандарт может обязать разработчиков реализации сделать описываемую стандартом возможность языка.

Да ну? Можешь назвать широко распространённую версию Common Lisp без потоков, FFI, слабых ссылок и финализаторов?

современный стандарт делает возможным писать переносимые программы, которые с меньшей вероятностью будут тормозить или глючить

Вполне хватает bordeaux-thread, CFFI и trivial-garbage. Можно их считать стандартом де-факто.

В C++ трэды появились в C++11, в C11 появились, а в Common Lisp - нет.

В случае Си вообще неясно, зачем включать потоки в стандарт языка, если есть POSIX.

После выхода C++11 все запомнили фразу Страуструпа «C++ сейчас ощущается как новый язык». Потом был C++14, потом будет C++17 и т.д. И это вносит ощущение стабильности и уверенности, что язык будет развиваться и это развитие будет контролироваться не шайкой олдфагов с IRC, комитетом по стандартизации.

Обратная сторона: C++ с каждой версией всё тяжелей (для изучения, для реализации). Может повторить судьбу PL/1. Тот тоже контролировался «не шайкой олдфагов с IRC». А в результате все ушли на Си.

monk ★★★★★
()
Ответ на: комментарий от monk

Должно быть так: bytes в Racket — я могу этот массив передавать в любую функцию на Си, но при этом сам массив под управлением сборщика мусора. Мне не надо явно вызывать foreign-free.

В LispWorks тоже можно, вот аналог:

CL-USER> (fli:define-foreign-function (%time "time")
    ((timep :pointer))
  :result-type :int64)
%TIME
CL-USER> (fli:define-foreign-function (%localtime "localtime")
    ((timep (:const :pointer)))
  :result-type :pointer)
%LOCALTIME
CL-USER> (fli:define-foreign-function (%strftime "strftime")
    ((s (:pointer :char))
     (max :size-t)
     (fmt (:reference-pass :ef-mb-string))
     (tm :pointer))
  :result-type :size-t)
%STRFTIME
CL-USER> (setq buf (make-array 100 :element-type '(unsigned-byte 8)
                          :initial-element 0
                          :allocation :static))
#(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)
CL-USER> (fli:with-dynamic-foreign-objects ((timep :int64))
  (setf (fli:dereference timep) (%time fli:*null-pointer*))
  (fli:with-dynamic-lisp-array-pointer (pbuf buf :type :char)
    (let ((len (%strftime pbuf (length buf) "%a, %d %b %y %T %z"
                          (%localtime timep))))
      (ef:decode-external-string buf :utf-8 :end len))))
"Tue, 01 Sep 15 15:46:34 +0700"
Oxdeadbeef ★★★
() автор топика
Ответ на: комментарий от anonymous

А чего же ты пример с TreeView на Racket не привёл? :-) Неужто потому, что TreeView в гуишной либе Racket попросту нет?

Почему же? Есть: http://docs.racket-lang.org/mrlib/Hierarchical_List_Control.html

Примерно такой же, как и в CAPI. Поэтому я добавил к Racket прямой интерфейс к GTK: https://github.com/Kalimehtar/gir

monk ★★★★★
()
Ответ на: комментарий от monk

В CAPI tree-view многоколоночсти нет, раскраски горизонтальных полосок нет, поиска нет...

Я этот вопрос досконально не изучал, потому что надобности такой не было. Возможно можно «зделоть», так как там очень много ручек для настройки.

Oxdeadbeef ★★★
() автор топика
Ответ на: комментарий от Oxdeadbeef

В LispWorks тоже можно

ОК, Я невнимательно читал документацию.

monk ★★★★★
()
Ответ на: комментарий от monk

Да ну? Можешь назвать широко распространённую версию Common Lisp без потоков, FFI, слабых ссылок и финализаторов?

Я говорю про *обязать*. То, что в большинстве реализаций есть потоки (с разным API), FFI (везде по-разному, в SBCL так вообще только Lisp->C) говорит лишь о том, что кто-то когда-то соизволил это сделать. Именно соизволил. Проснулся однажды и подумал: «а не сделать ли мне... для фана». :-)

Вполне хватает bordeaux-thread, CFFI и trivial-garbage. Можно их считать стандартом де-факто.

То, что становится стандартом де-факто, в приличном обществе должно стать стандартом де-юре. Это «принцип протоптанных дорожек».

В случае Си вообще неясно, зачем включать потоки в стандарт языка, если есть POSIX.

Совершенно ясно. Умные дяди из комитетов ANSI C и ANSI C++ понимают, что зависят друг от друга. Поэтому и стандарты новые написали как бы совместно. Молодцы.

Обратная сторона: C++ с каждой версией всё тяжелей (для изучения, для реализации). Может повторить судьбу PL/1. Тот тоже контролировался «не шайкой олдфагов с IRC». А в результате все ушли на Си.

Ну и кто же это ушёл на Си? Я не люблю цепепе, но с выходом C++11 я отчётливо вижу рост его популярности. И все это видят. И все это связывают с выходом нового стандарта. А ведь всегда был тот же великий и ужасный boost, в котором были и трэды, и смартпоинтеры и ещё много чего. Только вот именно после выхода C++11 цепепе стал снова набирать популярность.

anonymous
()
Ответ на: комментарий от anonymous

опубликованная 21 мая сего года - http://www.cs.utah.edu/~mflatt/scope-sets-5/ Судя по мэйллисту, идей там много

Это, опять же, эволюция. «Consistent with those aims, purely pattern-based macros work with the new expander the same as with the old one, except for unusual macro patterns within a recursive definition context.». Ещё есть https://github.com/samth/pycket — если будет успешен, то Racket, возможно, сменит JIT компилятор.

Более того, уже мечтают о Racket 2 https://github.com/jeapostrophe/racket2/blob/master/scribblings/racket2/racke... :-)

Там вообще уже не лисп. Опять M-выражения кому-то спать не дают :-)

monk ★★★★★
()
Вы не можете добавлять комментарии в эту тему. Тема перемещена в архив.