openbsd-ports/net/netatalk/patches/patch-libadouble-adopenc

121 lines
3.9 KiB
Plaintext
Raw Normal View History

--- 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 );