121 lines
3.9 KiB
Plaintext
121 lines
3.9 KiB
Plaintext
|
--- libatalk/adouble/ad_open.c.orig Thu Jul 9 23:13:58 1998
|
||
|
+++ libatalk/adouble/ad_open.c Wed Nov 10 15:10:13 1999
|
||
|
@@ -28,7 +28,7 @@
|
||
|
#include <netatalk/endian.h>
|
||
|
#include <sys/syslog.h>
|
||
|
#include <atalk/adouble.h>
|
||
|
-#include <strings.h>
|
||
|
+#include <string.h>
|
||
|
#include <fcntl.h>
|
||
|
#include <unistd.h>
|
||
|
|
||
|
@@ -50,16 +50,16 @@
|
||
|
char c, *slash;
|
||
|
|
||
|
if ( adflags & ADFLAGS_DIR ) {
|
||
|
- strcpy( pathbuf, path );
|
||
|
+ (void)strlcpy( pathbuf, path, sizeof( pathbuf ) );
|
||
|
if ( *path != '\0' ) {
|
||
|
strcat( pathbuf, "/" );
|
||
|
}
|
||
|
slash = ".Parent";
|
||
|
} else {
|
||
|
- if (( slash = rindex( path, '/' )) != NULL ) {
|
||
|
+ if (( slash = strrchr( path, '/' )) != NULL ) {
|
||
|
c = *++slash;
|
||
|
*slash = '\0';
|
||
|
- strcpy( pathbuf, path );
|
||
|
+ (void)strlcpy( pathbuf, path, sizeof ( pathbuf ) );
|
||
|
*slash = c;
|
||
|
} else {
|
||
|
pathbuf[ 0 ] = '\0';
|
||
|
@@ -102,8 +102,8 @@
|
||
|
* (path or subdirectory name) to get the name we want to stat.
|
||
|
* For a path which is just a filename, use "." instead.
|
||
|
*/
|
||
|
- strcpy( modebuf, path );
|
||
|
- if (( slash = rindex( modebuf, '/' )) != NULL ) {
|
||
|
+ (void)strlcpy( modebuf, path, sizeof (modebuf) );
|
||
|
+ if (( slash = strrchr( modebuf, '/' )) != NULL ) {
|
||
|
*slash = '\0'; /* remove pathname component */
|
||
|
} else {
|
||
|
modebuf[0] = '.'; /* use current directory */
|
||
|
@@ -132,6 +132,7 @@
|
||
|
* It's not possible to open the header file O_RDONLY -- the read
|
||
|
* will fail and return an error.
|
||
|
*/
|
||
|
+int
|
||
|
ad_open( path, adflags, oflags, mode, ad )
|
||
|
char *path;
|
||
|
int adflags, oflags, mode;
|
||
|
@@ -171,7 +172,7 @@
|
||
|
* mkdir it.
|
||
|
*/
|
||
|
if ( errno == ENOENT ) {
|
||
|
- if (( slash = rindex( ad_p, '/' )) == NULL ) {
|
||
|
+ if (( slash = strrchr( ad_p, '/' )) == NULL ) {
|
||
|
ad_close( ad, adflags );
|
||
|
return( -1 );
|
||
|
}
|
||
|
@@ -206,12 +207,12 @@
|
||
|
* This is a new adouble header file. Initialize the structure,
|
||
|
* instead of reading it.
|
||
|
*/
|
||
|
- bzero( (char *)ad->ad_eid, sizeof( ad->ad_eid ));
|
||
|
+ memset( (char *)ad->ad_eid, 0, sizeof( ad->ad_eid ));
|
||
|
if ( ad->ad_hf.adf_flags & ( O_TRUNC | O_CREAT )) {
|
||
|
ad->ad_magic = AD_MAGIC;
|
||
|
ad->ad_version = AD_VERSION;
|
||
|
- bzero( ad->ad_homefs, sizeof( ad->ad_homefs ));
|
||
|
- bzero( ad->ad_data, sizeof( ad->ad_data ));
|
||
|
+ memset( ad->ad_homefs, 0, sizeof( ad->ad_homefs ));
|
||
|
+ memset( ad->ad_data, 0, sizeof( ad->ad_data ));
|
||
|
|
||
|
ad->ad_eid[ ADEID_RFORK ].ade_off = ADEDOFF_RFORK;
|
||
|
ad->ad_eid[ ADEID_RFORK ].ade_len = ADEDLEN_RFORK;
|
||
|
@@ -237,6 +238,7 @@
|
||
|
return( 0 );
|
||
|
}
|
||
|
|
||
|
+int
|
||
|
ad_refresh( ad )
|
||
|
struct adouble *ad;
|
||
|
{
|
||
|
@@ -271,15 +273,15 @@
|
||
|
* we know that magic, version, homefs, and nentries are less
|
||
|
* than data, so we don't check whether we exceed end.
|
||
|
*/
|
||
|
- bcopy( buf, (char *)&ad->ad_magic, sizeof( ad->ad_magic ));
|
||
|
+ memcpy( (char *)&ad->ad_magic, buf, sizeof( ad->ad_magic ));
|
||
|
ad->ad_magic = ntohl( ad->ad_magic );
|
||
|
buf += sizeof( ad->ad_magic );
|
||
|
- bcopy( buf, (char *)&ad->ad_version, sizeof( ad->ad_version ));
|
||
|
+ memcpy( (char *)&ad->ad_version, buf, sizeof( ad->ad_version ));
|
||
|
ad->ad_version = ntohl( ad->ad_version );
|
||
|
buf += sizeof( ad->ad_version );
|
||
|
- bcopy( buf, ad->ad_homefs, sizeof( ad->ad_homefs ));
|
||
|
+ memcpy( ad->ad_homefs, buf, sizeof( ad->ad_homefs ));
|
||
|
buf += sizeof( ad->ad_homefs );
|
||
|
- bcopy( buf, (char *)&nentries, sizeof( nentries ));
|
||
|
+ memcpy( (char *)&nentries, buf, sizeof( nentries ));
|
||
|
nentries = ntohs( nentries );
|
||
|
buf += sizeof( nentries );
|
||
|
|
||
|
@@ -289,13 +291,13 @@
|
||
|
return( -1 );
|
||
|
}
|
||
|
|
||
|
- bcopy( buf, (char *)&eid, sizeof( eid ));
|
||
|
+ memcpy( (char *)&eid, buf, sizeof( eid ));
|
||
|
eid = ntohl( eid );
|
||
|
buf += sizeof( eid );
|
||
|
- bcopy( buf, (char *)&off, sizeof( off ));
|
||
|
+ memcpy( (char *)&off, buf, sizeof( off ));
|
||
|
off = ntohl( off );
|
||
|
buf += sizeof( off );
|
||
|
- bcopy( buf, (char *)&len, sizeof( len ));
|
||
|
+ memcpy( (char *)&len, buf, sizeof( len ));
|
||
|
len = ntohl( len );
|
||
|
buf += sizeof( len );
|
||
|
|