author Geoff Lankow <>
Tue, 08 Oct 2019 20:34:06 +1300
changeset 37101 83c4a792b5894bb4fad4908ec2ae235568d871aa
parent 33311 4aa20359173fc49b4ae3699985ba8696577f1cbe
child 37198 6a279db8f7370513cd9853ece3d8cb7ce00b62e0
permissions -rw-r--r--
No bug - Tidy some poor formatting in IDL files; rs=white-space-only

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* 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 */

    Field map interface for importing address books

  A field map is an arbitrary sized list of mozilla address book fields.
  The field map is used by import to map fields from the import format
  to mozilla fields.
  For export, the map contains the ordered list of mozilla fields to

#include "nsISupports.idl"

interface nsIAddrDatabase;
[ptr] native nsIMdbRow (nsIMdbRow);
class nsIMdbRow;

[scriptable, uuid(deee9264-1fe3-47b1-b745-47b22de454e2)]
interface nsIImportFieldMap : nsISupports
    Flag to indicate whether or not to skip the first record,
    for instance csv files often have field names as the first
  attribute boolean skipFirstRecord;

  readonly attribute long numMozFields;
  readonly attribute long mapSize;

  wstring GetFieldDescription(in long index);

    Set the size of the field map, all unpopulated entries
    will default to -1
  void SetFieldMapSize(in long size);

    Initialize the field map to a given size with default values
  void DefaultFieldMap(in long size);

    Return the field number that this index maps to, -1 for no field
  long GetFieldMap(in long index);

    Set the field that this index maps to, -1 for no field
  void SetFieldMap(in long index, in long fieldNum);

    Return if this field is "active" in the map.
  boolean GetFieldActive(in long index);

    Set the active state of this field
  void SetFieldActive(in long index, in boolean active);

    Set the value of the given field in the database row
  void SetFieldValue(in nsIAddrDatabase database, in nsIMdbRow row, in long fieldNum, in wstring value);