Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-09-2013, 11:33   #1
nico159
Senior Member
 
Iscritto dal: Aug 2003
Città: Barletta (BA)
Messaggi: 939
[Generico] Nimrod: The Return of Pascal

Ho notato questo articolo riguardante un nuovo linguaggio, Mimrod:
http://steved-imaginaryreal.blogspot...of-pascal.html

Ho trovato il linguaggio così interessante, che ho voluto condividerlo anche qua

http://nimrod-code.org/tut1.html
http://nimrod-code.org/tut2.html

Qualcuno ha dei pareri al riguardo?

Ovviamente è un linguaggio nuovo, quindi librerie e tools scarseggiano
__________________
In a world without fences, who needs Gates?
Power by: Fedora 8 - Mac OS X 10.4.11

Ultima modifica di nico159 : 04-09-2013 alle 16:41.
nico159 è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2013, 06:40   #2
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Il fatto che sia ispirato al Pascal mi mette l'acquolina in bocca, ma al momento non ho tempo per dargli un'occhiata. Vediamo se posso questo fine settimana.

Anche se, come hai già detto tu, il problema dei nuovi linguaggi è quello che ci sono poche librerie e sono poco supportati. Questo, ormai, è un elemento molto importante, a prescindere dalla bontà stessa del linguaggio.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 07-09-2013, 17:28   #3
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Ho letto circa metà del primo tutorial e un circa un quarto del post del blog.

Tutto sommato la commistione di Python (perché come base trovo che parta da questo, piuttosto che dal Pascal) mi piace, anche se alcune soluzioni che ha adottato non mi piacciono o mi fanno storcere decisamente il naso.

Penso all'operatore & per concatenare le stringhe, ma soprattutto al finally: piazzato all'inizio della procedura e allo stesso livello di indentazione delle altre istruzioni. Assolutamente non condivisibili.

Non mi piace, poi il fatto che non utilizzi la type inference anche per il valore restituito da una procedura. Un piccolo sforzo poteva essere fatto anche in questa direzione.

Altra cosa che non mi garba sono i commenti multilinea o che devono essere allineati al blocco attuale.

Infine funzioni come low e high applicate a un intervallo le avrei evitate, preferendo un paio di attributi tipo .low e .high o, al massimo (ma non mi piace molto), come metodi.

Per il momento è tutto. Non so se avrò tempo per leggere altro. Al momento il mio giudizio è più positivo che negativo: c'è tanta roba interessante, e meno cose che non mi aggradano.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 07-09-2013, 18:04   #4
nico159
Senior Member
 
Iscritto dal: Aug 2003
Città: Barletta (BA)
Messaggi: 939
Quote:
Non mi piace, poi il fatto che non utilizzi la type inference anche per il valore restituito da una procedura. Un piccolo sforzo poteva essere fatto anche in questa direzione.
Sto testando un pò il linguaggio anche io
Puoi usare auto al posto di dichiarare il tipo di ritorno
__________________
In a world without fences, who needs Gates?
Power by: Fedora 8 - Mac OS X 10.4.11
nico159 è offline   Rispondi citando il messaggio o parte di esso
Old 08-09-2013, 10:37   #5
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Ho finito di leggere il blog, ma ho trovato sostanzialmente critiche per alcune scelte. Le riporto ugualmente, perché magari possono interessare. Eccole di seguito.

Codice:
type
     TChars = range['A'..'C']
Sarebbe stato meglio:
Codice:
type
     TChars = 'A'..'C'
perché 'A'..'C' identifica già un intervallo, e che si tratti di un nuovo tipo è evidenziato anche dalla keyword type.

Per i parametri passati per riferimento trovo che sia più comoda la sintassi del Pascal, che piazza la keyword var all'inizio di un elenco di parametri. In questo modo si sarebbero potuti marcare come var diversi parametri, anziché soltanto uno alla volta.

Non capisco per quale motivo il risultato di una funzione dev'essere scartato manualmente. Quale valore aggiunto porta questa decisione?

Le tuple, al contrario di quanto asserito, non sono come le tuple in Python. Sono, invece, come le struct in C, e sono anche mutabili. Mentre in Python sono anonime (ci sono le named tuple per assegnare dei nomi ai valori) e immutabili.

Peccato per l'uso di append anziché add come nome del metodo per appendere nuovi valori alle liste.

Non trovo corretto che con import vengano importati tutti i simboli di un modulo nel namespace. Sarebbe stato meglio dare visibilità al solo modulo, ed esplicitare i casi di importazione di tutto.

La definizione delle classi e dei metodi non mi spiace. E' verbosa e dispersiva. Avrei preferito qualcosa che incapsulasse tutto nella definizione, delegando magari fuori, a un'apposita sezione del codice, tutta o una parte dell'implementazione. E' una delle cose che digerisco di meno, come pure il dover creare manualmente l'istanza con new(result). Si poteva pensare a una soluzione stilistica di gran lunga migliore.
Devo vedere, invece, come funziona concretamente il concetto di dispatch-tree al posto della classica Virtual Method Table.

Mi piace l'idea dei generic "automatici", anche se trovo più leggibile la sintassi più esplicita (in cui si specifica un tipo opaco).

Stringhe mutabili... no. Non se ne sentiva il bisogno. Magari come tipo a parte sarebbe stato preferibile.

La sintassi per le procedure anonime è troppo verbosa e complessa. Decisamente poco pratica e poco intuitiva.

L'operatore $ per la convertire in stringa non mi piace. Sarebbe stato meglio mettere a disposizione un magic method, che avrebbe aumentato anche la leggibilità del codice.

Per adesso è tutto. Non so, però, se continuare coi tutorial, con questo spirito troppo critico. Ma forse dipende dal fatto che ho la mia idea di come dovrebbero andare le cose e come dovrebbe essere realizzato un linguaggio staticamente tipizzato, e non riesco proprio a farmi piacere le scelte fatte da altri. Limite mio, sia chiaro, ma voglio essere onesto ed esprimere esattamente ciò che penso.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 08-09-2013, 14:38   #6
Shirov
Senior Member
 
Iscritto dal: May 2004
Messaggi: 419
Anche io ci avevo speso un po' di tempo e tutto sommato mi trovo allineato con quanto detto di Cesare, forse reputo le pecche elencate un po' meno gravi dal punto di vista del gradimento ma lì è una questione di gusti. Onestamente tutti i linguaggi hanni limiti e carenze ma la più grave, per linguaggi come Nimrod, è quella dei tempi e dell continuità di sviluppo. Ormai di questi strumenti ce ne sono a centinaia e alcuni sarebbero anche davvero molto validi. Penso ad esempio a Cobra (forse quello messo meglio), ancor di più a Falcon (eccellente linguaggio creato da un italiano)... ma come fai a prendere i mano strumenti che ci mettono 4 o 5 anni per passare dalla fase alpha alla 1.0? Anche Clay era un linguaggio interessante, per fare un altro esempio... ma da luglio dello scorso anno non viene aggiornato... Wirbel, il "Python compilato" nato e morto in un paio d'anni. Per un Python o un Ruby ce ne sono altri 100 che passano inosservati anche si tratta di cose eccellenti. Altro problema è quello riguardante la documentazione.... come si fa a promuovere un linguaggio se la gente deve disperatamente cercare tra i sorgenti solo per far leggere una stringa di input dalla tastiera? La documentazione deve essere ampia, chiara ed aggiornata.... un controesempio, a mio avviso, è Fantom, linguaggio eccellente con molte caratteristiche interessanti ma l'organizzazione del materiale al suo riguardo è molto rigida e approssimativa..... Se si è interessati ai linguaggi "per diletto" va bene tutto... azzeccare "the next big thing" invece è un terno al lotto.... forse andrei con uno tra Rust, Go, Ceylon, Kotlin e Julia perchè hanno alle spalle team non dipendenti da un singolo sviluppatore... poi magari la gente adotterà in massa, che so, Ya, creato di recente da uno schizzato russo... ma chi può dirlo....
__________________
--In Siberia non sono tutte gnocche... ma tante si...

Ultima modifica di Shirov : 08-09-2013 alle 14:40.
Shirov è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2013, 06:24   #7
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Infatti. Ormai abbiamo strumenti comodi per smanettare e tirare fuori nuovi linguaggi, per gioco o per qualcosa di più serio. Ma il loro futuro è una grande incognita per le motivazioni che hai ben esposto.

Per avere delle discrete possibilità di diffusione, credo che oggi un nuovo linguaggio debba avere un team alle spalle, che garantisca continuità.
Una cosa che potrebbe incoraggiare molto è se fosse basato su un altro linguaggio, di cui sarebbe quindi un'estensione o dal quale comunque prenderebbe molto, in modo da favorire un passaggio più morbido agli utenti. Ma questo rappresenta anche un grosso freno all'innovazione e alla creatività...
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2013, 18:33   #8
epimerasi
Member
 
Iscritto dal: Apr 2013
Messaggi: 247
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Infatti. Ormai abbiamo strumenti comodi per smanettare e tirare fuori nuovi linguaggi, per gioco o per qualcosa di più serio. Ma il loro futuro è una grande incognita per le motivazioni che hai ben esposto.

Per avere delle discrete possibilità di diffusione, credo che oggi un nuovo linguaggio debba avere un team alle spalle, che garantisca continuità.
Una cosa che potrebbe incoraggiare molto è se fosse basato su un altro linguaggio, di cui sarebbe quindi un'estensione o dal quale comunque prenderebbe molto, in modo da favorire un passaggio più morbido agli utenti. Ma questo rappresenta anche un grosso freno all'innovazione e alla creatività...
A proposito (semi-OT), ma il tuo progetto wpython?
epimerasi è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2013, 20:31   #9
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
E' fermo causa assoluta mancanza di tempo.

Le idee ci sono per migliorare (penso pure di molto) le prestazioni, ma non trovo spazio per implementarle.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
Nilox svela la sua nuova gamma: ci sono ...
Juventus-Inter, novità storica: l...
SAP presenta il suo cloud sovrano per l'...
Google riduce i costi di Veo 3: i video ...
Signal introduce i backup in cloud: grat...
Pure Loop 3 FX, da be quiet! un modo sem...
Hollow Knight: Silksong, scoperto un cod...
AMD espande il supporto di FSR 4 a oltre...
Tesla lancia Megablock e Megapack 3: bat...
Sciopero della fame: una serie di attivi...
Sfida Nintendo in tribunale senza avvoca...
GEEKOM entra nel settore dei notebook co...
Il giudice blocca l'accordo da 1,5 milia...
Non solo creativi: le app business che r...
Amazon questa mattina è scatenata...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 13:40.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v