summaryrefslogtreecommitdiffstats
path: root/dom/plugins/base/nsPluginManifestLineReader.h
blob: be7d77044754a5e39c845090a361587bc43c32f0 (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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#ifndef nsPluginManifestLineReader_h_
#define nsPluginManifestLineReader_h_

#include "nspr.h"
#include "nsDebug.h"

#ifdef XP_WIN
#define PLUGIN_REGISTRY_FIELD_DELIMITER '|'
#else
#define PLUGIN_REGISTRY_FIELD_DELIMITER ':'
#endif

#define PLUGIN_REGISTRY_END_OF_LINE_MARKER '$'

class nsPluginManifestLineReader
{
  public:
    nsPluginManifestLineReader() {mBase = mCur = mNext = mLimit = 0;} 
    ~nsPluginManifestLineReader() { if (mBase) delete[] mBase; mBase=0;}
    
    char* Init(uint32_t flen) 
    {
      mBase = mCur = mNext = new char[flen + 1];
      if (mBase) {
        mLimit = mBase + flen;
        *mLimit = 0;
      }
      mLength = 0;
      return mBase;
    }
    
    bool NextLine()
    {
      if (mNext >= mLimit)
        return false;
      
      mCur = mNext;
      mLength = 0;
      
      char *lastDelimiter = 0;
      while(mNext < mLimit) {
        if (IsEOL(*mNext)) {
          if (lastDelimiter) {
            if (lastDelimiter && *(mNext - 1) != PLUGIN_REGISTRY_END_OF_LINE_MARKER)
              return false;
            *lastDelimiter = '\0';
          } else {
            *mNext = '\0';
          }

          for (++mNext; mNext < mLimit; ++mNext) {
            if (!IsEOL(*mNext))
              break;
          }
          return true;
        }
        if (*mNext == PLUGIN_REGISTRY_FIELD_DELIMITER)
          lastDelimiter = mNext;
        ++mNext;
        ++mLength;
      }
      return false;        
    }

    int ParseLine(char** chunks, int maxChunks)
    {
      NS_ASSERTION(mCur && maxChunks && chunks, "bad call to ParseLine");
      int found = 0;
      chunks[found++] = mCur;
      
      if (found < maxChunks) {
        for (char* cur = mCur; *cur; cur++) {
          if (*cur == PLUGIN_REGISTRY_FIELD_DELIMITER) {
            *cur = 0;
            chunks[found++] = cur + 1;
            if (found == maxChunks)
              break;
          }
        }
      }
      return found;
    }

    char*       LinePtr() { return mCur; }
    uint32_t    LineLength() { return mLength; }    

    bool        IsEOL(char c) {return c == '\n' || c == '\r';}

    char*       mBase;
  private:
    char*       mCur;
    uint32_t    mLength;
    char*       mNext;
    char*       mLimit;
};

#endif