-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathcomm-w32.ch
60 lines (50 loc) · 2.57 KB
/
comm-w32.ch
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
This is the change file for CWEB's COMMON under Win32
(Contributed by Fabrice Popineau, February 2002 <[email protected]>)
The Microsoft C compiler included in Visual Studio allows for different
parameter passing conventions than the standard one. This is actually
specified with the Intel IA32 architecture. There exist three
calling conventions under the IA32 architecture as defined by Intel.
One of them is the standard C calling convention: Parameters are passed on
the stack, calling function is responsible to unstack arguments. Names are
decorated with a prefixed underscore. It is called the __cdecl convention.
Another calling convention is the __fastcall convention. The first two 32bits
arguments are passed on the stack. The called function is responsible for
stack maintenance. Names are decorated with an @ sign as prefix, and another
@ sign followed by the size of the arguments as suffix.
The third one is the __stdcall convention and is basically the Pascal calling
convention.
Using the __fastcall convention is usually faster on Intel architecture. Names
are decorated because obviously a __cdecl function can't behave the same way
as a __fastcall one of the same prototype. So the new full prototype includes
the keyword __cdecl or __fastcall. A compiler option allows to compile all
functions using one or the other calling convention. If you compile using
__fastcall, then you are bound to explicitly declare a few functions as
__cdecl : the ones that are passed to the C library (like function pointers
for qsort() or signal()) or functions that replace functions from the C
library, because the standard headers have a __cdecl prototype for these
functions. Also, you cannot declare a library function without giving it the
exact prototype used in the library headers files. So you'd better use the
header files to be safe.
Admittedly, this is not vital for cweb, except that I build the whole texlive
set of programs using the __fastcall convention.
@x section 11
extern boolean names_match(name_pointer,const char *,size_t,eight_bits);
@y
extern boolean __cdecl names_match(name_pointer,const char *,size_t,eight_bits);
@z
@x section 75
An omitted change file argument means that |"/dev/null"| should be used,
@y
An omitted change file argument means that |"NUL"| should be used,
@z
@x section 75
strcpy(change_file_name,"/dev/null");
@y
strcpy(change_file_name,"NUL");
@z
@x section 75 (this change copied from comm-bs.ch, July 94)
else if (*s=='/') dot_pos=NULL,name_pos=++s;
@y
else if (*s == ':' || *s == '\\' || *s == '/')
dot_pos=NULL,name_pos=++s;
@z