aboutsummaryrefslogtreecommitdiff
path: root/src/mem/ft_memcmp.c
blob: c61ca9aca5cdf3b8adceb435a42999fd707644c8 (plain)
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
/* ************************************************************************** */
/*                                                                            */
/*                                                        :::      ::::::::   */
/*   ft_memcmp.c                                        :+:      :+:    :+:   */
/*                                                    +:+ +:+         +:+     */
/*   By: cacharle <marvin@42.fr>                    +#+  +:+       +#+        */
/*                                                +#+#+#+#+#+   +#+           */
/*   Created: 2019/10/07 09:56:44 by cacharle          #+#    #+#             */
/*   Updated: 2020/01/17 10:54:15 by cacharle         ###   ########.fr       */
/*                                                                            */
/* ************************************************************************** */

#include "libft.h"
#include "libft_mem.h"

int	ft_memcmp(const void *s1, const void *s2, size_t n)
{
	while ((n & 0b111) != 0)
	{
		n--;
		if (*(uint8_t*)s1 != *(uint8_t*)s2)
			return (*(uint8_t*)s1 - *(uint8_t*)s2);
		s1++;
		s2++;
	}
	while (n > 0)
	{
		if (*(uint64_t*)s1 != *(uint64_t*)s2)
		{
			if (((uint8_t*)s1)[0] != ((uint8_t*)s2)[0])
				return (((uint8_t*)s1)[0] - ((uint8_t*)s2)[0]);
			if (((uint8_t*)s1)[1] != ((uint8_t*)s2)[1])
				return (((uint8_t*)s1)[1] - ((uint8_t*)s2)[1]);
			if (((uint8_t*)s1)[2] != ((uint8_t*)s2)[2])
				return (((uint8_t*)s1)[2] - ((uint8_t*)s2)[2]);
			if (((uint8_t*)s1)[3] != ((uint8_t*)s2)[3])
				return (((uint8_t*)s1)[3] - ((uint8_t*)s2)[3]);
			if (((uint8_t*)s1)[4] != ((uint8_t*)s2)[4])
				return (((uint8_t*)s1)[4] - ((uint8_t*)s2)[4]);
			if (((uint8_t*)s1)[5] != ((uint8_t*)s2)[5])
				return (((uint8_t*)s1)[5] - ((uint8_t*)s2)[5]);
			if (((uint8_t*)s1)[6] != ((uint8_t*)s2)[6])
				return (((uint8_t*)s1)[6] - ((uint8_t*)s2)[6]);
			if (((uint8_t*)s1)[7] != ((uint8_t*)s2)[7])
				return (((uint8_t*)s1)[7] - ((uint8_t*)s2)[7]);
		}
		n -= 8;
		s1 += 8;
		s2 += 8;
	}
	return (0);
}