File: PsychVersioning.c

package info (click to toggle)
psychtoolbox-3 3.0.19.14.dfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 86,796 kB
  • sloc: ansic: 176,245; cpp: 20,103; objc: 5,393; sh: 2,753; python: 1,397; php: 384; makefile: 193; java: 113
file content (142 lines) | stat: -rw-r--r-- 4,482 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
/*
  PsychToolbox2/Source/Common/Base/PsychVersioning.c		
    
  AUTHORS:
  Allen.Ingling@nyu.edu		awi 
  
  PLATFORMS:	This file should compile on all platforms.
    

  HISTORY:
  3/13/03  awi		Created. 
  
  DESCRIPTION:
  
  
 
  
*/


#include "Psych.h"


/*
    PsychGetBuildDate()

-This function gurantees that the date stamp stays constant thoughout the compile, though the __DATE__ macro might do that anyway.  Descriptions of __DATE__ which I can find do not specify if it does, and it could depend on the implementation.

-It All references to the date macro should be made through PsychGetBuildDate() because then we can refresh any time macro references within all
source files by recompiling only this one file.  Otherwise, we would either do an incremental build, which would not update the date, or a 
a clean build, which recompiles all files and takes forever.  
*/
char *PsychGetBuildDate(void)
{
    static char buildDate[]=__DATE__;
    
    return(buildDate);
}

/*
    PsychGetBuildTime()

-This function gurantees that the time stamp stays constant thoughout the compile, though the __TIME__ macro might do that anyway.  Descriptions __TIME__ which I can find do not specify if it does, and it could depend on the implementation.

-It All references to the time macro should be made through PsychGetBuildDate() because then we can refresh any time macro references within all
source files by recompiling only this one file.  Otherwise, we would either do an incremental build, which would not update the date, or a 
a clean build, which recompiles all files and takes forever.

*/
char *PsychGetBuildTime(void)
{
    static char buildTime[]=__TIME__;
    
    return(buildTime);
}

/*
    PsychGetBuildNumber()
    
    Returns a unique number with each build.  
*/
int PsychGetBuildNumber(void)
{
    int year, month, day, hour, minute, second;
    const char *buildDateStr, *buildTimeStr;     //"Feb 12 1996"  //"23:59:01"
    char monthStr[10];   //gcc just gives 3-letter abbr. but we don't know about all compilers".  
    char *monthNames[]={"Jan", "Feb", "Mar", "Apr", "May",  "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"}; 
    static int buildNumber;
    static psych_bool firstTime=TRUE;
    
    
    if(firstTime){
        //first scan
        buildDateStr=PsychGetBuildDate();
        buildTimeStr=PsychGetBuildTime();
        sscanf(buildTimeStr,"%d:%d:%d",&hour,&minute,&second);  //make sure this works with numbers beginning with "0".  
        sscanf(buildDateStr,"%s %d %d", monthStr, &day, &year);
        for(month=0;month< 12;month++){
            if(!strncmp(monthNames[month], monthStr,3)) 
                break;
            else if(month==11)
                PsychErrorExitMsg(PsychError_internal, "failed to identify the macro constant specifying the month");
        } 
        buildNumber=second + minute*60 + hour *60*60 + day*24*60*60 + month*31*24*60*60 + (year - 2003)*12*31*24*60*60; 
        firstTime=FALSE;
    }
    return(buildNumber);
 
}

/*
    PsychGetVersionString()
    
    The version string has form major.minor.build.  
*/
char *PsychGetVersionString(void)
{
    #define MAX_VERSION_STRING_LENGTH 100
    static char versionString[MAX_VERSION_STRING_LENGTH];
    static psych_bool firstTime=TRUE;
    int buildNumber;
    
    if(firstTime){
        buildNumber=PsychGetBuildNumber();
        sprintf(versionString, "%d.%d.%d.%d", PSYCHTOOLBOX_MAJOR_VERSION, PSYCHTOOLBOX_MINOR_VERSION,  PSYCHTOOLBOX_POINT_VERSION, buildNumber);
        firstTime=FALSE;
    }
    return(versionString);
}


/* PsychGetMajorVersionNumber()

	Get the major version number of the Psychtoolbox.  For the time being we just read it from a 
	macro within the PsychSource but eventually it should be read from the Contents.m file at run time because
	that follows the policy of having one canonical define from which all references are derived. That's better
	than keeping multiple copies in sync, one in contents .m and one in the source.  
*/
int PsychGetMajorVersionNumber(void)
{
	return(PSYCHTOOLBOX_MAJOR_VERSION);
}


/* PsychGetMinorVersionNumber()

	Get the minor version number of the Psychtoolbox.  See  PsychGetMajorVersionNumber. 
*/
int PsychGetMinorVersionNumber(void)
{
	return(PSYCHTOOLBOX_MINOR_VERSION);
}


/* PsychGetPointVersionNumber()

	Get the minor version number of the Psychtoolbox.  See  PsychGetMajorVersionNumber. 
*/
int PsychGetPointVersionNumber(void)
{
	return(PSYCHTOOLBOX_POINT_VERSION);
}