• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 755
  • Last Modified:

Access violation on a form in Windows 2000

I have a problem (only under Win2000, works on NT) where I have a form where the parent property is assigned to a panel of another form and it blows up with an access violation.  This problem does not happen on any other forms done in the same way using the same base create method, any ideas?

Ziggy
0
Ziggy500
Asked:
Ziggy500
  • 5
  • 3
  • 2
  • +3
1 Solution
 
GloomyFriarCommented:
>I have a form where the parent property is assigned to a panel of another form
Why do you need it?
0
 
Ziggy500Author Commented:
It is needed as the application is based on a framework where we snap in various forms to present information as the user travels around the application.

As I said, it is working in all instances except for one form that causes the access violation...

0
 
kretzschmarCommented:
well,
i used this kind of embedded forms also often,
and got never an access violation

could you more specific about the access violation
and when it is raised?

meikl ;-)
0
Cloud Class® Course: Python 3 Fundamentals

This course will teach participants about installing and configuring Python, syntax, importing, statements, types, strings, booleans, files, lists, tuples, comprehensions, functions, and classes.

 
Ziggy500Author Commented:
The violation is being raised when the child form was being created. It has been narrowed down through process of eliminating controls to a combo control on the form. This control appears on the other forms as well so still not sure what is going on. We thought setting OldCreationOrder to false solved the problem but the problem is back after one successful open.

Ziggy
0
 
kretzschmarCommented:
this combo-control is a standard TComboBox or a Thirdparty?
- if standard, how are the items populated or are they static?
- if thirdparty, which?
0
 
Ziggy500Author Commented:
It is an in house combo, it appears the problem is arising when the combo allows blank items. When I changed the combo boxes on other forms to allow blanks they also blow up. Perhaps in windows 2000 the messaging is not in the order I am expecting and the list is not created when I try to put a blank item in it? If I set allow blanks to false it works fine.

Code:
procedure TLookupListControl.RegisterList(List: TStrings; OnLoadEvent: TNotifyEvent; AllowBlankItem: boolean);
Var I: Integer;
begin
  For I := 0 to RegList.Count-1 do
    if List = TRegItem(RegList.Items[I]).List then break;
 
  if (I = RegList.Count) or (RegList.Count = 0) then begin
    RegList.Add(TRegItem.Create(List, OnLoadEvent, AllowBlankItem));
    end; // if
 
  List.BeginUpdate;
  try
    List.Assign(FList);  // load strings here
 
    // if a blank item is allowed then add it.
    If AllowBlankItem then
      List.InsertObject(0, '', TLPList.Create(Null, False));
  finally
    List.EndUpdate;
    end; // R.P.B.
end; // RegisterList

Zigster
0
 
Ziggy500Author Commented:
Actual error:

Access violation at address 77F8C7A4 in module 'ntdll.dll'. Write of address 00405201
0
 
Colin_DawsonCommented:
How about a quick botch.

    If AllowBlankItem then
      List.InsertObject(0, ' ', TLPList.Create(Null, False));

Put a space in the Item.

The reason that I'm saying this is that the TStrings that is behind the Items, doesn't actually create a place holder for the object when the text for that line is set to ''. - It doesn't do this to save memory.  The same is true for cells on a TStringGrid too!
0
 
Colin_DawsonCommented:
I'm glad that old chestnut still works.

Thanks for the points.
0
 
Ziggy500Author Commented:
I was looking in all the wrong places, such a simple solution!

Odd that it only pops its head up on windows 2000 too...

Thanks alot!

0
 
joinedCommented:
You can try EurekaLog (http://www.eurekalog.com).

EurekaLog is an add-in tool that gives to your application (GUI, Console, Web, etc.) the ability to catch every exception (even those raised by memory leaks) and every infinite-loops/deadlock bugs, generating a detailed log of call stack (with unit, class, method and line #), showing and sending it back to you via email.
--
Best regards...

Fabio Dell'Aria.
0
 
simonjeffsCommented:
Fantastic !!!!

I can believe my luck: I entered "77f8c7a4 ntdll.dll" into google and it displayed this !!!!

I can't believe it is windows 2000 specific.

Solved the problem very quickly and kept customer happy.
0
 
Colin_DawsonCommented:
hehe, it lucky for you that it is an OS problem.  Otherwise that address would have been about as much use as a chocolate teapot :-)

Colin.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Cloud Class® Course: Microsoft Exchange Server

The MCTS: Microsoft Exchange Server 2010 certification validates your skills in supporting the maintenance and administration of the Exchange servers in an enterprise environment. Learn everything you need to know with this course.

  • 5
  • 3
  • 2
  • +3
Tackle projects and never again get stuck behind a technical roadblock.
Join Now