I have an application that runs on a device that is not connected to the internet. The OS is Windows XP. There're C++ module and Java module that interact over a socket. The Java part needs to get a file from the C++ part according to its date and time. When DST switch arrived they stopped working. It seems that the C++ ignores DST because Windows has not downloaded the yearly DST update, while Java handles DST according to some internal table it has. The device I'm programming has to be able to run continuously, disconnected from the net and in different countries. My question is: how can I make both Java and C++ ignore external updates and operate according to some pre-defined DST table.
Do you have to use a time representation that is sensitive to DST? You could use Unix time (which is probably the one I would go with), TAI, or any other time-since-[some epoch] systems, and not have to worry about things like daylight savings or leap-seconds.
I would suggest you use GMT+0 to record all date and only adjust the time when you display it.
Encode the date as a string which includes timezone information (ISO 8601 is the most complete standard for this). Use a good framework for parsing to/from the format on each side. Boost (C++) and Joda (Java) provide excellent support for this.
Epoch time will not work for you since it does not represent time zone.
If you need to adapt the timezone for doing centralized work with it then standardize on UTC, and allow the client to adapt the date/time to its locale for display purposes or for local manipulations. Otherwise just store/retrieve the date/time in the local timezone if all manipulations and display are done in the local timezone.