• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef COMPONENTS_AUTOFILL_CORE_BROWSER_FORM_FIELD_H_
6 #define COMPONENTS_AUTOFILL_CORE_BROWSER_FORM_FIELD_H_
7 
8 #include <vector>
9 
10 #include "base/basictypes.h"
11 #include "base/gtest_prod_util.h"
12 #include "base/strings/string16.h"
13 #include "components/autofill/core/browser/field_types.h"
14 
15 namespace autofill {
16 
17 class AutofillField;
18 class AutofillScanner;
19 
20 // Represents a logical form field in a web form.  Classes that implement this
21 // interface can identify themselves as a particular type of form field, e.g.
22 // name, phone number, or address field.
23 class FormField {
24  public:
~FormField()25   virtual ~FormField() {}
26 
27   // Classifies each field in |fields| with its heuristically detected type.
28   // The association is stored into |map|.  Each field has a derived unique name
29   // that is used as the key into the |map|.
30   static void ParseFormFields(const std::vector<AutofillField*>& fields,
31                               ServerFieldTypeMap* map);
32 
33  protected:
34   // A bit-field used for matching specific parts of a field in question.
35   enum MatchType {
36     // Attributes.
37     MATCH_LABEL      = 1 << 0,
38     MATCH_NAME       = 1 << 1,
39     MATCH_VALUE      = 1 << 2,
40 
41     // Input types.
42     MATCH_TEXT       = 1 << 3,
43     MATCH_EMAIL      = 1 << 4,
44     MATCH_TELEPHONE  = 1 << 5,
45     MATCH_SELECT     = 1 << 6,
46     MATCH_TEXT_AREA  = 1 << 7,
47     MATCH_ALL_INPUTS =
48         MATCH_TEXT | MATCH_EMAIL | MATCH_TELEPHONE | MATCH_SELECT |
49         MATCH_TEXT_AREA,
50 
51     // By default match label and name for input/text types.
52     MATCH_DEFAULT    = MATCH_LABEL | MATCH_NAME | MATCH_VALUE | MATCH_TEXT,
53   };
54 
55   // Only derived classes may instantiate.
FormField()56   FormField() {}
57 
58   // Attempts to parse a form field with the given pattern.  Returns true on
59   // success and fills |match| with a pointer to the field.
60   static bool ParseField(AutofillScanner* scanner,
61                          const base::string16& pattern,
62                          AutofillField** match);
63 
64   // Parses the stream of fields in |scanner| with regular expression |pattern|
65   // as specified in the |match_type| bit field (see |MatchType|).  If |match|
66   // is non-NULL and the pattern matches, the matched field is returned.
67   // A |true| result is returned in the case of a successful match, false
68   // otherwise.
69   static bool ParseFieldSpecifics(AutofillScanner* scanner,
70                                   const base::string16& pattern,
71                                   int match_type,
72                                   AutofillField** match);
73 
74   // Attempts to parse a field with an empty label.  Returns true
75   // on success and fills |match| with a pointer to the field.
76   static bool ParseEmptyLabel(AutofillScanner* scanner, AutofillField** match);
77 
78   // Adds an association between a field and a type to |map|.
79   static bool AddClassification(const AutofillField* field,
80                                 ServerFieldType type,
81                                 ServerFieldTypeMap* map);
82 
83   // Derived classes must implement this interface to supply field type
84   // information.  |ParseFormFields| coordinates the parsing and extraction
85   // of types from an input vector of |AutofillField| objects and delegates
86   // the type extraction via this method.
87   virtual bool ClassifyField(ServerFieldTypeMap* map) const = 0;
88 
89  private:
90   FRIEND_TEST_ALL_PREFIXES(FormFieldTest, Match);
91 
92   // Function pointer type for the parsing function that should be passed to the
93   // ParseFormFieldsPass() helper function.
94   typedef FormField* ParseFunction(AutofillScanner* scanner);
95 
96   // Matches |pattern| to the contents of the field at the head of the
97   // |scanner|.
98   // Returns |true| if a match is found according to |match_type|, and |false|
99   // otherwise.
100   static bool MatchAndAdvance(AutofillScanner* scanner,
101                               const base::string16& pattern,
102                               int match_type,
103                               AutofillField** match);
104 
105   // Matches the regular expression |pattern| against the components of |field|
106   // as specified in the |match_type| bit field (see |MatchType|).
107   static bool Match(const AutofillField* field,
108                     const base::string16& pattern,
109                     int match_type);
110 
111   // Perform a "pass" over the |fields| where each pass uses the supplied
112   // |parse| method to match content to a given field type.
113   // |fields| is both an input and an output parameter.  Upon exit |fields|
114   // holds any remaining unclassified fields for further processing.
115   // Classification results of the processed fields are stored in |map|.
116   static void ParseFormFieldsPass(ParseFunction parse,
117                                   std::vector<AutofillField*>* fields,
118                                   ServerFieldTypeMap* map);
119 
120   // Returns true iff |type| matches |match_type|.
121   static bool MatchesFormControlType(const std::string& type, int match_type);
122 
123   DISALLOW_COPY_AND_ASSIGN(FormField);
124 };
125 
126 }  // namespace autofill
127 
128 #endif  // COMPONENTS_AUTOFILL_CORE_BROWSER_FORM_FIELD_H_
129