Когда пытаюсь обратиться к свойствам или вызвать метод (MyRef.SomeProp)... программа вылетает на дебаг

Подскажите кто-нидь в чем дело? раньше на том же коде все работало...
Модератор: Дед Пахом
Ok... пожалста простой примерru_alex писал(а):Поточнее бы:
Что значит:
MyRef создаю методами класса
где includе делаешь?
а вообще лучше код в студию, простейший, и точки вставки.
Код: Выделить всё
OMIT('_EndOfInclude_',_xRPTClassPresent_)
_xRPTClassPresent_ EQUATE(1)
!**********************************************************
MyClass1 CLASS,TYPE,MODULE('xMyClass.clw'),LINK('xMyClass.clw',_ABCLinkMode_), DLL(_ABCDllMode_)
!описание свойств/методов
Construct PROCEDURE()
Destruct PROCEDURE()
QMyClass2 &QueMyClass2
AddMyClass2 PROCEDURE()
ChooseMyClass2 PROCEDURE(LONG NElement)
END
MyClass2 CLASS,TYPE,MODULE('xMyClass.clw'),LINK('xMyClass.clw',_ABCLinkMode_), DLL(_ABCDllMode_)
!описание свойств/методов
END
QueMyClass2 QUEUE, TYPE
IClass &MyClass2
END
CurMyClass2 &MyClass2
_EndOfInclude_
Код: Выделить всё
MEMBER
MAP.
INCLUDE('xMyClass.inc'),ONCE
MyClass1.Construct PROCEDURE()
CODE
self.QMyClass2 &= new QueMyClass2
MyClass1.Destruct PROCEDURE()
CODE
! тут все мочим
MyClass1.AddMyClass2 PROCEDURE()
CODE
self.QMyClass2.IClass &= new MyClass2
ADD(self.QMyClass2)
MyClass1.ChooseMyClass2 PROCEDURE(LONG NElement)
GET(self.QMyClass2, NElement)
CurMyClass2&=self.QMyClass2.IClass
Код: Выделить всё
INCLUDE('xMyClass.inc'),ONCE
Код: Выделить всё
Local Data
MyC &MyClass1
CODE
MyC &= new MyClass1
MyC.AddMyClass2()
MyC.ChooseMyClass2(1)
!!!до этих пор все ok, а когда я обращаюсь к CurMyClass2 програма слетает
CurMyClass2.SomeProperty=...
dispose(MyC)
Код: Выделить всё
MyC.ChooseMyClass2(1)
if CurMyClass2 &= NULL then message('CurMyClass2 &= NULL').
Код: Выделить всё
! прототип - будем возвращать ссылку
ChooseMyClass2 PROCEDURE(LONG NElement),LONG
! код метода
MyClass1.ChooseMyClass2 PROCEDURE(LONG NElement)
code
GET(self.QMyClass2, NElement)
if errorcode() then message('get error').
return address(self.QMyClass2.IClass)
! и собственно сам вызов
CurMyClass2 &= MyC.ChooseMyClass2(1)
причина падения действительно очевидна...StillZero писал(а):из-за чего падает понятно
но причина лежит вне области моего пониманияКод: Выделить всё
MyC.ChooseMyClass2(1) if CurMyClass2 &= NULL then message('CurMyClass2 &= NULL').
Код: Выделить всё
MyClass1.ChooseMyClass2 PROCEDURE(LONG NElement)
GET(self.QMyClass2, NElement)
CurMyClass2&=self.QMyClass2.IClass
Message(CurMyClass2.SomeProperty)! все ok
спасибо за вариант...я уже прикидывал, что так можно сделать, но людям больше нравится MyClass1.ChooseMyClass2(1), чем CurMyClass2 &= MyC.ChooseMyClass2(1)...StillZero писал(а): можно обойти данный момент изменив метод ChooseMyClass2Код: Выделить всё
! прототип - будем возвращать ссылку ChooseMyClass2 PROCEDURE(LONG NElement),LONG ! код метода MyClass1.ChooseMyClass2 PROCEDURE(LONG NElement) code GET(self.QMyClass2, NElement) if errorcode() then message('get error'). return address(self.QMyClass2.IClass) ! и собственно сам вызов CurMyClass2 &= MyC.ChooseMyClass2(1)
Код: Выделить всё
GloRef &myClass
myClass.Constructor
CODE
GloRef &= SELF
Код: Выделить всё
GloRef &myClass,EXTERNAL
Спасибо за ответ... все действительно идет на ураAndrew Myalin писал(а):если мне надо какая то глобальная ссылка, я её декларирую в .CLW реализации типового класса, в конструкторе которого делаю присвоение:в APP я декларирую такую переменную какКод: Выделить всё
GloRef &myClass myClass.Constructor CODE GloRef &= SELF
всё, работа с GloRef идёт на ураКод: Выделить всё
GloRef &myClass,EXTERNAL
Такая схема не работает в Clarion5... когда делаю в app MyRef &= new(MyClass) программа слетаетiBAH писал(а):Спасибо за ответ... все действительно идет на ураAndrew Myalin писал(а):если мне надо какая то глобальная ссылка, я её декларирую в .CLW реализации типового класса, в конструкторе которого делаю присвоение:в APP я декларирую такую переменную какКод: Выделить всё
GloRef &myClass myClass.Constructor CODE GloRef &= SELF
всё, работа с GloRef идёт на ураКод: Выделить всё
GloRef &myClass,EXTERNAL
Можно и так, но у меня ссылки объявлены в clw...ru_alex писал(а):Если тебе не нужно видеть указатель MyRef в clw, в котором лежит реализация методов класса, то объяви его в основной APP проекта прямо в глобальных данных APP, в других как external. Должно работать, у меня работает на С5, С5.5, С6
все аналогично... однако GLORef в clw, если объявлять в *.inc то в случае, если метод класса делает GLORef&=SomeRef... в app он один фиг видит GLORef=NULL... поэтому объявление у меня GLORef &MyClass в clw, а в Global Data: GLORef &MyClass, EXTERNAL и все работало до тех пор пока меня не попросили перетащить класс в Clarion5 ... пользоваться классом вообще не дает... при любом объявлении типа MyC MyClass слетает напрочьru_alex писал(а):Тогда наверное проблема в том, как ты подвязываешь inc и clw.
У меня сейчас в рабочем проекте
MyClass.inc в нем объявление типа класса и GLORef - указатель на этот тип
MyClass.clw в нем реализация методов
include(MyClass.inc) в точку вставки ABC AfterGlobalInclude в GlobalEmbeds.
MyClass.clw в проектнике как External Source Files
все в APP GLORef видно в любой процедуре APP.
Неподходит тем, что, оказыватся ваще с классом в C5 работать невозможно... в предыдущем посте написал всеru_alex писал(а):Сейчас повнимательнее посмотрел код, у меня присвоение указателя идет в самой APP, так что наверное я поторопился с ответом.
Чем тебе не подходит вариант предложенный StillZero. По-моему здесь все корректно должно отрабатывать.