Home | History | Annotate | Download | only in browser
      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:
     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.
     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                          const 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                                   const 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,
     77                               const AutofillField** match);
     78 
     79   // Adds an association between a field and a type to |map|.
     80   static bool AddClassification(const AutofillField* field,
     81                                 ServerFieldType type,
     82                                 ServerFieldTypeMap* map);
     83 
     84   // Derived classes must implement this interface to supply field type
     85   // information.  |ParseFormFields| coordinates the parsing and extraction
     86   // of types from an input vector of |AutofillField| objects and delegates
     87   // the type extraction via this method.
     88   virtual bool ClassifyField(ServerFieldTypeMap* map) const = 0;
     89 
     90  private:
     91   FRIEND_TEST_ALL_PREFIXES(FormFieldTest, Match);
     92 
     93   // Function pointer type for the parsing function that should be passed to the
     94   // ParseFormFieldsPass() helper function.
     95   typedef FormField* ParseFunction(AutofillScanner* scanner);
     96 
     97   // Matches |pattern| to the contents of the field at the head of the
     98   // |scanner|.
     99   // Returns |true| if a match is found according to |match_type|, and |false|
    100   // otherwise.
    101   static bool MatchAndAdvance(AutofillScanner* scanner,
    102                               const base::string16& pattern,
    103                               int match_type,
    104                               const AutofillField** match);
    105 
    106   // Matches the regular expression |pattern| against the components of |field|
    107   // as specified in the |match_type| bit field (see |MatchType|).
    108   static bool Match(const AutofillField* field,
    109                     const base::string16& pattern,
    110                     int match_type);
    111 
    112   // Perform a "pass" over the |fields| where each pass uses the supplied
    113   // |parse| method to match content to a given field type.
    114   // |fields| is both an input and an output parameter.  Upon exit |fields|
    115   // holds any remaining unclassified fields for further processing.
    116   // Classification results of the processed fields are stored in |map|.
    117   static void ParseFormFieldsPass(ParseFunction parse,
    118                                   std::vector<const AutofillField*>* fields,
    119                                   ServerFieldTypeMap* map);
    120 
    121   // Returns true iff |type| matches |match_type|.
    122   static bool MatchesFormControlType(const std::string& type, int match_type);
    123 
    124   DISALLOW_COPY_AND_ASSIGN(FormField);
    125 };
    126 
    127 }  // namespace autofill
    128 
    129 #endif  // COMPONENTS_AUTOFILL_CORE_BROWSER_FORM_FIELD_H_
    130