- Feature Articles
- CodeSOD
- Error'd
- 
                
                    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
No, sell the utilities to all your contacts on the user forums.
Admin
A language like C, but even worse?
Oh come on, no such beast exists. I call shenanigans.
Admin
I wonder what self respecting company would continue to buy this crap from this vendor. Probably the same company that thinks a made-for-the-hobbyist Arduino is something to build a product off of (hint: it's not).
Bet ya a dollar the boss is her dad and the other employee was her sibling.
Admin
I've seen poorly made, partially to-standard C implementations before, but I would like to know just which language they used for those screens out of morbid curiosity.
Admin
The description of the language in the article sounds a lot like B, C's immediate predecessor.
https://en.wikipedia.org/wiki/B_(programming_language)
Admin
Nothing wrong with minimal languages. With a DSL (Domain Specific Language) you put in just the absolute minimum features you need.
Also there have been good industrial (not hobbyist) Arduino boards. I did quite a bit of work with "Arduino Industrial 101" (now a retired product).
Admin
You don't believe there is a worse language than 'C'? You have led a sheltered life....
Forth Fortran COBOL Lisp
Admin
I thought it sounded like BCPL. Everything is a word. So, a string is a word, and a function is a word. So you could write
and it would jump the program counter to the string. The skill was in writing your machine code subroutine in the form if a string. In the days before Unicode.
Admin
At least her boss is pretty decent here.
Admin
That language was called C--.
Admin
These two lines in the story seem to be contradictory -
"Alyssa first tried to control the screens using the manufacturer's own serial library. She couldn't get any of the system commands to work over serial"
and
"Alyssa recalled that sending serial commands directly had worked before"
Admin
Oh hell no!
I have seen this story before 100 times. The moment you do that you will:
Nope there is two ways to deal with this:
2)Sell it to vendor, with a full hand off, they may be interested if it actually makes their product more marketable. This way either they deal with supporting it, you get paid and if they need further input from you - you get paid again.
Admin
At a guess, they were probably using an AT Mega chip or similar, and just calling it an Arduino. They probably used actual Arduino boards for prototyping, and then ran off their custom boards for actual product release (that's what we used to do at my old job).
Admin
You're just not thinking creatively enough. I worked with a guy who had his own custom library to basically slap a facade of PHP on what was otherwise C++. Oh, and he was the CTO and one of the founders, so the company's whole product was built atop this thing.
Admin
Don't forget JavaScript
Admin
I object. FORT AND COBOL is exelent on starved macines
Admin
It's English, but it doesn't make any sense.
Admin
I would consider creating a cross-compiler from C to the almost C
Admin
Small batch, POS part, ..... I'm sensing a lot of false economy behind remaining loyal to the previous design choice.
Admin
I second your objection.
I would also like to argue that LISP is sort of a lingua franca for functional programming (but Scheme is better :-)), and since it's inherently extendable, is the basis for a ecosystem of domain specific languages, like elisp or AutoLisp.
Admin
One of our devices uses a SOC that has 16-bit bytes - TI's C2000 series. It's an old chip, and that was their trick to give you more flash ROM with one less address line. It makes things very 'interesting', and yes every character in a string is 16 bits. There ain't nothing smaller! However, the C for it is full featured and standard, and there are 32-bit ints and floats (or 64-bits if you really, really need it, but they're slow, entirely in software). So once you wrap your head around 16-bit bytes/chars it's actually not too different than usual. Incrementing a char* ptr still works as you'd expect. Just for sanity we explicitly type all our variables (Int16, Uint16, Int32, Uint32, Float32, etc) and never use 'byte', but you have to remember that 'char' is char16.
( As an aside, some people get very angry when I tell them this cpu has 16-bit bytes, because bytes are 8 bits BY DEFINITION YOU CHURL. You can tell the newbs. )
Admin
Frist igniting a flame war on byte size. You seem to confuse machine word (8 or 16 or 36 or whatever bits is used) and byte, that is, by current definition, exactly 8 bits. Unless you mean Baker's byte, that's 9 bits, cause you're such a good customer (xkcd/394)
Admin
Hi there, newb! A byte is almost always 8 bits these days, so it's a de-facto standard and you can certainly assume it, but a byte is whatever the smallest character size is / the increment of your address lines. We've had 4-bit bytes too. An octet is guaranteed 8 bits, which is why standards are very careful to say 'octet' if they really mean 8 bits. Back in the day, byte and word were often the same size, but then they diverged and a word is usually 32 or 64-bits these days.
And on this CPU, a byte/char is 16 bits. Address 100 holds 16 bits, address 101 holds 16 different bits, etc. If you define char *foo = "foo"; it allocates 4 16-bit chars with the top octets wasted. Yes it's weird, so designers don't usually do this. TI just wanted to save an address line. Search 'Byte Accesses with the C28x CPU' for more info.
Admin
With everything-is-16-bits it could have been a [trigger warning] MSP430.
Admin
The only thing in C you can be sure of is that sizeof(char) <= sizeof(short) <= sizeof(int) <= sizeof(long) <= sizeof(long long)
Note that all the comparisons are less than or equals. So 16-bit chars are perfectly valid, as are 32-bit chars. Or they all can be 32-bits.
If you need specifically sized types, that's what inttypes.h is for, which gives you the (u)int8_t, (u)int16_t, (u)int32_t, (u)int64_t and such. And if you really need to cast a pointer to an int, intptr_t, which guarantees an int big enough to hold a pointer.
Though they also went a bit overboard and defined the printf-type specifier needed to print those ints properly in a printf() type function, but they used such unwieldy names it's pracrically impossible to use.
Admin
You're missing this bit at the end of the paragraph the first of those lines is in:
Admin
Them's fighting words. Lisp is not worse than C. Also, for certain applications, neither is Forth.
C++ is worse than C obviously and the clue is in the name. You add all those extra features to C but actually use the language from before incrementing it They should have called it ++C
Admin
According to the C standard "A byte is composed of a contiguous sequence of bits, the number of which is implementation defined."
By far, the most common size is 8 bits, but as far as I can tell, no official standard exists. Some documents (e.g. for networking standards, which need to be independent of the machine architecture) specifically use the term "octet" to avoid ambiguity.
Admin
this reminds me of a Dilbert comic: the PHB became SO dense he turned into a black hole, THEN said, "why don't you program in "B"?