Hi,
Many thanks for your reply.
Spliting the 'return p_x=xx;' is not a problem at all.
Problems with 'f()[0] = value;' are more serious.
> I'll think if those can be fixed, however, I can not put priority on fixing
When you think about it, could you also please think about the attached
macro ( trial3.cxx ) where functions are 'strictly' declared.
Proper "compiler" output as from trial2.cxx, wrong CINT output :
--------------------------
root [0] .L t12.cxx
Warning: Undeclared data member x FILE:/home/holeczek/src/test/./t12.cxx LINE:9
*** Interpreter error recovered ***
--------------------------
Thanks in advance,
Jacek.
#include <stream.h>
class XYZ {
public:
int p_x[10];
int p_y[20];
int p_z[30];
int (&x())[10] {return p_x;}
// int *y() {return p_y;}
int (&y())[20] {cout << "*p_y -> " << *p_y ;*p_y=6;cout << " -> " << *p_y << endl;return p_y;}
int (&z())[30] {return p_z;}
XYZ() {return;}
~XYZ() {return;}
int (&x(int xx))[10] {cout << "xx -> " << xx << " *p_x -> " << *p_x << endl;p_x[0]=xx;return p_x;}
int (&y(int yy))[20] {cout << "yy -> " << yy << " *p_y -> " << *p_y << endl;p_y[0]=yy;return p_y;}
int (&z(int zz))[30] {cout << "zz -> " << zz << " *p_z -> " << *p_z << endl;p_z[0]=zz;return p_z;}
};
main()
{
XYZ *xyz = new XYZ;
cout << "donald duck" << endl;
xyz->x(1)[0] = 10; cout << "xyz->x(1)[0] = 10 -> " << *xyz->p_x << endl;
xyz->y(2); cout << "*xyz->y(2) -> " << *xyz->p_y << endl;
xyz->z(3)[0] = 30; cout << "xyz->z(3)[0] = 30 -> " << *xyz->p_z << endl;
xyz->x()[0] = 4;
xyz->y()[0] = 5; cout << "*xyz->y() = 5 -> " << *xyz->p_y << endl;
cout << *xyz->x() << " " << *xyz->y() << " " << *xyz->z() << endl;
cout << "miki mouse" << endl;
}
This archive was generated by hypermail 2b29 : Tue Jan 04 2000 - 00:43:31 MET