Comments (2)
Yeah this is a tricky issue. You're analysis about the cause is correct. The reason we can't declare Exceptions as actual instances of types is this:
Through some tricks we've managed to let the user declare Type objects such as "Int" at compile time. But it is still impossible for a user to declare instances of this object type at compile time because Types such as "Int" are declared as "extern" (or "global" in Cello). For example this will not compile.
var x = $(Int, 5);
int main(int argc, char** argv) {
show(x);
}
This is why we declare Exceptions using Singleton
, which makes them Type objects like Int
. This is done because it would be very annoying for users to have to declare their exception types at the start of the program code and delete them at the end (and we couldn't do it for builtin exceptions anyway).
One hack might be this: rather than use Singleton
use a different macro (say Exception
) which similarly constructs an empty type, but leaves in an extra flag specifying that this type is an exception type and that upon show
to as_str
it should also print out any active exception message.
from cello.
Although there are various ways to do this I think the correct way at the end of the day is to just let users get the exception message manually using Exception_Message()
.
There are a number of alternative workarounds but all of them would essentially be tricking the users where it is better if they gain a real understanding of what is going on as is said above. So I'm closing this issue for now.
from cello.
Related Issues (20)
- Unexpected GC behavior with Tuple HOT 5
- Make install should use "install --mode=..." instead of "cp" HOT 2
- make install doesn't install the dynamic library
- How do one "extends" a type? HOT 3
- error: cast to pointer from integer of different size HOT 2
- pop semantics? HOT 3
- Append Char HOT 2
- MacOS: __dyld section not supported HOT 1
- Abstracting a scripting language's internal value types using Cello HOT 1
- Feature request : Lua->Cello transpiler
- Missing Git tag for 2.1.0 release HOT 2
- Can I make a wrapper for other languages?
- Add vcpkg installation instructions
- Question about Array
- Doesn't work with Emscripten HOT 2
- is the project alive? can I use it in my product? who develops forks based on Cello? HOT 3
- Moving objects between threads HOT 1
- Failed to compile on GCC 8.1.0
- Can you do a comparison to Nim and Nelua?
- new release? HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from cello.