- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
Yup. 7.0
https://docs.oracle.com/javase/7/docs/technotes/guides/language/catch-multiple.html
Without multi-catch, your exception handling can get a little ugly. That's why I mentioned it :)
Admin
That's when "Shelves" become very useful. Make a change, shelve it, and send it to the lead developer/architect for blessing and merging. Over time, assuming I was seeing good code practices, I would likely tell a developer that they didn't need to bring every single thing like this to my attention, so long as they did their proper unit testing.
A developer who is actually knowledgeable and able to clear up "technical dept" without causing big holes in the system is all too rare a treasure, though, in my experience.
Admin
Not all VCSs have shelvesets though; I know for a fact git doesn't. Then again, with git, branching is pretty cheap; you can easily branch then issue a PR, and it achieves the same goal.
Admin
Good point. 99% of my personal experience has been with VSS/TFS over the years. Shelving in TFS is really just a special kind of branch, so making a branch that can be merged and destroyed later would accomplish the same thing.
Admin
You missed my point. It's not about the changes per se alone, it's about the unauthorized effort put into those changes.
Admin
Admin
I didn't say "not make a change", I said "not leave your fingerprints".
Admin
I didn't miss that. Again, rule # 2 is:
The fact that the change wasn't attributed to you moves you from "bastard that broke it" to "bastard that let it fail through inaction". That's not any better.Admin
If it goes wrong, in which case it's either "bastard that broke it" to "bastard that let it fail".
Admin
Which brings you all the way back to agreeing with the post that you originally posted a rebuttal to.
Original:
To which you relied (somewhat indirectly):Admin
Without the managers catching on.
You don't suppose what it comes down to is that the developers should be entrusted with development, and the managers should be making it possible for them to do so for the best outcome? It's a novel idea, but I don't think it'll catch on.
Admin
NO.... A ShelveSet is transitory and can be deleted (in fact good practices dictate a process for doing so), a Branch is a permanent (auditable) activity. There is also the Code Review request/response which keeps the review as an auditable activity, but utilizes a transitory shelveset for the code itself (later the review should be associated with the final commit)
Admin
IMO, shelveset is a handy feature that, when you're the only developer and the test machine is your desktop, when you suddenly need to deploy something out, you can shelf all changes on hand and undo to latest stable state and complie and deploy, then get back the WIP items from shelf and continue.
Admin
Hi, git has stashes, which sound very similar, at least in use case, for shelvesets.
Admin
Sadly though, for the foreseeable future, will need to be done
because of problems like the Law of Disinformation and the ways in which different personality types attempt to satisfy the will to power.Admin
Shelvesets are on the server; Stashes are on the client.
Stashes suck. Git sucks. Gribnit sucks.
Admin
Ah okay, yeah, forgot that the mad cult needs the central server thing so hard. So sounds like TFS is beating Subversion pretty roundly these days - bad news for FLOSS!
Admin
I'm guessing this is supposed to be sarcasm?
But TFS 2013 is really, really great. Both compared to Subversion and Git. It basically has all the features of both of those SCMs.
Admin
You're implementing some
Iterator<T>
and there's no meaningful semantics for#remove()
, there the method contract calls for you to throw a subclass of RuntimeException.. also if some fool calls#next()
even though not#hasNext()
, you throw a RuntimeException there.. lots of use cases if you're following the complete API contracts for things.Not even going to think about Swing here. Not that those are even RuntimeException, but (screams) (gibbers)
Admin
I moved from SubVersion to TFS and I really miss externals.
Admin
That's only a needed feature when you can't check something out to two places simultaneously. With SVN, when I ran into that situation, I simply checked out another copy to do whatever I needed. It took seconds.
Also, get a build machine. Building by hand on developer workstations is not a great practice.
Admin
Yeah well I really miss YOUR MOM because there were TOO MANY SAILORS ALREADY IN LINE!
Admin
(Psst, you can do that in TFS also.)
Admin
Being on the server I think a
tag
will do, just push a tag to server like2.rc3
for third release candidate of version 10. If it is just for the sake of backing up latest code to the server, it is best be committed to a working branch (not master branch), ingit-flow
that would bedevelop
if it is the single developer andfeature/foo
if there are multiple developers.Admin
I've successfully caught and handled OutOfMemoryException in C# before
Admin
Yes, checking out another local copy is totally the same as storing some work on the server, not checked in, that you can let someone else look at/you can finish later.
Admin
I never made the claim you seem to think I did. He wants to build from the unchanged source, and checking out to a second location will accomplish that.
Besides, checking out a second copy doesn't preclude you from checking in your changes on the first copy, so you very well could save the work on the server and have other people work on it. However, I agree that shelvesets are the right feature for that workflow - the only problem is that we weren't talking about that workflow.
Admin
... if you create a second workspace. It's not exactly intuitive, and still limits you to one checkout per workspace.
Admin
kinda hard to devote any brainspace to this topic, really, these are all subcases of branching, and the significance of a branch is arbitrary.. sounds like a bunch of special cases, compared to git.
Admin
It's often difficult to handle OOM, not because it's impossible to recover from a particular failure-to-allocate, but because what do you do next? If a small allocate fails, you're probably screwed because the likelihood that the next small allocate will succeed is minimal.
Using the stack (C++ style) means that you need much larger stacks. That can create different problems (or at least make them bite on a different schedule).
Admin
This was a very special case, where I was using a library to write an Excel file, and OOM basically meant the object was over the 1GB limit. I returned an error message basically saying "save this shit as a CSV" and killed the object. Not particularly pretty, but it worked in this situation
Admin
Large-alloc failure is usually recoverable, yes. That's why just setting the computer on fire when allocate fails is a bad move. :)
Admin
There is a big difference between checking in (leaving a permanent record, of what should ALWAYS be working code) and the purpose of a shelvset (which is transitory, but stored on the server).
About 6 years ago, I had one client (huge company) a different area was using 100% laptops, but they were no mobile. All locked to the respective desk (and the developers did NOT have the key). One day the office opened and every laptop was gone, and cut cables were all that remained (eventually the cleaning crew was prosecuted, but the laptops were never recovered).
Since all work had been put into ShelveSets,two things happened. Critical work began by taking whatever was available and RDP into VM's....A run as made to a local store (where they had a corporate account) and all available laptops were picked up [and in service by right after lunch] and the rest were express ordered.
Would hate to think of what would have happened if the work had all been (only) on the laptops.
Admin
:wtf:
...Oh, you actually mean all unfinished work. Cool, then. That's a good thing.
Admin
I was not explicit...yes, work in progress that was not ready to be committed. This [IMHO] should be done every time one takes a break, leaves the office, etc. It eliminates any risk of effort being lost due to a local machine problem, yet does not contaminate the repository.
Also if for some reason the person does not come back (they get sick), everything right up to the last keystroke is available to those people who are working.
Additionally, it is a great way to do exchanges (in fact the entire pre-commit code review process is built on them).
Admin
Not convinced, I am fine with there being branches that are not
as long as the commit notes don't indicate otherwise. Preferably, sure, would want some naming conventions to allow me to be wary of such branches. If the laptops are at risk the devs should push those branches to remote. Hey look, now we have a way to leave an ecosystem where the leader has abandoned ship for hipper markets!
ShelveSets sounds like a sort of creepy institutional notion, in name - granted, this is not an actual argument against.
Admin
You do realize you just said in more detail what I said :smile:
While you are completely correct, I was referring more to how you work with a ShelveSet. Not the dictionary definition differences between the two.