Solved

MSComm Timeout

Posted on 2003-12-02
5
944 Views
Last Modified: 2008-02-01
Hi.

I have an VBA application that talks to a serial device, which acts as a converter and talks to another device. I would like a way for the application to timeout if it doesn't recieve a response in a certain period of time.

The trouble with the timeouts built in to mscomm (that I know of) is that they will only detect if the serial device is there when the app is transmitting, but I need to know if the third device is not responding.

Thanks and sorry if I wasn't clear enough.
0
Comment
Question by:Dormouse31
  • 2
5 Comments
 
LVL 1

Accepted Solution

by:
mazfar earned 125 total points
ID: 9862756
I dont know if it answers your question but its a kind of work around.

Put a timer control and set it to whatever is your max waiting time at the port. Whenever you do a serial port open, activate the timer. When the specified interval passes, the timer event will fire and you can close the port (or do whatever u want to here). In the MSCOMM oncomm event, reset the counter (so as whenever you receive anything timer starts again).

I hope I was able to explain my solution.

Ciao
0
 

Author Comment

by:Dormouse31
ID: 9863085
I thought of the timer idea, but there isn't a timer in the VBA toolbox. How do you use a timer in a VBA App?
0
 
LVL 1

Expert Comment

by:mazfar
ID: 9869740
Check this link to use timer API to replicate timer functionality in VBA.

http://www.developerfusion.com/show/1090/

Have a nice day.
0
 
LVL 29

Expert Comment

by:leonstryker
ID: 10212185
No comment has been added lately, so it's time to clean up this TA.
I will leave a recommendation in the Cleanup topic area that this question is:

Answered mazfar
 
Please leave any comments here within the next seven days.

PLEASE DO NOT ACCEPT THIS COMMENT AS AN ANSWER!

leonstryker
EE Cleanup Volunteer
0

Featured Post

ScreenConnect 6.0 Free Trial

At ScreenConnect, partner feedback doesn't fall on deaf ears. We collected partner suggestions off of their virtual wish list and transformed them into one game-changing release: ScreenConnect 6.0. Explore all of the extras and enhancements for yourself!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

There are many ways to remove duplicate entries in an SQL or Access database. Most make you temporarily insert an ID field, make a temp table and copy data back and forth, and/or are slow. Here is an easy way in VB6 using ADO to remove duplicate row…
Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

809 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question