You know I get a lot of feedback that says: "when i click
Environment, I always get 'Unable to fully display recursive
composition.'"
Er, maybe a different error message is needed? People seem really
confused about the current one, also it's hard for them to understand
what
Environment means...
Thoughts are welcome
--
=
=
=
========================================================================
John M. McIntosh <johnmci(a)smalltalkconsulting.com>
Corporate Smalltalk Consulting Ltd. http://www.smalltalkconsulting.com
=
=
=
========================================================================
Hi, I been reading and using Magritte for a couple of days and it
is impressive how fast a web app can be written with it.
We are planing to use it in the development of a major app, but I have some
concerns/questions that I would like to ask. Most of them are related with
the coupling it generates between the model and the view using the
descriptions. These are the questions:
(I wanted this mail to be short, but it turned out sort of long... sorry for
that...)
1) Has anybody defined the descriptions in other class but the model class?
It seems to me that defining the descriptions as class methods in the model
class creates a coupling between the model and the view that I would like to
avoid. Part of that coupling is because of some view's "attributes" like
label, priority, beSorted, readOnly, etc. It also couples the model with
Magritte, which avoids me to use the model in an environment without
Magritte.
I was looking around and it seems possible, but the method #asComponent
sends the message #description which finally creates the description
container with all the collected descriptions. I could have my own
implementation of #asComponent or have another object to do it, but I wanted
to know if somebody already did it.
(btw, why #description and not #magritteDescription? it keeps my model
objects from using the message #description for a business porpoise)
2) The description "descriptionCanton" of the tutorial, is another example
of why I want to decouple descriptions from the model class. In the tutorial
the cantons are hard coded in the method, but that is not possible in a
"real" app. Cantons should be taken from another object, lets say the
"Cantons" object. But if I keep the "descriptionCanton" in Address and use
"Cantons" from there, I will be coupling Address with Cantons, which will
prevent me from using Address in another context or with provinces or states
instead of cantons. Does anybody has a suggestion for doing this?
3) To keep the objects that are created, the tutorial suggests to use a
class variable, but that is an option that does not scale. For instance,
what happens if I want to host the same app several times with different
data? (we are planning to use GLASS) Using the tutorial classes, I would
like to have an instance of MAPersonManager for one of our customers,
another instance of MAPersonManager for other customer, and so on. Also,
using a class variable keeps us from writing tests for that class because
that variable is shared among all the objects (tests, the real app, etc). I
think this is more a SeaSide question...
Anyway, I would like to have something like this:
MAPersonManager for: self customer1 <-- this is one instance of person
manager for one customer
MAPersonManager for: self customer2 <--- this is the other...
Is it possible? how?
3) I see that Magritte always needs an object to edit it. I mean, an
instance of Address to edit an address, an instance of Person to edit a
person, and so on. That means that the system could have invalid instances
for some period of time. For example, a person without a last name is an
invalid instance of Person, but to be able to edit a Person Magritte needs
an instance of Person without a last name. Maybe some people will say "so
what? what is the problem?". Well there are some problems with doing it this
way, for example a programmer could write a program that reads people from
an archive and forgets to check that the last name can not be empty. You
could say that for writing that program the programmer should use Magritte's
description also, but why? what is the meaning of label, priority, etc. in
that case? But let's say the programmer uses Magritte's description to read
from the file, what will prevent him to create a Person with out a last name
from the workspace?
So, to avoid invalid instances we use a technique were valid instances are
created from the beginning. For the Person example of the tutorial, I would
have something like this:
Person class>>named: aFirstName and: aLastName ....
self assertNotEmpty: aFirstName.
self assertNotEmpty: aLastName.
....
"Only if all the assertions are passed, the object is created"
^self new initilializeNamed: aFirstName and: aLastName ....
and if the object is not immutable, it will have a #syncronizeWith: message
that takes a valid instance and changes its instance variables. For the
person example:
Person>>syncronizeWith: aPerson
firstName := aPerson firstName.
lastName := aPerson lastName.
.... "the same with all inst. var".
Doing so, the system ensure me that the person after being modified is valid
because "aPerson" has to be valid to exist as an object.
There are many advantages of doing this:
a) There is no problem when an object is valid depending on the value of
different instance variables because all the validations are done together
before creating the object. (Dates are an example of this case, it is not
enough to know its day number to see if it is valid, the month has to be
known also)
b) Only valid instances exist in the image, no matter how I create them,
from the UI, reading a file, using the workspace, etc.
c) New programmers can not make mistakes using the current objects. If they
create an object it has to be valid, if not, they will get a debugger.
d) Validations of the object are kept with the object, the validations are
part of the object's definition and they are not spread in different places.
(This is also different from Magritte, that suggests to define validations
in the descriptions)
Of course we could agree or not that this is a good technique, but it proved
to be good for me and the people I work with and I would like to continue
using it.
Does anybody imagine how to do it with Magritte? or is it completely against
its philosophy?
Well, these are the questions I have by now... sorry for the long mail.
Bye,
Hernan.
Hello!
I want to put several links to the same file differenly labeled. Say, I have
some page, and a file named 'file' added as a child. I want to put on it
something like
You can download <this file> or do the same <that way>
where in <> is a link that after click on it immediately starts the download
(or opens browser dialog for it).
In Pier1.1.1
+file+ gives me the full name of file in the text.
+Label>file+ do the same.
*Another label>file* opens the page of the file.
Probably I miss something, but how can I do this using Pier's syntax?
TIA
--
Dennis Schetinin
I am still learning with Pier and I probably did something wrong. I am now
trying to edit /mainenviorment. There I have this:
FileDoesNotExistException:
'/home/mariano/squeak/imagenes/destinoMochila/Pier-1-1-1.app/Contents/Resources/files/b2/g03r5h2xukw1wbdb5dfktkusjilyoc/unknown'
I remember to delete all
/home/mariano/squeak/imagenes/destinoMochila/Pier-1-1-1.app/Contents/Resources/files/
once because I move all my images from there (pier) to a particular library
(they were css pictures).
Any ideas of how can I fix this ?
Thanks!!
Mariano
Hi All,
when i call: ((someDescription asComponentOn: aModel)
addMessage: anString;
adValidateForm;
yourself
somtime i have strange answer ( HTTP 500 ) when press the submit buttons.
I have do some test and i think :
if someDescription size are big,
the system after some timeout answer error.
It's correct ?
How i can set it?
Or there is other consideration about the error ?
Thank
Dario
I had tried to load the slide show Pier-Slideshow-lr.8
but I get the DNU, so where does rendererInstance come from?
MessageNotUnderstood: WARenderCanvas>>rendererInstance
• thisContext[] in PRSlideshow>>renderSlideOn: {[html rendererInstance
continue: self current in: self on: html]}
=
=
=
========================================================================
John M. McIntosh <johnmci(a)smalltalkconsulting.com>
Corporate Smalltalk Consulting Ltd. http://www.smalltalkconsulting.com
=
=
=
========================================================================