* * * *

Privacy Policy

Blog italiano

Clicca qui se vuoi andare al blog italiano su Lazarus e il pascal.

Forum ufficiale

Se non siete riusciti a reperire l'informazione che cercavate nei nostri articoli o sul nostro forum vi consiglio di visitare il
Forum ufficiale di Lazarus in lingua inglese.

Lazarus 1.0

Trascinare un file nel programma
DB concetti fondamentali e ZeosLib
Recuperare codice HTML da pagina web
Mandare mail con Lazarus
Stabilire il sistema operativo
Esempio lista in pascal
File INI
Codice di attivazione
Realizzare programmi multilingua
Lavorare con le directory
Utilizzare Unità esterne
TTreeView
TTreeview e Menu
Generare controlli RUN-TIME
LazReport, PDF ed immagini
Intercettare tasti premuti
Ampliare Lazarus
Lazarus e la crittografia
System Tray con Lazarus
UIB: Unified Interbase
Il file: questo sconosciuto
Conferma di chiusura di un applicazione
Liste e puntatori
Overload di funzioni
Funzioni a parametri variabili
Proprietà
Conversione numerica
TImage su Form e Panel
Indy gestiore server FTP lato Client
PopUpMenu sotto Pulsante (TSpeedButton)
Direttiva $macro
Toolbar
Evidenziare voci TreeView
Visualizzare un file Html esterno
StatusBar - aggirare l'errore variabile duplicata
Da DataSource a Excel
Le permutazioni
Brute force
Indy 10 - Invio email con allegati
La gestione degli errori in Lazarus
Pascal Script
Linux + Zeos + Firebird
Dataset virtuale
Overload di operatori
Lavorare con file in formato JSON con Lazarus
Zeos ... dietro le quinte (prima parte)
Disporre le finestre in un blocco unico (come Delphi)
Aspetto retrò (Cmd Line)
Lazarus 1.0
Come interfacciare periferica twain
Ubuntu - aggiornare free pascal e lazarus
fpcup: installazioni parallele di lazarus e fpc
Free Pascal e Lazarus sul Raspberry Pi
Cifratura: breve guida all'uso dell'algoritmo BlowFish con lazarus e free pascal.
Creare un server multithread
guida all'installazione di fpc trunk da subversion in linux gentoo
Indice
DB concetti fondamentali e connessioni standard
Advanced Record Syntax
DB concetti fondamentali e DBGrid
DB concetti fondamentali e TDBEdit, TDBMemo e TDBText
Advanced Record Syntax: un esempio pratico
Superclasse form base per programmi gestionali (e non)
Superclasse form base per programmi gestionali (e non) #2 - log, exception call stack, application toolbox
Superclasse form base per programmi gestionali (e non) #3 - traduzione delle form
Superclasse form base per programmi gestionali (e non) #4 - wait animation
Un dialog per la connessione al database:TfmSimpleDbConnectionDialog
Installare lazarus su mac osx sierra
immagine docker per lavorare con lazarus e free pascal
TDD o Test-Driven Development
Benvenuto! Effettua l'accesso oppure registrati.
Giugno 13, 2026, 11:12:25 pm

Inserisci il nome utente, la password e la durata della sessione.

129 Visitatori, 0 Utenti

Autore Topic: Questo è un bug ?  (Letto 4820 volte)

DragoRosso

  • Scrittore
  • Hero Member
  • *****
  • Post: 1794
  • Karma: +53/-0
  • Prima ascoltare, poi decidere
Questo è un bug ?
« il: Aprile 30, 2026, 10:56:06 pm »
Ciao, vi propongo questo codice ripreso dal forum internazionale (https://forum.lazarus.freepascal.org/index.php/topic,73909.msg581815/topicseen.html):

Codice: [Seleziona]
program Project1;

uses SysUtils;

type
  TColor = -$7FFFFFFF-1..$7FFFFFFF;

const
  clmyRed: TColor = 255;

procedure A1(p: TColor); overload;
begin
  writeln('Color');
end;

procedure A1(p: Integer); overload;
begin
  writeln('Integer');
end;

var myint: integer;
begin
  myint := 87;
  A1(clmyRed);
  A1(myint);  //QUESTO dovrebbe chiamare la versione "Integer" non quella "Color" ...
  ReadLn;
end.

Provate a farlo girare, e vedrete che stamperà due volte "Color" a terminale. Eppure il codice è chiaro ...
Il perchè viene fatto ciò rimane oscuro, però è preoccupante se non si riesce a dare una spiegazione credibile.

E' certo che il valore 87 è all'interno del range di TColor, e quindi potrebbe essere confuso ... ma il tipo che lo contiene è integer ed è un tipo diverso da TColor.

Ma anche se fosse, se le due definizioni delle procedure in overload non sono distinguibili, il compilatore DEVE generare un errore.
Da notare che Delphi genera la corretta sequenza Color / Integer sul terminale con lo stesso identico codice ... che appunto è quello che ci si aspetta (o meglio che io mi aspetto).

Questo comportamento, a mio parare, mina la credibilità di FPC su uno dei più importanti paradigmi della programmazione ad oggetti.
:) Ogni alba è un regalo, ogni tramonto è una conquista :)

cappe

  • Jr. Member
  • **
  • Post: 73
  • Karma: +0/-0
Re:Questo è un bug ?
« Risposta #1 il: Maggio 16, 2026, 04:06:46 pm »
per non lo è, prova ad invertire

procedure A1(p: Integer); overload;
begin
  writeln('Integer');
end;

procedure A1(p: TColor); overload;
begin
  writeln('Color');
end;


DragoRosso

  • Scrittore
  • Hero Member
  • *****
  • Post: 1794
  • Karma: +53/-0
  • Prima ascoltare, poi decidere
Re:Questo è un bug ?
« Risposta #2 il: Maggio 16, 2026, 04:28:35 pm »
per non lo è, prova ad invertire .................

Cosa cambia ? Scriverà sempre Integer invece di TColor, ne sono abbastanza sicuro anche senza provare
Esattamente lo stesso bug.

Anzi è peggio, dimostrerebbe che in realtà il tipo "rilevato" è sempre uno solo OSSIA il primo che trova implementato in ordine nelle funzioni in overload (quindi da un verso sempre TColor e dall'altra sempre Integer), e quindi a maggior ragione dovrebbe generare un errore in compilazione.

Ammesso e non concesso che possa andare bene, avremmo due comportamenti diversi con le stesse identiche dichiarazioni.

Non penso che la definizione di overload debba avere una precedenza ... se no quale sarebbe quella giusta ?
:) Ogni alba è un regalo, ogni tramonto è una conquista :)

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 3083
  • Karma: +23/-4
Re:Questo è un bug ?
« Risposta #3 il: Maggio 17, 2026, 10:12:27 pm »
scusate...
ho letto nel forum internazionale ed ho provato a compilare il programma in questo thread
(che per sicurezza riporto)

però, a me da il risultato corretto....  ???

Codice: [Seleziona]
program testover;

type
  TColor = -$7FFFFFFF-1..$7FFFFFFF;

const
  clmyRed: TColor = 255;

procedure A1(p: TColor); overload;
begin
  writeln('Color');
end;

procedure A1(p: Integer); overload;
begin
  writeln('Integer');
end;

var myint: integer;
begin
  myint := 87;
  A1(clmyRed);
  A1(myint);  //QUESTO dovrebbe chiamare la versione "Integer" non quella "Color" ...
  ReadLn;
end.

dopo averlo compilato con fpc 3.2.2, ho questo risultato:
Codice: [Seleziona]
$ ./test_over 
Color
Integer

Edit:
non capisco, voi che versione di fpc avete provato?
« Ultima modifica: Maggio 17, 2026, 10:19:02 pm da nomorelogic »
Imagination is more important than knowledge (A.Einstein)

DragoRosso

  • Scrittore
  • Hero Member
  • *****
  • Post: 1794
  • Karma: +53/-0
  • Prima ascoltare, poi decidere
Re:Questo è un bug ?
« Risposta #4 il: Maggio 18, 2026, 12:41:17 am »
Lazarus 4.6 fpc 3.2.2, però sono su Windows con compilatore a 64 bit.
« Ultima modifica: Maggio 18, 2026, 12:45:33 am da DragoRosso »
:) Ogni alba è un regalo, ogni tramonto è una conquista :)

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 3083
  • Karma: +23/-4
Re:Questo è un bug ?
« Risposta #5 il: Maggio 18, 2026, 10:10:59 am »
Ho provato su windows, compilatore fpc 3.2.2 64bit: quì ho riscontrato il bug.

Su Linux, stesso cpmpilatore fpc 3.2.2 64bit, come già accennato, il bug non si presenta.

Il problema sembrerebbe quindi localizzato sulla generazione del binario su OS Windows.

Imagination is more important than knowledge (A.Einstein)

DragoRosso

  • Scrittore
  • Hero Member
  • *****
  • Post: 1794
  • Karma: +53/-0
  • Prima ascoltare, poi decidere
Re:Questo è un bug ?
« Risposta #6 il: Maggio 18, 2026, 12:01:29 pm »
Ho provato su windows, compilatore fpc 3.2.2 64bit: quì ho riscontrato il bug.
Su Linux, stesso cpmpilatore fpc 3.2.2 64bit, come già accennato, il bug non si presenta.
Il problema sembrerebbe quindi localizzato sulla generazione del binario su OS Windows.

Ma il codice binario riguardante quella parte non dovrebbe avere differenze, non ci sono di mezzo chiamate API. La "tipizzazione" e l'overload sono una caraterizzazione del compilatore e non dovrebbero dipendere dal sistema operativo (sicuramente nel caso si processore compatibile).
Se hai usato Linux su x86-64 e Windows su x86-64 questa cosa non dovrebbe accadere, ma potrebbe accadere su piattaforme completamente diverse, ad esempio su ARM o su codice a 32 bit ... questo si (rimane comunque un bug).

Questa cosa è preoccupante, perchè mette in dubbio su come il compilatore esegua la tipizzazione e l'overload. Non può scambiare fischi per fiaschi.
Nel forum hanno riportato altre prove, e sembra che una discriminante importante sia la "lunghezza" del "tipo", quindi tipi con lunghezza identica come in questo caso potrebbero "confondere" il compilatore.

Quello che non comprendo è che nessuno a dato peso più di tanto a questo aspetto.
Non voglio assolutamente denigrare FPC, sia chiaro, ma ritengo che questa cosa sia importante.

L'overload dei metodi sono fondamentali e li uso spessissimo, quindi avere un tarlo sismile per mè sarebbe un incubo. E' accaduto anche per Delphi quando sbagliò a compilare codice (solo a 64 bit) su una particolare funzione .... non vi dico gli incubi notturni e diurni per paura che il mio codice fosse affetto da tale problema .... perchè ho il vizio di aggiornare alla prima occasione tutti i prodotti ed i clienti e quindi avrei diffuso il "bug" a dismisura ...
Poi per fortuna dopo mal di testa e verifiche approfondite il mio codice non era affetto dal problema e ho tirato un sospiro di sollievo.

Ciò lo espongo solo per chiarificare il mio comportamento nel contesto.
:) Ogni alba è un regalo, ogni tramonto è una conquista :)

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 3083
  • Karma: +23/-4
Re:Questo è un bug ?
« Risposta #7 il: Maggio 18, 2026, 12:17:33 pm »
appena ho modo proverò a compilare sotto LInux qualche sorgente preso dal forum inglese
se avrò un binario corretto lo segnalerò anche a loro
Imagination is more important than knowledge (A.Einstein)

varianus

  • Newbie
  • *
  • Post: 7
  • Karma: +1/-0
Re:Questo è un bug ?
« Risposta #8 il: Maggio 18, 2026, 01:07:13 pm »
Fa la stessa cosa anche con FPC 3.2.3 sotto Windows compilando a 32 bit.

Presumo che sia dovuto al fatto che usando la stessa rappresentazione il compilatore li consideri la stessa cosa.
Se forzo la clonazione del tipo
Codice: [Seleziona]
type
  TColor = type -$7FFFFFFF-1..$7FFFFFFF; 
funziona correttamente, almeno con la mia versione. E' la stessa cosa che hanno fatto per differenziare double e TDateTime.

I due tipi restano comunque compatibili a livello di assegnazione, come specificato nel wiki: https://wiki.freepascal.org/Type

DragoRosso

  • Scrittore
  • Hero Member
  • *****
  • Post: 1794
  • Karma: +53/-0
  • Prima ascoltare, poi decidere
Re:Questo è un bug ?
« Risposta #9 il: Maggio 18, 2026, 02:53:13 pm »
Fa la stessa cosa anche con FPC 3.2.3 sotto Windows compilando a 32 bit.
Presumo che sia dovuto al fatto che usando la stessa rappresentazione il compilatore li consideri la stessa cosa.
Se forzo la clonazione del tipo
Codice: [Seleziona]
type
  TColor = type -$7FFFFFFF-1..$7FFFFFFF; 
funziona correttamente, almeno con la mia versione. E' la stessa cosa che hanno fatto per differenziare double e TDateTime.
I due tipi restano comunque compatibili a livello di assegnazione, come specificato nel wiki: https://wiki.freepascal.org/Type

Quando si dichiara l'overload, questo deve funzionare correttamente, perchè io richiamo come parametro una variabile tipizzata, non un valore qualsiasi, come una costante literale dove si possono creare dubbi a runtime
E il fatto di definire il "range" di TColor come anch'esso un tipo è un sovrappiù (basterebbe anche solo il casting, che però non funziona comunque).

Senza il tuo "type", anche l'assegnazione, forse in questo caso funziona, ma avrei parecchi dubbi nel complesso (già esperienze negative simili in FPC):

- attiva il range checking e cambia il valore assegnato a myInt e il valore di clmyRed in $7FFFFFFE ->
 
Codice: [Seleziona]
myint := $7FFFFFFE;
.......
clmyRed: TColor = $7FFFFFFE;

Esegui ... dovrebbe andare tutto bene.

Ora cambia il valore limite massimo di TColor in $7FFFFFFE  ->
 
Codice: [Seleziona]
 TColor = -$7FFFFFFF-1..$7FFFFFFE;

Esegui ...  errore nel range checking ????
Perchè ?

Se ci fosse un problema con i tipi, questo DEVE essere segnalato a livello di compilazione, ossia non posso assegnare pere con mele anche se entrambi si pesano sempre in grammi.

Ma se passa la compilazione e i valori limite rientrano nei range, perchè generare un errore a runtime?

Poi è ovvio che il range check nessuno le attiva, però ciò ti dà l'idea che qualcosa nel compilatore non gira nel verso giusto.

Ohh, magari sono io fissato. Però ....

Codice compelto con error checking
Codice: [Seleziona]
program testover;

{$mode Delphi}

type
  TColor = -$7FFFFFFF-1..$7FFFFFFE;

const
  clmyRed: TColor = $7FFFFFFE;

procedure A1(p: TColor); overload;
begin
  writeln('Color');
end;

procedure A1(p: Integer); overload;
begin
  writeln('Integer');
end;

var myint: integer;
begin
  myint := $7FFFFFFE;
  A1(clmyRed);
  A1(myint);   //QUESTO dovrebbe chiamare la versione "Integer" non quella "Color" ...
  ReadLn;
end.
« Ultima modifica: Maggio 18, 2026, 03:00:28 pm da DragoRosso »
:) Ogni alba è un regalo, ogni tramonto è una conquista :)

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 3083
  • Karma: +23/-4
Re:Questo è un bug ?
« Risposta #10 il: Maggio 19, 2026, 07:21:09 pm »
comunque leggendo sul forum inglese si vede che il problema sembra più che altro legato alla LCL (unit Graphics)
strano sul serio...
Imagination is more important than knowledge (A.Einstein)

 

Recenti

How To

Utenti
Stats
  • Post in totale: 20414
  • Topic in totale: 2452
  • Online Today: 424
  • Online Ever: 1525
  • (Giugno 08, 2026, 07:34:29 am)
Utenti Online
Users: 0
Guests: 129
Total: 129

Disclaimer:

Questo blog non rappresenta una testata giornalistica poiché viene aggiornato senza alcuna periodicità. Non può pertanto considerarsi un prodotto editoriale ai sensi della legge n. 62/2001.