/*
- * Copyright (C) 1996-2015 The Squid Software Foundation and contributors
+ * Copyright (C) 1996-2017 The Squid Software Foundation and contributors
*
* Squid software is distributed under GPLv2+ license and includes
* contributions from numerous individuals and organizations.
/* DEBUG: section 68 HTTP Content-Range Header */
#include "squid.h"
+#include "base/Packable.h"
#include "Debug.h"
#include "enums.h"
#include "HttpHdrContRange.h"
}
static void
-httpHdrRangeRespSpecPackInto(const HttpHdrRangeSpec * spec, Packer * p)
+httpHdrRangeRespSpecPackInto(const HttpHdrRangeSpec * spec, Packable * p)
{
/* Ensure typecast is safe */
assert (spec->length >= 0);
if (!known_spec(spec->offset) || !known_spec(spec->length))
- packerPrintf(p, "*");
+ p->append("*", 1);
else
- packerPrintf(p, "bytes %" PRId64 "-%" PRId64,
- spec->offset, spec->offset + spec->length - 1);
+ p->appendf("bytes %" PRId64 "-%" PRId64, spec->offset, spec->offset + spec->length - 1);
}
/*
HttpHdrContRange *
httpHdrContRangeCreate(void)
{
- HttpHdrContRange *r = (HttpHdrContRange *)memAllocate(MEM_HTTP_HDR_CONTENT_RANGE);
+ HttpHdrContRange *r = new HttpHdrContRange;
r->spec.offset = r->spec.length = range_spec_unknown;
r->elength = range_spec_unknown;
return r;
HttpHdrContRange *r = httpHdrContRangeCreate();
if (!httpHdrContRangeParseInit(r, str)) {
- httpHdrContRangeDestroy(r);
- r = NULL;
+ delete r;
+ return nullptr;
}
return r;
return 1;
}
-void
-httpHdrContRangeDestroy(HttpHdrContRange * range)
-{
- assert(range);
- memFree(range, MEM_HTTP_HDR_CONTENT_RANGE);
-}
-
HttpHdrContRange *
httpHdrContRangeDup(const HttpHdrContRange * range)
{
}
void
-httpHdrContRangePackInto(const HttpHdrContRange * range, Packer * p)
+httpHdrContRangePackInto(const HttpHdrContRange * range, Packable * p)
{
assert(range && p);
httpHdrRangeRespSpecPackInto(&range->spec, p);
assert (range->elength >= 0);
if (!known_spec(range->elength))
- packerPrintf(p, "/*");
+ p->append("/*", 2);
else
- packerPrintf(p, "/%" PRId64, range->elength);
+ p->appendf("/%" PRId64, range->elength);
}
void