unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* [ELPA] Package proposal: EBDB
@ 2017-07-30 19:18 Eric Abrahamsen
  2017-07-31  0:49 ` Richard Stallman
                   ` (2 more replies)
  0 siblings, 3 replies; 30+ messages in thread
From: Eric Abrahamsen @ 2017-07-30 19:18 UTC (permalink / raw)
  To: emacs-devel

Hi all,

I'd like to propose the following package for inclusion in ELPA:
https://github.com/girzel/ebdb

It's a port/re-write of BBDB using the EIEIO libraries.

Perhaps apropos of the recent copyright discussions: there's a fair
bit of BBDB code still in there. I haven't gone through and measured,
but my top-of-the-head guess is around 15-20%. I've noted this fact in
the comments sections of the files, including the names of original
authors where applicable. I was trying to be polite, but besides the
etiquette question I suppose there might be a copyright issue here.

Can anyone advise? I'd be happy to go through and figure out exactly
how much (and which parts) of the code is original to BBDB, if that's
relevant.

My other question is: if I require the cl-generic package for
backwards compatibility, what's the earliest Emacs version I can
expect to be compatible with? I'm also using seq 2.0 and pcase, and
seq at least says it wants Emacs 25.1 or up, so I guess that's my
floor, regardless...

Thanks,
Eric




^ permalink raw reply	[flat|nested] 30+ messages in thread
* Re: [ELPA] Package proposal: EBDB
@ 2017-08-06 22:12 Roland Winkler
  2017-08-07  0:44 ` Eric Abrahamsen
  0 siblings, 1 reply; 30+ messages in thread
From: Roland Winkler @ 2017-08-06 22:12 UTC (permalink / raw)
  To: emacs-devel; +Cc: jwiegley


> The ability to make BBDB extensible in future without requiring
> core changes is definitely a positive thing.

I agree, using, e.g., country-specific libraries can be a great way
of extending EBDB.  But this can also cause problems:

- Writing country-specific libraries for EBDB can be a fair bit of
  work.  Someone may develop a library for country XYZ up to the
  point "it works for me".  With the complexity of EBDB the
  developer may not notice / not care that some "irrelevant"
  features do not work.  When other users want to use the library,
  they can be stuck.

- Yet worse: "plain" users may have some records from country XYZ in
  their database, using the EBDB library for XYZ.  At some point,
  the very core of the EBDB code base may get updated in a way that
  also requires an update of the country-specific EBDB libraries.
  But the maintainer of the XYZ library may have disappeared from
  the stage for whatever reason.  What can the users do?  The EBDB
  database of a user might become unusable if its XYZ part cannot be
  read anymore.

  The opposite is also possible: It may turn out that it would be
  nice to update the EBDB code base in a way that also requires an
  update of the EBDB country-specific "add-on libraries" (or any
  other add-on libraries handling certain new fields for EBDB).  If
  there are many such country-specific add-on libraries out in the
  wild, it may become difficult to update the EBDB code base without
  breaking EBDB for many users.

  (Having developed BBDB for some time, I find it hard to predict
  when the code base of BBDB may have reached a level of maturity
  that allowed me to exclude the possibility of any further
  upgrades, say, in the format of the BBDB database files.  Then I
  am glad that such updates of BBDB can include the code to migrate
  the BBDB database files of the users.)

  (BBDB allows the user to customize the handling of addresses in a
  country-specific way; but this does not affect what is being
  stored in the database file using a universal, country-independent
  format.)

- In the worst case, also legal problems may arise: it may not be
  possible that someone else updates the code for the XYZ library.
  (But I am not a lawyer who could predict the details of such
  scenarios.)

I guess that to some extent these are generic aspects of an
object-oriented programming model, which is something I am less
familiar with in such a context.  Maybe others can comment.

It is certainly a [EB]BDB-specific issue that any code development
needs to keep in mind that many users already bring along their
database files.



^ permalink raw reply	[flat|nested] 30+ messages in thread

end of thread, other threads:[~2017-08-17 23:31 UTC | newest]

Thread overview: 30+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-07-30 19:18 [ELPA] Package proposal: EBDB Eric Abrahamsen
2017-07-31  0:49 ` Richard Stallman
2017-07-31  3:10   ` Eli Zaretskii
2017-07-31  3:12   ` Eric Abrahamsen
2017-07-31  3:28     ` Eli Zaretskii
2017-07-31  3:30       ` Eric Abrahamsen
2017-08-09 21:17   ` Eric Abrahamsen
2017-08-13  1:03     ` Eric Abrahamsen
2017-08-13 21:47       ` Stefan Monnier
2017-08-14  1:44         ` Eric Abrahamsen
2017-08-14  9:45           ` Stefan Monnier
2017-08-14 15:59             ` Eric Abrahamsen
2017-08-14 23:15               ` Stefan Monnier
2017-08-14 23:50                 ` Eric Abrahamsen
2017-08-15  7:49                   ` Stefan Monnier
2017-08-15 15:30                     ` Eric Abrahamsen
2017-08-17 16:57                       ` Eric Abrahamsen
2017-08-17 22:21                         ` Stefan Monnier
2017-08-17 22:52                           ` Eric Abrahamsen
2017-08-17 23:27                             ` Stefan Monnier
2017-08-17 23:31                               ` Eric Abrahamsen
2017-08-01  5:33 ` John Wiegley
2017-08-01 16:04   ` Eric Abrahamsen
2017-08-01 22:25     ` John Wiegley
2017-08-01 23:52       ` Eric Abrahamsen
2017-08-02  1:28         ` John Wiegley
2017-08-02  3:08           ` Eric Abrahamsen
2017-08-01  5:58 ` Stefan Monnier
  -- strict thread matches above, loose matches on Subject: below --
2017-08-06 22:12 Roland Winkler
2017-08-07  0:44 ` Eric Abrahamsen

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).