Wilmar C. Degobbi said:
Jack, thanks for the answer.
Please consider that I am only reading the lags, not writing.
If my actual conclusions is right, the lag read (*) not represents
the real time (in minutes, how you said) when the inputed
lag was in "%". When the inputed was in time unit, OK.
If this conclusion is right (I am confused...),
should be have a read "flag" p.ex., indicating the condition that
lag was inputed in "%" to possibility treating the number obtained ?
Or No ?
If you or somebody could help me I would apreciate.
(*) I am using:
.
.
Set Ativ_Selec = ActiveSelection.Tasks(1)
.
.
For each Ativ_pred in Ativ_Selec.TaskDependencies
.
Latencia = Ativ_pred.Lag
[and for testing typing the Latencia for differents predecessors]
.
Next Ativ_pred
Thanks,
Wilmar
Wilmar,
If I may interject. Unfortunately the lag property is not consistent in
the data it provides. This is one case where the value read using VBA IS
dependent on how lag was input by the user. The VBA help file says that
string values default to days while non-string values are in minutes.
I'm not sure what that really means because it doesn't appear consistent
with how it actually works in real lines of code. If lag is input as a
percentage, the lag property, when read using VBA, will be given as an
integer value of the percentage divided by 10. For example, if the lag
is 25%, the value will be 2. Not very useful in my opinion.
For all other lag entries (e.g. 5 days, 5 minutes), the value provided
will be in minutes. For example, 5 days will be 2400 minutes, assuming a
standard 8 hour work day.
In my opinion when the TaskDependencies object was added to the Project
object model, it was not done very well. When I need to obtain link
modifier information, I decode the predecessor text string. Indeed, it
takes more lines of code but once the decoding algorithm is developed,
it gives consistent results.
John
Project MVP