/* * $Id: ETag.cc,v 1.10 2003/02/21 22:50:05 robertc Exp $ * * DEBUG: none ETag parsing support * AUTHOR: Alex Rousskov * * SQUID Web Proxy Cache http://www.squid-cache.org/ * ---------------------------------------------------------- * * Squid is the result of efforts by numerous individuals from * the Internet community; see the CONTRIBUTORS file for full * details. Many organizations have provided support for Squid's * development; see the SPONSORS file for full details. Squid is * Copyrighted (C) 2001 by the Regents of the University of * California; see the COPYRIGHT file for full details. Squid * incorporates software developed and/or copyrighted by other * sources; see the CREDITS file for full details. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA. * */ #include "squid.h" /* * Note: ETag is not an http "field" like, for example HttpHdrRange. ETag is a * field-value that maybe used in many http fields. */ /* parses a string as weak or strong entity-tag; returns true on success */ /* note: we do not duplicate "str"! */ int etagParseInit(ETag * etag, const char *str) { int len; assert(etag && str); etag->str = NULL; etag->weak = !strncmp(str, "W/", 2); if (etag->weak) str += 2; /* check format (quoted-string) */ len = strlen(str); if (len >= 2 && str[0] == '"' && str[len - 1] == '"') etag->str = str; return etag->str != NULL; } /* returns true if etags are equal */ int etagIsEqual(const ETag * tag1, const ETag * tag2) { assert(tag1 && tag2); assert(!tag1->weak && !tag2->weak); /* weak comparison not implemented yet */ return !strcmp(tag1->str, tag2->str); }