/srv/irclogs.ubuntu.com/2012/06/22/#bzr.txt

=== Guest7726 is now known as wallyworld
psusihow can I go back and correct a commit after adding a few more on top of it?  With git I would just commit the fix, then use rebase -i to squash the fix into the original.00:55
bob2you can rebase if you want00:55
bob2or just fix it00:55
psusihow would I rebase it?  I'd prefer to not clutter the history with the fix commit00:59
bob2by rebasing it?01:00
bob2http://wiki.bazaar.canonical.com/Rewrite01:01
bob2depends how much you care01:01
psusido I have to branch into another directory first, then uncommit back to the problem commit, fix, recommit, then rebase the original branch onto this one?01:03
psusior is there a way to do it in the current directory?01:03
spivpsusi: use the rebase command (from the bzr-rewrite plugin)01:09
psusispiv, yea... how exactly?01:10
spivAlthough maybe I'm wrong, and it still needs you to do it in another directory.01:10
spivI'm sorry, my memory on using it is hazy :(01:10
mwhudsonpsusi: one of the reasons people don't care so much about this sort of thing in bzr is that most of the time one is working a branch that's going to be combined with trunk by "bzr merge"01:18
lifelessyou'll need to branch the rev you want to fix to  a new branch, uncommit once and commit with the fixed message, then replay from the other branch01:18
lifelessmwhudson: I think they do care, often, but we've filtered them out of the community; see my manifesto for my analysis about it ;)01:19
mwhudsonpsusi: and when people run "bzr log" in trunk, they only see the message that the branch was merged with by default01:19
mwhudsonlifeless: well yes01:19
psusimwhudson, that not only does not avoid cluttering the history with minor fixup commits, but clutters it even more with useless merges01:19
mwhudsonpsusi: you see, i don't think of them as 'useless merges' -- quite the opposite, they are actually the most important thing01:20
mwhudsonpsusi: not trying to convert you or say you are wrong, but different tools tend to be used in different ways01:21
psusia merge that just fast forwards rather than actually merges concurrent development lines is a useless line in the history at best, and at worst, hides the actual development01:21
spivIt depends on what you value (and what the owners of the other branches value).01:21
psusiwell, there aren't other branches01:22
psusihence, why I don't want to add extra commits01:22
spivI tend to value having a single, clear commit on my branch when a merge happens summarising the thing that landed (and then if I want to see details of how that got developed I dig into the history on that side).01:22
spivBut I understand other folks work differently or value different properties more.01:23
psusithat makes sense... if I branched and made several commits that all are part of one new feature... but I didn't... just several unrelated commits01:23
=== zyga-afk is now known as zyga
jammorning all07:28
mgzmorning08:32
jmlhello09:03
lifelesshawdee09:09
=== zyga is now known as zyga-afk
=== zyga-afk is now known as zyga
Wiz_KeeDhey guys!!13:36
mgzhey13:36
Wiz_KeeDmgz i have some question about bzr think you can help out?13:37
Wiz_KeeD:D13:37
mgzWiz_KeeD: don't ask to ask, just ask.13:49
psusiwhen I want to ammend the previous commit, if I uncommit, fix it, then recommit, I have to retype the log message.  Is there a way to avoid that?13:57
jelmer_psusi: the commit message is saved in .bzr/branch/branch.conf if you have bzr-gtk or qbzr instaled14:00
jelmer_they will also suggest the old commit messages if you commit using 'bzr qcommit' or 'bzr gcommit'14:00
jelmer_'bzr commit' doesn't have this functionality (yet)14:00
psusidoh14:00
mgzI just keep it on the clipboard generally...14:00
psusiproblem with that is that if I look at the log, copy, and paste it back in, I have to manually delete the indentation from each line14:01
psusiwhich gets annoying14:01
Wiz_KeeDhow can i browse bzr revisions?14:04
jelmer_Wiz_KeeD: bzr viz or bzr qlog14:04
Wiz_KeeDnone work14:04
Wiz_KeeDwait14:04
Wiz_KeeDnop, neither work14:05
jelmer_Wiz_KeeD: you'll have to have either bzr-gtk or qbzr installed14:05
Wiz_KeeDunknwon command14:05
* gour uses fish shell and it usually guess correct log message14:07
Wiz_KeeDit has installed olive bazzar gui14:07
psusiI did a bzr rebase and it shows up in the log as a merge.. what gives?14:11
Wiz_KeeDwhat does rebase do?14:11
psusirewrites history to make commits appear as being based on a different starting point14:11
Wiz_KeeDbeing based on a different startying point?14:13
psusiinstead of rev X, then A and B, it's rev Y, then A and B14:14
Wiz_KeeDah...14:14
Wiz_KeeDlittel wierd14:14
* psusi beats bzr with a rubber hose... a rebase is NOT a merge!15:07
jelmer_psusi: hmm?15:08
psusijelmer_: a few commits back, I fixed something wrong.  So I branched, uncommitted back there, fixed it, committed it again, and am now trying to rebase the subsequent commits on top of the new fixed old commit so it looks like I got it right the first time15:10
psusiand when I bzr rebase -r 33.. fixed, rev 33 shows up as a MERGE15:10
jelmer_psusi: presumably because the old rev 33 was a merge commit?15:12
psusinope15:14
psusino merges anywhere15:14
psusiuntil after I try to rebase15:14
psusierr, actually it was rev 33 where the error was so I rebase -r 34.. to get all of the commits above there onto the new, corrected 3315:15
psusibut after the rebase, r34 shows as a merge that has the description of the old r34, but merges the new, corrected r3315:16
jelmer_ah, bzr-rebase probably doesn't handle the same revision being in the branch multiple times very well15:17
psusiargh... this is so easy in git15:19
psusithis is really broken... the history apparently was correctly rebased... it shows r34 following the new, corrected r33... it r34 also says it merged in the OLD r3315:28
psusiwhich makes no sense at all15:28
psusiwell, I guess it's back to my old method of uncommit, shelve, repeat, edit, recommit, unshelve, commit, repeat15:40
fullermdWell, it's a parent of the old 34, so in that sense it could be part of the stuff to be brought over, given a certain interpretation.15:40
psusithe whole point of rebasing is to discard the old history15:41
fullermd'd probably have to poke around in the helpfile for the details; I don't know (or have it around to check myself)15:41
psusiand make 34+ as if they were originally done on top of the new 3315:41
fullermdA matter of interpretation.  It would be just as valid to say the point is to take (history on that side that's not here) and stick it on the end of here.15:41
psusiand you obviously did not merge the old 33, since the state of the files reflects the contents of the new 33, but the log makes it look that way15:42
psusino, that's what a merge is15:43
fullermdNot really.  Merge couldn't put them on the end.15:43
psusimerge always puts them on the end.... under a merge commit15:43
fullermdnew-33 isn't a parent of old-34, so merge couldn't make that happen; only a rebase could.15:43
fullermdIt has to create a new-34 to cause that.15:44
fullermdMerge can only put them off to the side, then put something new on the end that connects the two.15:44
psusiright... rebase changes new-34 so it says its parent is new-33.. and that's all it should do15:44
psusiinstead it seems to make new-34's parent new-33, AND merge in old-3315:44
psusiyou can't have both old and new 33, they conflict15:45
fullermdAnyway.  This is bootless.  My point is that it's not immediately obvious to me whether the existing parent of 34 is part of what should be preserved or not in a rebase, and so I'd consider either behavior a sensible answer to the question.  It would take digging into the details of what rebase does and what args it takes to know for sure, and I don't have any of that at my fingertips.15:45
fullermdSemantically, yes; that's what you intend.  The question is, is the command you're running expressing that as bzr expects.15:46
fullermdIt could be a bug "the default choices aren't what I expect", or a bug "the default choices aren't working as designed"; I don't know which.15:47
psusihow is it not obvious?  the whole point of a rebase is to eliminate the existing parent and replace it with a new one15:47
fullermdIf the former, there's probably some arg you can find in help that will get you where you want to be.15:47
* fullermd shrugs.15:48
fullermdTo me, in isolation, it's not obvious that one of the choices is obviously right and the other obviously wrong, so I couldn't express an opinion as to which way things are failing.15:48
psusione of the choices follows the definition of rebase, the other does not15:49
fullermdThere is no "definition of rebase".15:49
psusisure there is... to change the base revision on which a set of history started from15:50
fullermdThere's a "what _git_ does when you run rebase with -xyz", and a "what _bzr_ does when you run rebase with -xyz".  Presumably they're _close_, but I don't see any reason to assume they're identical.15:50
abentleyvila: I'd like to discuss bug #1015614 .  Do you have a minute?15:50
ubot5Launchpad bug 1015614 in Bazaar "Configuring local colocated branches matches too broadly" [Undecided,New] https://launchpad.net/bugs/101561415:50
fullermdWow, LP got into the millions there.15:53
abentleyfullermd: Yep, about a month ago: http://blog.launchpad.net/general/one-in-a-million15:56
fullermdThe downside is that I'm really going to have to knuckle down and write some terrible code if we're going to hit the billion mark in my lifetime.  Sigh.  Back to the salt mines...15:58
mgzit's not enough just to be bad fullermd, you also have to be popular16:07
fullermdOh, I take _that_ part for granted.  I mean, _look_ at me!16:08
abentleymgz: like nvidia? :-)16:09
jmlhey, someone just asked me why submit: and push: locations are two different things17:43
jmland I don't know the answer17:44
jmlwhat's the answer?17:44
jelmer_jml: submit is what you want to submit merge proposals against19:07
jelmer_jml: e.g. in the case of bzr19:08
jelmer_you push your feature branch to lp:~jml/bzr/feature-branch19:08
jelmer_whereas the submit location is lp:bzr19:08
=== yofel_ is now known as yofel
=== gour1 is now known as gour
=== jelmer_ is now known as jelmer

Generated by irclog2html.py 2.7 by Marius Gedminas - find it at mg.pov.lt!