mirror of
https://github.com/wnayes/macutils.git
synced 2025-01-02 11:31:19 +00:00
926f4a694d
Some of these may not be needed, but none of them should be incorrect.
205 lines
3.4 KiB
C
205 lines
3.4 KiB
C
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include "../fileio/fileglob.h"
|
|
#include "masks.h"
|
|
#include "util.h"
|
|
|
|
#include <stdlib.h>
|
|
|
|
#define MACTIMOFFS 1904
|
|
|
|
static int mlength[] = {0, 31, 61, 92, 122, 153, 184, 214, 245, 275, 306, 337};
|
|
|
|
uint32_t get4(char *bp)
|
|
{
|
|
register int i;
|
|
int32_t value = 0;
|
|
|
|
for(i = 0; i < 4; i++) {
|
|
value <<= 8;
|
|
value |= (*bp & BYTEMASK);
|
|
bp++;
|
|
}
|
|
return value;
|
|
}
|
|
|
|
/* For if integers are stored wrong-endian. */
|
|
uint32_t get4i(char *bp)
|
|
{
|
|
register int i;
|
|
int32_t value = 0;
|
|
|
|
bp += 3;
|
|
for (i = 0; i < 4; i++) {
|
|
value <<= 8;
|
|
value |= (*bp & BYTEMASK);
|
|
bp--;
|
|
}
|
|
return value;
|
|
}
|
|
|
|
uint32_t get2(char *bp)
|
|
{
|
|
register int i;
|
|
int value = 0;
|
|
|
|
for(i = 0; i < 2; i++) {
|
|
value <<= 8;
|
|
value |= (*bp & BYTEMASK);
|
|
bp++;
|
|
}
|
|
return value;
|
|
}
|
|
|
|
/* For if integers are stored wrong-endian. */
|
|
uint32_t get2i(char *bp)
|
|
{
|
|
register int i;
|
|
int32_t value = 0;
|
|
|
|
bp += 1;
|
|
for(i = 0; i < 2; i++) {
|
|
value <<= 8;
|
|
value |= (*bp & BYTEMASK);
|
|
bp--;
|
|
}
|
|
return value;
|
|
}
|
|
|
|
unsigned char
|
|
getb (FILE *fp)
|
|
{
|
|
int c;
|
|
|
|
bytes_read += 1;
|
|
c = getc(fp);
|
|
if(c == EOF) {
|
|
(void)fprintf(stderr, "\nPremature EOF\n");
|
|
exit(1);
|
|
}
|
|
return c & BYTEMASK;
|
|
}
|
|
|
|
void
|
|
copy (char *d, char *s, int n)
|
|
{
|
|
while(--n >= 0) {
|
|
*d++ = *s++;
|
|
}
|
|
}
|
|
|
|
int
|
|
do_query (void)
|
|
{
|
|
char *tp, temp[10];
|
|
|
|
(void)fprintf(stderr, "? ");
|
|
(void) fflush(stdout);
|
|
(void) read(2, temp, sizeof(temp));
|
|
temp[sizeof(temp) - 1] = 0;
|
|
tp = temp;
|
|
while(*tp != 0) {
|
|
if(*tp == 'y' || *tp == 'Y') {
|
|
return 1;
|
|
} else {
|
|
tp++;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
void
|
|
put4 (char *dest, uint32_t value)
|
|
{
|
|
*dest++ = (value >> 24) & BYTEMASK;
|
|
*dest++ = (value >> 16) & BYTEMASK;
|
|
*dest++ = (value >> 8) & BYTEMASK;
|
|
*dest++ = value & BYTEMASK;
|
|
}
|
|
|
|
void
|
|
put2 (char *dest, uint32_t value)
|
|
{
|
|
*dest++ = (value >> 8) & BYTEMASK;
|
|
*dest++ = value & BYTEMASK;
|
|
}
|
|
|
|
void
|
|
do_indent (int indent)
|
|
{
|
|
int i;
|
|
|
|
for(i = 0; i < indent; i++) {
|
|
(void)fputc(' ', stderr);
|
|
}
|
|
}
|
|
|
|
real_time
|
|
set_time (int year, int month, int day, int hours, int minutes, int seconds)
|
|
{
|
|
real_time toset;
|
|
|
|
toset.year = year;
|
|
toset.month = month;
|
|
toset.day = day;
|
|
toset.hours = hours;
|
|
toset.minutes = minutes;
|
|
toset.seconds = seconds;
|
|
return toset;
|
|
}
|
|
|
|
uint32_t
|
|
tomactime (real_time time)
|
|
{
|
|
int32_t accum;
|
|
int year;
|
|
|
|
accum = time.month - 3;
|
|
year = time.year;
|
|
if(accum < 0) {
|
|
accum += 12;
|
|
year--;
|
|
}
|
|
accum = time.day + mlength[accum] + 59;
|
|
accum += (year - MACTIMOFFS) * 365 + year / 4 - MACTIMOFFS / 4;
|
|
accum = ((accum * 24 + time.hours) * 60 + time.minutes) * 60 + time.seconds;
|
|
return (unsigned)accum;
|
|
}
|
|
|
|
real_time
|
|
frommactime (uint32_t accum)
|
|
{
|
|
int32_t tmp1, tmp2;
|
|
real_time time;
|
|
|
|
time.seconds = tmp1 = accum % 60;
|
|
accum /= 60;
|
|
time.minutes = tmp1 = accum % 60;
|
|
accum /= 60;
|
|
time.hours = tmp1 = accum % 24;
|
|
accum /= 24;
|
|
tmp1 = (int32_t)accum - 60;
|
|
tmp2 = tmp1 % 1461;
|
|
if(tmp2 < 0) {
|
|
tmp2 += 1461;
|
|
}
|
|
tmp1 = (tmp1 - tmp2) / 1461;
|
|
time.year = tmp1 * 4;
|
|
tmp1 = tmp2 / 365;
|
|
if(tmp1 > 3) {
|
|
tmp1 = 3;
|
|
}
|
|
time.year += tmp1 + MACTIMOFFS;
|
|
tmp2 -= tmp1 * 365;
|
|
tmp1 = 12;
|
|
while(mlength[--tmp1] > tmp2);
|
|
time.day = tmp2 + 1 - mlength[tmp1];
|
|
time.month = tmp1 + 3;
|
|
if(tmp1 > 9) {
|
|
time.month = tmp1 - 9;
|
|
time.year++;
|
|
}
|
|
return time;
|
|
}
|
|
|