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
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
|
If you read this file _as_is_, just ignore the funny characters you
see. It is written in the POD format (see pod/perlpod.pod) which is
specifically designed to be readable as is.
=head1 Name
Perl for NetWare
=head1 Description
This file gives instructions for building Perl 5.7 and above, and also
Perl modules for NetWare. Before you start, you may want to read the
README file found in the top level directory into which the Perl source
code distribution was extracted. Make sure you read and understand
the terms under which the software is being distributed.
=head1 Build
This section describes the steps to be performed to build a Perl NLM
and other associated NLMs.
=head2 Tools & SDK
The build requires CodeWarrior compiler and linker. In addition,
the "NetWare SDK", "NLM & NetWare Libraries for C" and
"NetWare Server Protocol Libraries for C", all available at
L<http://developer.novell.com/ndk/>, are also required.
Microsoft Visual C++ version 4.2 or later is also required.
=head2 Setup
The build process is dependent on the location of the NetWare SDK.
Once the Tools & SDK are installed, the build environment has to
be setup. The following batch files setup the environment.
=over 4
=item *
If you want to build with Default settings you can follow the One step
process given below to create the default Build Environment.
=item SetNWDef.bat
The Execution of this file takes 2 parameters as input.The first being
the NetWare SDK path, Second being the path for CodeWarrior Compiler &
other tools. Execution of this file sets the Build type to
Release(default) , the NetWare SDK path, path for Compiler & other
tools.
=item Custom Build Environment
If you want to change the default settings you could do so by
following the steps listed below.
=item Buildtype.bat
This sets the build type to release or debug.
=item *
Example: Typing "buildtype d on" at the command prompt causes the
buildtype to be set to Debug type. Typing "buildtype r" at the
command prompt sets it to Release Build type.
=item SetNWBld.bat
This sets the NetWare SDK path, path to Compiler & other tools.
These batch files are under NetWare\bat folder. These batch files
call a couple of other batch files to setup the environment. Invoking
the batch file with I</now> will show the current settings and I</h>
or I</?> gives the usage help.
=back
=head2 Make
The make process runs only under WinNT shell. The NetWare makefile is
located under the NetWare folder. This makes use of miniperl.exe to
run some of the Perl scripts. To create miniperl.exe, first set the
required paths for Visual c++ compilier (specify vcvars32 location) at
the command prompt. Then run nmake from win32 folder through WinNT
command prompt. The build process can be stopped after miniperl.exe
is created. Then run nmake from NetWare folder through WinNT command
prompt.
Currently the following two build types are tested on NetWare
=over 4
=item *
USE_MULTI, USE_ITHREADS & USE_IMP_SYS defined
=item *
USE_MULTI & USE_IMP_SYS defined and USE_ITHREADS not defined
=back
=head2 Interpreter
Once miniperl.exe creation is over, run nmake from the NetWare folder.
This will build the Perl interpreter for NetWare as I<perl.nlm>.
This is copied under the I<Release> folder if you are doing
a release build, else will be copied under I<Debug> folder for debug builds.
=head2 Extensions
The make process also creates the Perl extensions as I<<Extension>.nlm>
=head1 Install
To install NetWare Perl onto a NetWare server, first map the Sys
volume of a NetWare server to I<i:>. This is because the makefile by
default sets the drive letter to I<i:>. Type I<nmake nwinstall> from
NetWare folder on a WinNT command prompt. This will copy the binaries
and module files onto the NetWare server under I<sys:\Perl>
folder. The Perl interpreter, I<perl.nlm>, is copied under
I<sys:\perl\system> folder. Copy this to I<sys:\system> folder.
Example: At the command prompt Type "nmake nwinstall". This will
install NetWare Perl on the NetWare Server. Similarly if you type
"nmake install", This will cause the binaries to be installed on the
local machine. (Typically under the c:\perl folder)
=head1 Build new extensions
To build extensions other than standard extensions, NetWare Perl has
to be installed on Windows along with Windows Perl. The Perl for
Windows can be either downloaded from the CPAN site and built using
the sources, or the binaries can be directly downloaded from the
ActiveState site. Installation can be done by invoking I<nmake
install> from the NetWare folder on a WinNT command prompt after
building NetWare Perl by following steps given above. This will copy
all the *.pm files and other required files. Documentation files are
not copied.Thus one must first install Windows Perl, Then install
NetWare Perl.
Once this is done, do the following to build any extension:
=over 4
=item *
Change to the extension directory where its source files are present.
=item *
Run the following command at the command prompt:
perl -II<path to NetWare lib dir> -II<path to lib> Makefile.pl
Example:
perl -Ic:/perl/5.7.2/lib/NetWare-x86-multi-thread -Ic:\perl\5.7.2\lib MakeFile.pl
=item *
nmake
=item *
nmake install
Install will copy the files into the Windows machine where NetWare
Perl is installed and these files may have to be copied to the NetWare
server manually. Alternatively, pass I<INSTALLSITELIB=i:\perl\lib> as
an input to makefile.pl above. Here I<i:> is the mapped drive to the
sys: volume of the server where Perl on NetWare is installed. Now
typing I<nmake install>, will copy the files onto the NetWare server.
Example: You can execute the following on the command prompt.
perl -Ic:/perl/5.7.2/lib/NetWare-x86-multi-thread -Ic:\perl\5.7.2\lib MakeFile.pl
INSTALLSITELIB=i:\perl\lib
=item *
Note: Some modules downloaded from CPAN may require NetWare related API
in order to build on NetWare.Other modules may however build smoothly with or
without minor changes depending on the type of module.
=back
=head1 Acknowledgements
The makefile for Win32 is used as a reference to create the makefile
for NetWare. Also, the make process for NetWare port uses
miniperl.exe to run scripts during the make and installation process.
=head1 Authors
Anantha Kesari H Y (hyanantha@novell.com)
Aditya C (caditya@novell.com)
=head1 Date
=over 4
=item *
Created - 18 Jan 2001
=item *
Modified - 25 June 2001
=item *
Modified - 13 July 2001
=item *
Modified - 8 May 2002
=back
|