Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code | Sign in
(645)

Issue 7009047: Allows for easier creation of many Lilypond objects via Scheme.

Can't Edit
Can't Publish+Mail
Start Review
Created:
12 years, 10 months ago by MikeSol
Modified:
12 years, 10 months ago
Reviewers:
dak, marc, mike7, david.nalesnik, wl
CC:
lilypond-devel_gnu.org
Base URL:
http://git.savannah.gnu.org/gitweb/?p=lilypond.git/trunk/
Visibility:
Public.

Description

Allows for easier creation of many Lilypond objects via Scheme.

Patch Set 1 #

Patch Set 2 : Fixes typos #

Total comments: 4
Unified diffs Side-by-side diffs Delta from patch set Stats (+161 lines, -11 lines) Patch
A input/regression/scheme-everything.ly View 1 chunk +119 lines, -0 lines 0 comments Download
M ly/property-init.ly View 1 chunk +18 lines, -0 lines 1 comment Download
M scm/define-grobs.scm View 1 chunk +11 lines, -6 lines 2 comments Download
M scm/define-music-types.scm View 2 chunks +13 lines, -5 lines 1 comment Download

Messages

Total messages: 10
dak
All of this is absolutely devastatingly horrible code that is not reconcilable with sane per-session ...
12 years, 10 months ago (2012-12-23 23:10:19 UTC) #1
mike7
On 24 déc. 2012, at 01:10, dak@gnu.org wrote: > All of this is absolutely devastatingly ...
12 years, 10 months ago (2012-12-24 07:28:17 UTC) #2
marc
On 2012/12/24 07:28:17, mike7 wrote: > So what I need from you, if you're willing ...
12 years, 10 months ago (2012-12-24 08:10:25 UTC) #3
dak
On 2012/12/24 07:28:17, mike7 wrote: > On 24 déc. 2012, at 01:10, mailto:dak@gnu.org wrote: > ...
12 years, 10 months ago (2012-12-24 08:36:31 UTC) #4
dak
On 2012/12/24 08:10:25, marc wrote: > On 2012/12/24 07:28:17, mike7 wrote: > > > So ...
12 years, 10 months ago (2012-12-24 08:40:43 UTC) #5
mike7
On 24 déc. 2012, at 10:10, marc@hohlart.de wrote: > On 2012/12/24 07:28:17, mike7 wrote: > ...
12 years, 10 months ago (2012-12-24 13:01:14 UTC) #6
mike7
On 24 déc. 2012, at 10:36, dak@gnu.org wrote: > On 2012/12/24 07:28:17, mike7 wrote: > ...
12 years, 10 months ago (2012-12-24 13:22:22 UTC) #7
wl_gnu.org
>> It is just wires sticking out, and it is wires to something that >> ...
12 years, 10 months ago (2012-12-24 13:43:42 UTC) #8
david.nalesnik
On Mon, Dec 24, 2012 at 7:22 AM, mike@mikesolomon.org <mike@mikesolomon.org> wrote: > On 24 déc. ...
12 years, 10 months ago (2012-12-24 13:56:00 UTC) #9
mike7
12 years, 10 months ago (2012-12-25 09:17:34 UTC) #10
On 24 déc. 2012, at 15:55, David Nalesnik <david.nalesnik@gmail.com> wrote:

> On Mon, Dec 24, 2012 at 7:22 AM, mike@mikesolomon.org
> <mike@mikesolomon.org> wrote:
>> On 24 déc. 2012, at 10:36, dak@gnu.org wrote:
>> 
>> On 2012/12/24 07:28:17, mike7 wrote:
>> 
>> On 24 déc. 2012, at 01:10, mailto:dak@gnu.org wrote:
>> 
>> 
>>> All of this is absolutely devastatingly horrible code that is not
>>> reconcilable with sane per-session semantics and tampers with
>> 
>> LilyPond
>> 
>>> internals in a way that has bleed-over effects into future files in
>> 
>> the
>> 
>>> same command line.
>>> 
>>> In addition, the interfaces into the exposed internals are
>> 
>> absolutely
>> 
>>> horrific and cryptic and don't make any sense as a user interface.
>>> 
>> 
>> 
>> I agree that the innards I'm exposing are not coded particularly
>> well
>> 
>> 
>> You don't get the point.  A user interface is not supposed to "expose
>> innards", it is supposed to provide functionality.  Pulling data
>> structures and some of the code accessing them into the open is not a
>> user interface.
>> 
>> 
>> I am certainly not saying that this type of task is for every user, but
>> someone comfortable enough to do this should not have to copy and paste from
>> define-*.scm every time.
>> 
>>> This is taking everything that is broken with
>>> input/regression/scheme-text-spanner.ly, magnifies it to a number of
>>> other cases, and gives it a bad interface.
>> 
>> 
>> 
>> I am of the opinion that it is better to have stuff like this that
>> allows people to do creative and interesting things with LilyPond
>> than not have it at all.
>> 
>> 
>> But those "creative and interesting things" will break frequently on
>> update.  We already have quite a bit of "why doesn't this stuff I
>> based on [some version of] scheme-text-spanner.ly not work in my
>> version of LilyPond?" questions.
>> 
>> 
>> It seems like you'd rather not make something accessible rather than making
>> it accessible in a fragile state.  I certainly prefer the latter, as it
>> allows more people to experiment.  For example, David's work on the frame
>> engraver would be a great trial ground for this sort of thing.
>> 
> 
> I've gotten a lot of use out of techniques in
> scheme-text-spanner.ly--that's probably very evident--and I'm quite
> appreciative that it's there.  I understand the problems that it
> causes--I've seen evidence of bleed-over.  However, I'm using these
> techniques as a convenient aid to developing new features.  I could
> certainly work directly in LilyDev and alter the necessary files in
> the proper way, but then I'm unable to get feedback from those users
> who would actively use the new features but aren't comfortable
> applying patches.

[responding to Werner too] I completely see where you're coming from - this is
how I've gone about work with a lot of features.  This is why I think the idea
of a git branch, while good for development, is not necessarily possible for the
average user to access.

> You can see just how much user feedback I got
> during the creation of the measure counter (issue 2445).  As far as
> the frame engraver goes, I've gotten a good sense of what such a thing
> ought to do, and corrected several problems based on input from
> lilypond-user.  My efforts here are still quite a way from producing a
> formal patch and putting it up for review, but that is the end goal.

I'm positive you'll get there.  The frame patch, when submitted, should be able
to use in-house grob-creation and event-creation mechanisms instead of copying
and pasting out of Scheme files.  My goal with the present patch is to get
LilyPond to a state where you and others can do this.  Any feedback on how to
control the bleed-over mechanisms that you, Mark and David K. have identified
would be very helpful.

Cheers,
MS
Sign in to reply to this message.

Powered by Google App Engine
RSS Feeds Recent Issues | This issue
This is Rietveld f62528b