]> git.saurik.com Git - apt.git/blame_incremental - apt-pkg/indexfile.cc
* apt-pkg/deb/dpkgpm.cc:
[apt.git] / apt-pkg / indexfile.cc
... / ...
CommitLineData
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
3// $Id: indexfile.cc,v 1.2.2.1 2003/12/24 23:09:17 mdz Exp $
4/* ######################################################################
5
6 Index File - Abstraction for an index of archive/souce file.
7
8 ##################################################################### */
9 /*}}}*/
10// Include Files /*{{{*/
11#include <apt-pkg/indexfile.h>
12#include <apt-pkg/error.h>
13#include <apt-pkg/aptconfiguration.h>
14
15#include <clocale>
16#include <cstring>
17 /*}}}*/
18
19// Global list of Item supported
20static pkgIndexFile::Type *ItmList[10];
21pkgIndexFile::Type **pkgIndexFile::Type::GlobalList = ItmList;
22unsigned long pkgIndexFile::Type::GlobalListLen = 0;
23
24// Type::Type - Constructor /*{{{*/
25// ---------------------------------------------------------------------
26/* */
27pkgIndexFile::Type::Type()
28{
29 ItmList[GlobalListLen] = this;
30 GlobalListLen++;
31 Label = NULL;
32}
33 /*}}}*/
34// Type::GetType - Locate the type by name /*{{{*/
35// ---------------------------------------------------------------------
36/* */
37pkgIndexFile::Type *pkgIndexFile::Type::GetType(const char *Type)
38{
39 for (unsigned I = 0; I != GlobalListLen; I++)
40 if (strcmp(GlobalList[I]->Label,Type) == 0)
41 return GlobalList[I];
42 return 0;
43}
44 /*}}}*/
45// IndexFile::ArchiveInfo - Stub /*{{{*/
46// ---------------------------------------------------------------------
47/* */
48string pkgIndexFile::ArchiveInfo(pkgCache::VerIterator Ver) const
49{
50 return string();
51}
52 /*}}}*/
53// IndexFile::FindInCache - Stub /*{{{*/
54// ---------------------------------------------------------------------
55/* */
56pkgCache::PkgFileIterator pkgIndexFile::FindInCache(pkgCache &Cache) const
57{
58 return pkgCache::PkgFileIterator(Cache);
59}
60 /*}}}*/
61// IndexFile::SourceIndex - Stub /*{{{*/
62// ---------------------------------------------------------------------
63/* */
64string pkgIndexFile::SourceInfo(pkgSrcRecords::Parser const &Record,
65 pkgSrcRecords::File const &File) const
66{
67 return string();
68}
69 /*}}}*/
70// IndexFile::TranslationsAvailable - Check if will use Translation /*{{{*/
71// ---------------------------------------------------------------------
72/* */
73bool pkgIndexFile::TranslationsAvailable() {
74 return (APT::Configuration::getLanguages().empty() != true);
75}
76 /*}}}*/
77// IndexFile::CheckLanguageCode - Check the Language Code /*{{{*/
78// ---------------------------------------------------------------------
79/* No intern need for this method anymore as the check for correctness
80 is already done in getLanguages(). Note also that this check is
81 rather bad (doesn't take three character like ast into account).
82 TODO: Remove method with next API break */
83__attribute__ ((deprecated)) bool pkgIndexFile::CheckLanguageCode(const char *Lang)
84{
85 if (strlen(Lang) == 2 || (strlen(Lang) == 5 && Lang[2] == '_'))
86 return true;
87
88 if (strcmp(Lang,"C") != 0)
89 _error->Warning("Wrong language code %s", Lang);
90
91 return false;
92}
93 /*}}}*/
94// IndexFile::LanguageCode - Return the Language Code /*{{{*/
95// ---------------------------------------------------------------------
96/* As we have now possibly more than one LanguageCode this method is
97 supersided by a) private classmembers or b) getLanguages().
98 TODO: Remove method with next API break */
99__attribute__ ((deprecated)) string pkgIndexFile::LanguageCode() {
100 if (TranslationsAvailable() == false)
101 return "";
102 return APT::Configuration::getLanguages()[0];
103}
104 /*}}}*/