Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-02-2011, 14:06   #1
dierre
Senior Member
 
L'Avatar di dierre
 
Iscritto dal: Sep 2004
Città: Interamnia Urbs
Messaggi: 2126
[SableCC] conoscere l'AST parziale

Mi rendo conto che un long shot chiedere qui (di solito non si parla di parser generator), ma tentare non nuoce.
Con SableCC 3.2 ho implementato un Custom Lexer che mi stampa i token letti fino ad un certo punto. Ecco un esempio:

Codice:
TId, state : 0, text : [font]
TLPar, state : 0, text : [(]
TBlank, state : 0, text : [ ]
TId, state : 0, text : [arial]
TComma, state : 0, text : [,]
TBlank, state : 0, text : [ ]
TId, state : 0, text : [bold]
TComma, state : 0, text : [,]
TBlank, state : 0, text : [ ]
TNumber, state : 0, text : [20]
TRPar, state : 0, text : [)]
TBlank, state : 0, text : [ ]
TLPar, state : 0, text : [(]
TBlank, state : 0, text : [ ]
TLPar, state : 0, text : [(]
TElement, state : 0, text : [v]
TDot, state : 0, text : [.]
TId, state : 0, text : [degree]
TBlank, state : 0, text : [ ]
TCop, state : 0, text : [>=]
TBlank, state : 0, text : [ ]
TNumber, state : 0, text : [3]
TBlank, state : 0, text : [ ]
TRPar, state : 0, text : [)]
TBlank, state : 0, text : [ ]
TLogicAnd, state : 0, text : [AND]
TBlank, state : 0, text : [ ]
TLogicNot, state : 0, text : [NOT]
TBlank, state : 0, text : [ ]
TElement, state : 0, text : [v]
TDot, state : 0, text : [.]
TId, state : 0, text : [label]
TBlank, state : 0, text : [ ]
TCop, state : 0, text : [==]
TBlank, state : 0, text : [ ]
TString, state : 0, text : ["Roma"]
TBlank, state : 0, text : [ ]
TRPar, state : 0, text : [)]
TBlank, state : 0, text : [ ]
TRPar, state : 0, text : [)]
Parser Exception
[1,71] expecting: EOF
Come potete vedere, siccome l'istruzione è incorretta, il parser genera un'eccezione dicendo dove è sbagliato il codice. Il che mi va benissimo, però il fatto che sia in grado di capire dov'è l'errore implica che sto benedetto AST è parzialmente costruito. Il problema è che il TreeWalker che deriva da un DepthFirstAdapter si attiva solo quando il parser non ha generato errori, io invece vorrei avere comunque accesso all'AST perché in pratica mi serve per colorare la sintassi e in questo caso i vari TId o TNumber che vedete sono in realtà dei parametri, io vorrei avere accesso al padre:

Codice:
	par = 
		{numero} number | 
		{stringa} string |
		{idpar} id ;
__________________
Un wormhole (buco di tarlo, in italiano), detto anche Ponte di Einstein-Rosen, è una ipotetica caratteristica topologica dello spaziotempo che è essenzialmente una "scorciatoia" da un punto dell'universo a un altro, che permetterebbe di viaggiare tra di essi più velocemente di quanto impiegherebbe la luce a percorrere la distanza attraverso lo spazio normale.
Go to a Wormhole
dierre è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2011, 15:03   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2785
Ciao, un'idea potrebbe essere quella di costruire "manualmente" l'albero all'interno delle produzioni. In ogni caso mi chiedo se sia questa la soluzione adottata dai vari IDE per il syntax highlighting in quando interrompendo la parsificazione al primo errore avrai una prima parte colorata e la seconda no (nel tuo esempio specifico in realtà no perché hai raggiunto EOF). Forse dovresti spezzare la grammatica in più sottoinsiemi disgiunti, ovviamente con una perdita di informazione, e parsificare più volte il codice per colorare una porzione per volta, ma non so se è fattibile, non ho mai fatto nulla del genere.
In ogni caso io non ho mai usato SableCC ma solo JavaCC ma credo siano simili...
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2011, 15:31   #3
dierre
Senior Member
 
L'Avatar di dierre
 
Iscritto dal: Sep 2004
Città: Interamnia Urbs
Messaggi: 2126
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Ciao, un'idea potrebbe essere quella di costruire "manualmente" l'albero all'interno delle produzioni. In ogni caso mi chiedo se sia questa la soluzione adottata dai vari IDE per il syntax highlighting in quando interrompendo la parsificazione al primo errore avrai una prima parte colorata e la seconda no (nel tuo esempio specifico in realtà no perché hai raggiunto EOF). Forse dovresti spezzare la grammatica in più sottoinsiemi disgiunti, ovviamente con una perdita di informazione, e parsificare più volte il codice per colorare una porzione per volta, ma non so se è fattibile, non ho mai fatto nulla del genere.
In ogni caso io non ho mai usato SableCC ma solo JavaCC ma credo siano simili...
Infatti ti spiego subito come ho fatto al momento:

spezzo il testo in "Istruzioni", essenzialmente l'elemento minimo affinché il parser possa valutare completamente. A quel punto faccio l'analisi Istruzioni per Istruzione (nel mio caso la fine istruzione è "\n"), il lexer cicla ad ogni key pressed mentre il parser cicla ad ogni \n, gli passo un secondo giro di colore

funziona, però mi stavo domandandavo appunto se potevo comunque analizzare l'albero parziale lo stesso. Ovviamente a quel punto sfrutterei solo quello che ha già costruito, è ovvio che la colorazione corretta si ha a fine istruzione.
__________________
Un wormhole (buco di tarlo, in italiano), detto anche Ponte di Einstein-Rosen, è una ipotetica caratteristica topologica dello spaziotempo che è essenzialmente una "scorciatoia" da un punto dell'universo a un altro, che permetterebbe di viaggiare tra di essi più velocemente di quanto impiegherebbe la luce a percorrere la distanza attraverso lo spazio normale.
Go to a Wormhole
dierre è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2011, 16:53   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2785
Quote:
Originariamente inviato da dierre Guarda i messaggi
Infatti ti spiego subito come ho fatto al momento:

spezzo il testo in "Istruzioni", essenzialmente l'elemento minimo affinché il parser possa valutare completamente. A quel punto faccio l'analisi Istruzioni per Istruzione (nel mio caso la fine istruzione è "\n"), il lexer cicla ad ogni key pressed mentre il parser cicla ad ogni \n, gli passo un secondo giro di colore
Ma quindi il parser che hai scritto valuta solo una singola istruzione? Non valuti il testo nell'insieme? E' più o meno quello che intendevo io, anche se pensavo a una cosa meno radicale: ad esempio un parser per riconoscere le dichiarazioni di variabili, uno per riconoscere le sequenze di parentesi, uno per la singola istruzione come mi pare di capire che hai fatto tu, ecc. Poi non so per quale linguaggio stai scrivendo il parser...
Quote:
Originariamente inviato da dierre Guarda i messaggi
funziona, però mi stavo domandandavo appunto se potevo comunque analizzare l'albero parziale lo stesso.
Credo di sì, alla peggio dovresti inserire delle istruzioni nelle produzioni per creare un secondo albero di sicurezza da sfruttare nel caso in cui la parsificazione termina prematuramente, ma secondo me potrebbe anche esserci una impostazione di SableCC che ti permette di dire che vuoi ottenere l'AST anche se non è completo.
Quote:
Originariamente inviato da dierre Guarda i messaggi
Ovviamente a quel punto sfrutterei solo quello che ha già costruito, è ovvio che la colorazione corretta si ha a fine istruzione.
Io in verità immaginavo un caso in cui invece di scrivere volta per volta aggiungendo al fondo vai anche a fare delle modifiche in mezzo al codice, in quel caso se si verificano degli errori tutta la parte dopo l'istruzione che hai aggiunto perde la colorazione. Ovviamente se parsifichi separatamente ogni istruzione e non il testo nell'insieme non c'è problema.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2011, 21:13   #5
dierre
Senior Member
 
L'Avatar di dierre
 
Iscritto dal: Sep 2004
Città: Interamnia Urbs
Messaggi: 2126
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Ma quindi il parser che hai scritto valuta solo una singola istruzione? Non valuti il testo nell'insieme? E' più o meno quello che intendevo io, anche se pensavo a una cosa meno radicale: ad esempio un parser per riconoscere le dichiarazioni di variabili, uno per riconoscere le sequenze di parentesi, uno per la singola istruzione come mi pare di capire che hai fatto tu, ecc. Poi non so per quale linguaggio stai scrivendo il parser...
è un linguaggio che usano nel mio dipartimento, è la mia tesi di laurea. Non ha dichiarazioni di variabili. Capisco cosa intendi tu, come fa anche l'editor di eclipse che divide in partizioni. Non è così complesso quindi l'unica partizione è quella dell'istruzione.

Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Credo di sì, alla peggio dovresti inserire delle istruzioni nelle produzioni per creare un secondo albero di sicurezza da sfruttare nel caso in cui la parsificazione termina prematuramente, ma secondo me potrebbe anche esserci una impostazione di SableCC che ti permette di dire che vuoi ottenere l'AST anche se non è completo.
Ho scoperto che posso implementare il metodo filter che mi permette di lavorare su ogni nodo al momento. Adesso vedo se posso fare qualcosa con quello.

Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Io in verità immaginavo un caso in cui invece di scrivere volta per volta aggiungendo al fondo vai anche a fare delle modifiche in mezzo al codice, in quel caso se si verificano degli errori tutta la parte dopo l'istruzione che hai aggiunto perde la colorazione. Ovviamente se parsifichi separatamente ogni istruzione e non il testo nell'insieme non c'è problema.
In pratica faccio così: per ogni key press prendi la posizione del cursore. Prendi lo \n precedente e quello successivo alla posizione e parla la singola istruzione.
__________________
Un wormhole (buco di tarlo, in italiano), detto anche Ponte di Einstein-Rosen, è una ipotetica caratteristica topologica dello spaziotempo che è essenzialmente una "scorciatoia" da un punto dell'universo a un altro, che permetterebbe di viaggiare tra di essi più velocemente di quanto impiegherebbe la luce a percorrere la distanza attraverso lo spazio normale.
Go to a Wormhole
dierre è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Disastro Rad Power Bikes: incendio al ma...
Speciale Braun in offerta su Amazon: reg...
Threads cresce e batte X su mobile a liv...
Televisori, asse Sony - TCL: c’è ...
Uso del carbone in calo in Cina e India ...
Una potente tempesta solare colpisce la ...
Italo fa la storia: Starlink arriver&agr...
Windows 11: rilasciati i fix di emergenz...
MacBook Air M4 in offerta su Amazon: il ...
Smartphone Motorola potenti a prezzi mai...
Dopo Las Vegas, Sphere raddoppia: in Mar...
Smarthome Tapo: funzionano bene, costano...
Valve aggiorna le linee guida Steam: chi...
PC portatili sempre più cari: ecc...
Samsung TV in offerta su Amazon: Neo QLE...
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:10.


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