Retrouvez-nous sur Twitter

Retrouvez-nous sur Facebook

Version d'archive

  • Ce site est maintenant fermé et servira d'archive, vous pouvez vous rendre sur le nouveau Refuge à cette adresse : www.aeriesguard.com
  • Le minisite Minecraft est toujours disponible à cette adresse : minecraft.aeriesguard.com

Ertaï

Ertaï
Ersatz de régnant.

(profil mis à jour il y a plus de 3 ans)

Présentation générale

Salut c'est Ertaï.

Enfin, plus trop. Ertaï est le pseudonyme que j'ai choisi lors de mon arrivée sur Internet il y a de ça 8 ans, depuis que j'ai dû choisir un pseudonyme pour m'inscrire sur mon premier site web, dont je ne me souviens plus le nom. A l'époque, je jouais beaucoup aux cartes Magic l'Assemblée©, et Ertaï est dans l'histoire une personnage que j'aime beaucoup, ainsi que sa carte. En résumé, c'est un sorcier vantard avec un grand potentiel, et j'ai trouvé que ça me correspondait bien. c'est avec ce pseudonyme-là que je me suis inscrit sur le Refuge en 2003, et il m'est resté depuis lors.

Mais entre temps, j'ai un peu vieilli, j'ai rencontré la femme de ma vie, et on s'est donné des surnoms rigolos. Elle, Marceline, moi, Hypolite, et un nom de famille en commun, Petovan. C'est désormais sous cette identité, bien moins courante que celle d'Ertaï, que je m'identifie sur tous les nouveaux sites sur lesquels je m'inscris. Mais sur AG, je resterai toujours Ertaï. Un Hypolite se balade sur le Refuge, mais comme l'indique son profil, ce n'est qu'un prête-nom pour tester le Refuge en tant que simple membre.

Fonctions sur le Refuge

J'occupe plusieurs fonctions sur le Refuge qui font de moi votre interlocuteur privilégié dans certaines situations :

  • Administrateur : Contactez-moi ou un des modérateurs en cas de problème sur le site avec un autre membre. Pour le reste normalement la FAQ devrait suffire.
  • Webmaster : Un problème d'affichage ou de navigation, une suggestion sur l'amélioration technique ou visuelle du site ? Je m'en occuperai (un jour) seulement si vous saisissez le problème ou la sudans la Boîte à Idées.
  • Rédacteur en chef : Une idée d'article, une question sur l'organisation du forum, où écrire, quoi écrire ? Je suis là pour vous aider à contribuer au site.
  • Grammar Nazi : Vous voulez écrire mais vous n'osez pas à cause des fautes que vous faites ? Je peux vous aider en vous faisant une correction commentée de vos textes. En attendant, vous pouvez toujours consulter la FAQ orthographique.

Mes jeux multi-joueur

  • Starcraft
  • Command and Conquer Alerte Rouge 2
  • Supreme Commander
  • Warhammer 40,000 Dawn of War : Soulstorm
  • Team Fortress 2
  • Haegemonia
  • Street Wars

Pour une liste un peu plus étendue, vous pouvez consulter la liste de mes jeux sur Steam.

Mes identités sur Internet

  • Steam : Hypolite
  • Starcraft : Ça dépend
  • et c'est tout, je ne suis pas un joueur sur Internet

Mes jeux de société sur AG

Pour ma ludothèque complète (et mise à jour le 15 Mai 2011), je vous invite à consulter ma ludothèque en détails et en chiffres.

Coq < Variable P :  D -> Prop.
P is assumed

Coq < Variable d : D.
d is assumed

Coq < Lemma weird : (forall x:D, P x) ->  exists a, P a.
1 subgoal
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  ============================
   (forall x : D, P x) -> exists a : D, P a

Coq <  intro UnivP.
1 subgoal
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  UnivP : forall x : D, P x
  ============================
   exists a : D, P a

Coq < exists d; trivial.
Proof completed.

Coq < Qed.
intro UnivP.
exists d; trivial.
weird is defined

Coq < Hypothesis EM : forall A:Prop, A \/ ~ A.
EM is assumed

Coq < Lemma drinker :  exists x:D, P x -> forall x:D, P x.
1 subgoal
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  EM : forall A : Prop, A \/ ~ A
  ============================
   exists x : D, P x -> forall x0 : D, P x0

Coq < elim (EM (exists x, ~ P x)).
2 subgoals
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  EM : forall A : Prop, A \/ ~ A
  ============================
   (exists x : D, ~ P x) -> exists x : D, P x -> forall x0 : D, P x0
subgoal 2 is:
 ~ (exists x : D, ~ P x) -> exists x : D, P x -> forall x0 : D, P x0

Coq < intro Non_drinker; elim Non_drinker; intros Tom Tom_does_not_drink.
2 subgoals
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  EM : forall A : Prop, A \/ ~ A
  Non_drinker : exists x : D, ~ P x
  Tom : D
  Tom_does_not_drink : ~ P Tom
  ============================
   exists x : D, P x -> forall x0 : D, P x0
subgoal 2 is:
 ~ (exists x : D, ~ P x) -> exists x : D, P x -> forall x0 : D, P x0

Coq < exists Tom; intro Tom_drinks.
2 subgoals
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  EM : forall A : Prop, A \/ ~ A
  Non_drinker : exists x : D, ~ P x
  Tom : D
  Tom_does_not_drink : ~ P Tom
  Tom_drinks : P Tom
  ============================
   forall x : D, P x
subgoal 2 is:
 ~ (exists x : D, ~ P x) -> exists x : D, P x -> forall x0 : D, P x0

Coq < absurd (P Tom); trivial.
1 subgoal
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  EM : forall A : Prop, A \/ ~ A
  ============================
   ~ (exists x : D, ~ P x) -> exists x : D, P x -> forall x0 : D, P x0

Coq < intro No_nondrinker; exists d; intro d_drinks.
1 subgoal
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  EM : forall A : Prop, A \/ ~ A
  No_nondrinker : ~ (exists x : D, ~ P x)
  d_drinks : P d
  ============================
   forall x : D, P x

Coq < intro Dick; elim (EM (P Dick)); trivial.
1 subgoal
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  EM : forall A : Prop, A \/ ~ A
  No_nondrinker : ~ (exists x : D, ~ P x)
  d_drinks : P d
  Dick : D
  ============================
   ~ P Dick -> P Dick

Coq < intro Dick_does_not_drink; absurd (exists x, ~ P x); trivial.
1 subgoal
  
  D : Set
  R : D -> D -> Prop
  P : D -> Prop
  d : D
  EM : forall A : Prop, A \/ ~ A
  No_nondrinker : ~ (exists x : D, ~ P x)
  d_drinks : P d
  Dick : D
  Dick_does_not_drink : ~ P Dick
  ============================
   exists x : D, ~ P x

Coq < exists Dick; trivial.
Proof completed.

Coq < Qed.
elim (EM (exists x : _, ~ P x)).
 intro Non_drinker; elim Non_drinker; intros Tom Tom_does_not_drink.
   exists Tom; intro Tom_drinks.
    absurd (P Tom); trivial.
intro No_nondrinker; exists d; intro d_drinks.
  intro Dick; elim (EM (P Dick)); trivial.
  intro Dick_does_not_drink;  absurd (exists x : _, ~ P x); trivial.
  exists Dick; trivial.
drinker is defined

Coq < End Predicate_calculus.

Coq < Check refl_if.
refl_if
     : forall (D : Set) (R : D -> D -> Prop),
       (forall x y : D, R x y -> R y x) ->
       (forall x y z : D, R x y -> R y z -> R x z) ->
       forall x : D, (exists y : D, R x y) -> R x x

Coq < Check weird.
weird
     : forall (D : Set) (P : D -> Prop),
       D -> (forall x : D, P x) -> exists a : D, P a

Coq < Check drinker.
drinker
     : forall (D : Set) (P : D -> Prop),
       D ->
       (forall A : Prop, A \/ ~ A) ->
       exists x : D, P x -> forall x0 : D, P x0

open Printf

let pi = 4. *. atan 1.

module Array = struct
  include Array

  let for_all p a =
    fold_left (fun b x -> p x && b) true a
end

type vec2 = { x: float; y: float }

let vec2 x y = {x=x; y=y}

let zero = vec2 0. 0.

let of_list = function
    [x; y] -> vec2 x y
  | _ -> invalid_arg "Vec2.of_list"

let ( +| ) a b = {x = a.x +. b.x; y = a.y +. b.y}
let ( -| ) a b = {x = a.x -. b.x; y = a.y -. b.y}
let ( ~| ) a = {x = -. a.x; y = -. a.y}
let ( *| ) s r = {x = s *. r.x; y = s *. r.y}

let normal a = { x = a.y; y = -. a.x }
let dot a b = a.x *. b.x +. a.y *. b.y
let length2 r = dot r r
let length r = sqrt(length2 r)
let unitise r = 1. /. length r *| r

(* Get the time since the program started. *)
let time =
  let t = Unix.gettimeofday() in
  fun () -> Unix.gettimeofday() -. t

let width = ref 1 and height = ref 1

(* Reshape the viewport and store the width and height. *)
let reshape ~w ~h =
  GlDraw.viewport ~x:0 ~y:0 ~w ~h;
  width := max 1 w;
  height := max 1 h

(* Pass a single vertex to the OpenGL. *)
let vertex {x=x; y=y} =
  GlDraw.vertex ~x ~y ()

let translate r =
  GlMat.translate ~x:r.x ~y:r.y ()

let rotate angle =
  let angle = angle *. 180. /. pi in
  GlMat.rotate ~angle ~z:1. ()

let scale s =
  GlMat.scale ~x:s ~y:s ()

let protect f g =
  try
    f();
    g()
  with e ->
    g();
    raise e

let mat f =
  GlMat.push();
  protect f GlMat.pop

let render prim f =
  GlDraw.begins prim;
  protect f GlDraw.ends

let circle x = vec2 (sin x) (cos x)

(* Memoize OpenGL calls in a display list. *)
let gl_memoize f =
  let dl = ref None in
  fun () -> match !dl with
  | Some dl -> GlList.call dl
  | None ->
      let dl' = GlList.create `compile in
      f ();
      GlList.ends ();
      dl := Some dl'

let rec iter f l u = if l<u then (f l; iter f (l+1) u)

(* Render a ball at the origin. *)
let render_ball =
  gl_memoize
    (fun () ->
       let n = 36 in
       let aux i = circle (2. *. pi *. float i /. float n) in
       render `triangle_fan
  (fun () ->
     vertex zero;
     iter (fun i -> vertex (aux i)) 0 (n/4+1));
       render `triangle_fan
  (fun () ->
     vertex zero;
     iter (fun i -> vertex (aux i)) (n/2) (3*n/4+1));
       render `triangle_strip
  (fun () -> iter (fun i ->
       vertex (0.9 *| aux i);
       vertex (aux i)) 0 (n+1)))

type circle = { center: vec2; radius: float }

type ball = { circle: circle;
       velocity: vec2;
       angle: float;
       angular_velocity: float }

let make_ball ?(v=vec2 0.1 0.) ?(r=0.05) x y =
  { circle = { center = vec2 x y; radius = r };
    velocity = v;
    angle = 0.;
    angular_velocity = 0. }

type surface =
    Line of vec2 * vec2
  | Circle of vec2 * float

let surfaces = ref [Line (vec2 0. 0., vec2 0. 1.);
      Line (vec2 0. 1., vec2 1. 1.);
      Line (vec2 1. 1., vec2 1. 0.);
      Line (vec2 1. 0.2, vec2 0. 0.)]

(* Split balls. *)
let balls =
  ref [|{(make_ball 0.5 0.9) with velocity = vec2 0. (-1.)};
 {(make_ball 0.45 0.05) with velocity = vec2 0. 0.};
 {(make_ball 0.55 0.05) with velocity = vec2 0. 0.}|]
let surfaces = ref [Line (vec2 0. 0., vec2 0. 1.);
      Line (vec2 0. 1., vec2 1. 1.);
      Line (vec2 1. 1., vec2 1. 0.);
      Line (vec2 1. 0., vec2 0. 0.)]
let g = vec2 0. 0.1

let n_balls = try min 100 (max 0 (int_of_string(Sys.argv.(1)))) with _ -> 3

(* Funnel *)
let balls =
  let n = 10 in
  ref (Array.init n_balls
  (fun x -> make_ball ~v:(vec2 0. 0.) ~r:0.02
     (0.2 +. 0.03 *. float ((x/n) mod 2) +. 0.06 *. float (x mod n))
     (0.9 -. 0.04 *. float (x/n))))
let surfaces =
  let n = 128 in
  let aux i =
    let r = circle (2. *. pi *. float (i + n/4) /. float n) in
    vec2 (0.5 +. 0.5 *. r.x) (1. +. r.y) in
  ref (Array.to_list (Array.init n (fun i -> Line (aux (i-1), aux i))))
let surfaces = ref (Circle (vec2 0.37 0.3, 0.11) ::
        Circle (vec2 0.63 0.3, 0.11) ::
        !surfaces)
let g = vec2 0. 0.5

let display_ball ball =
  mat (fun () ->
  translate ball.circle.center;
  rotate ball.angle;
  scale ball.circle.radius;
  render_ball())

let display_balls () =
  Array.iter display_ball !balls

let display_surface = function
    Line (v1, v2) ->
      GlDraw.begins `lines;
      List.iter vertex [v1; v2];
      GlDraw.ends ()
  | Circle (c, r) ->
      GlMat.push();
      mat (fun () ->
      translate c;
      scale r;
      let n = 360 in
      GlDraw.begins `line_loop;
      for i=0 to n-1 do
        vertex (circle (2. *. pi *. float i /. float n))
      done;
      GlDraw.ends ())

let display_surfaces =
  gl_memoize (fun () -> List.iter display_surface !surfaces)

let display () =
  GlClear.clear [ `color; `depth ];
  Gl.enable `depth_test;
  GlFunc.depth_func `lequal;

  (* Initialise a orthogonal projection of the 2D scene. *)
  GlMat.mode `projection;
  GlMat.load_identity ();
  GlMat.ortho ~x:(0., 1.) ~y:(0., 1.) ~z:(0., 1.);
  GlMat.mode `modelview;
  GlMat.load_identity ();

  GlDraw.color (1., 1., 1.) ~alpha:1.;

  display_balls();
  display_surfaces();

  Gl.finish ();

  Unix.sleep 0;

  Glut.swapBuffers ()

let clamp l u (x : float) =
  if x<l then l else if x>u then u else x

let circle_circle c1 r1 c2 r2 =
  let s = c2 -| c1 in
  c1 +| 0.5 *. (length s +. r1 -. r2) *| unitise s

let circle_circle c1 r1 c2 r2 =
  let s = c2 -| c1 in
  let l = length s in
  let s = (1. /. l) *| s in
  c1 +| 0.5 *. (l +. r1 -. r2) *| s

(* Find the point of impact between a circle and a surface. *)
let point_of_impact circle = function
    Line (p1, p2) ->
      (* Find the closest approach of the finite line v1 -> v2 to the point
  r. *)
      let p21 = p2 -| p1 in
      let x = clamp 0. 1. (dot (circle.center -| p1) p21 /. length2 p21) in
      p1 +| x *| p21
  | Circle (c2, r2) -> circle_circle circle.center circle.radius c2 r2

let circle_circle_intersects c1 c2 =
  let p = circle_circle c1.center c1.radius c2.center c2.radius in
  length(c1.center -| p) < c1.radius

let rec update_ball dt (ball, impacts as accu) surface =
  let p = point_of_impact ball.circle surface in

  let d = ball.circle.center -| p in

  if length d > ball.circle.radius then accu else begin
    (* Local basis through center and perpendicular. *)
    let a = unitise d in
    let b = normal a in
    
    (* Resolve the velocity at the point of impact into components through the
       center and perpendicular. *)
    let dva = dot ball.velocity a in
    let dvb = dot ball.velocity b in
    if dva >= 0. then accu else
      { ball with
   velocity = ball.velocity +| 2. *. abs_float dva *| a -|
       0. *. ball.angular_velocity *. ball.circle.radius *| b;
   angular_velocity = -. dvb /. ball.circle.radius }, p::impacts
  end

(* Bisect the time slice until there is only one impact. *)
let rec update t t' balls =
  let dt = t' -. t in

  (* Ball-ball impacts. *)
  let balls', impacts =
    let balls = Array.copy balls in
    let impacts = Array.map (fun _ -> []) balls in
    let n = Array.length balls in

    for i=0 to n-1 do
      (* Ball-surface impacts *)
      (fun (b, is) ->
  balls.(i) <- b;
  impacts.(i) <- is)
 (List.fold_left (update_ball dt) (balls.(i), impacts.(i)) !surfaces);

      (* Ball-ball impacts. *)
      if i>0 then
 let b1 = balls.(i) in
 for j=0 to i-1 do
   let b2 = balls.(j) in
   let c1 = b1.circle and c2 = b2.circle in
   let p = circle_circle c1.center c1.radius c2.center c2.radius in
   if length(c1.center -| p) < c1.radius then begin
     let u1 = b1.velocity and u2 = b2.velocity in
     let da1 = b1.angular_velocity and da2 = b2.angular_velocity in
     let r1 = c1.radius and r2 = c2.radius in

     (* Find the velocity difference to the center-of-momentum frame. *)
     let com = 0.5 *| (u1 +| u2) in

     (* Move to COM frame. *)
     let u1 = u1 -| com and u2 = u2 -| com in
     let u = unitise (c2.center -| c1.center) in
     let v = normal u in
     let impulse = u2 -| u1 +| (da1 *. r1 -. da2 *. r2) *| v in
     let impulse_u = dot u impulse *| u in
     let impulse_v = dot v impulse in
     let v1 = u1 +| impulse_u and v2 = u2 -| impulse_u in
     let da1' = da1 +. impulse_v *. r1 in
     let da2' = da2 -. impulse_v *. r2 in

     (* Move from COM frame. *)
     let v1 = v1 +| com and v2 = v2 +| com in

     balls.(i) <- { balls.(i) with
        velocity = v1;
        angular_velocity = da1' };
     balls.(j) <- { balls.(j) with
        velocity = v2;
        angular_velocity = da2' };
     impacts.(i) <- p :: impacts.(i);
     impacts.(j) <- p :: impacts.(j);
   end
 done;
    done;

    for i=0 to n-1 do
      let b = balls.(i) in
      let r = b.circle.center and dr = b.velocity in
      let a = b.angle and da = b.angular_velocity in
      let rec aux dr = function
   [] ->
      { balls.(i) with
   circle = { balls.(i).circle with center = r +| dt *| dr };
   angle = mod_float (a +. dt *. da) (2. *. pi);
   velocity = dr -| (t' -. t) *| g }
 | p::t ->
     (* Make sure the velocity is not pointing towards the impact
        point. *)
     let d = unitise(r -| p) in
     aux (dr -| min 0. (dot dr d) *| d) t in
      balls.(i) <- aux dr impacts.(i);
      match impacts.(i) with
 [] | [_] -> ()
      | _ ->
   balls.(i) <- { balls.(i) with angular_velocity = 0. }
    done;
    balls, impacts in

  (* Bisect if there was at least one impact and the time slice was large
     enough. *)
  let aux = function [] | [_] -> true | _ -> false in
  if dt<0.01 && (Array.for_all aux impacts || dt < 1e-3) then balls' else
    let t2 = (t +. t') *. 0.5 in
    update t2 t' (update t t2 balls)

let old_time = ref 0.

let idle () =
  let time' = time() in
  balls := update !old_time time' !balls;
  old_time := time';
  Glut.postRedisplay ()

let () =
  ignore (Glut.init Sys.argv);
  Glut.initDisplayMode ~alpha:true ~double_buffer:true ~depth:true ();
  Glut.initWindowSize ~w:1024 ~h:1024;
  ignore (Glut.createWindow ~title:"Bouncing balls");
  GlClear.color (0., 0., 0.) ~alpha:0.;

  Gl.enable `blend;
  List.iter Gl.enable [`line_smooth; `polygon_smooth];
  List.iter (fun x -> GlMisc.hint x `nicest) [`line_smooth; `polygon_smooth];
  GlDraw.line_width 4.;
  GlFunc.blend_func ~src:`src_alpha ~dst:`one;

  Glut.reshapeFunc ~cb:reshape;
  Glut.displayFunc ~cb:display;
  Glut.idleFunc ~cb:(Some idle);
  Glut.keyboardFunc ~cb:(fun ~key ~x ~y -> if key=27 then exit 0);
  Glut.mainLoop ()
    

Ce que les réfugiés en disent

SpiceGuid il y a plus de 3 ans

applause

Je découvre que le code OCaml est maintenant sensible à la case bisou


SpiceGuid il y a plus de 3 ans

C'est du code OCaml tiré de l'ouvrage OCaml for Scientists Smile


Zergy il y a plus de 3 ans

Mais à quoi sert donc le code source (en python) disponible dans ta fiche personnelle ?

C'est pour prendre la place d'Ivaldir ? icon_scratch


sasacool il y a plus de 4 ans

icon_surprised je ne savais même pas alors que je suis un fan "Des aventuriers du rail"


Ertaï il y a plus de 4 ans

Oui, j'ai même le jeu sur iPad qui permet de jouer à plusieurs sur le même iPad ou alors avec d'autres joueurs sur Internet Smile


sasacool il y a plus de 4 ans

Alors toi aussi tu joues aux Aventuriers du rail. Perso je trouve ce jeu super.


amin94916 il y a plus de 4 ans

sweat2


Hiruzen il y a plus de 4 ans

Moi perso, je me réveille à 6h maxi sourire3


Aka Guymelef il y a plus de 4 ans

Heureusement que tu es un grand flemmard de base, imagines que tu te sois réveiller à 8 heures heure française (ou moins) DoubleAccentCirconflexe


Ertaï il y a plus de 4 ans

Merci !

Au passage, je viens de me réveiller comme une fleur à midi heure française, ce qui correspond à 6 heures du matin heure locale, tout va bien, je ne suis pas du tout décalé sweat2


Aka Guymelef il y a plus de 4 ans

Bon vent d'Outre Atlantique icon_wink


Ertaï il y a plus de 4 ans

Une déclaration d'amour fraternel en public, il ne manquait plus que ça sur AG. sweat2


Cathaseris il y a plus de 4 ans

Heureusement qu'internet est là. J'ai presque pas le sentiment de perdre un pote comme ça.


Ertaï il y a plus de 4 ans

Je pars Mardi prochain, soit le 28 Février Smile


TSG il y a plus de 4 ans

Du coup, le jour de ton départ, c'est quand exactement?


SpiceGuid il y a plus de 5 ans

html, javascript, css, etc... Ragnarokplouf


Ertaï il y a plus de 5 ans

Evidemment ça m'intéresse. Je ne sais pas si je pourrai en faire quelque chose, mais ça m'intéresse Smile


Aka Guymelef il y a plus de 5 ans

Ertaï tu avais mentionné publier quelques articles à propos de l'intégration web (j'imagine tout ce qui est montage, javascript, css, etc...). Si tu n'as pas d'idées moi j'aurai un sujet où j'aimerais bien avoir ton avis sur la façon de procéder. Dis-moi si ça t'intéresse.


Dragoris il y a plus de 5 ans

Hey, je ne m'en suis aperçu que tard mais joyeuse fête du 13 août Hyppolyte !


Ertaï il y a plus de 5 ans

Nan mais c'est bien, on a transformé ma fiche personnelle en radio libre. Allez-y, défoulez-vous, quoi. icon_rolleyes


Aka Guymelef il y a plus de 5 ans

Tient je croyais que c'était le blog d'Ertaï ici ? Je m'âs trompé on dirait... icon_wink


Sevilla il y a plus de 5 ans

La vie n'est peut-être qu'une vaste illusion fumeuse ?

Attendez...je crois que je tiens une idée ! Ça peut vous paraître absurde, mais imaginez une seconde un malin génie non moins rusé et trompeur que puissant, qui emploierait toute son industrie à nous tromper sur notre existence...

D'ailleurs il y a un proverbe latin confortant mon idée: "Tere pera, numera castilla beni esùstis" qui signifie "la terre est ton père, nombreux en sont les châteaux bénis".

Méditez sur cette phrase.


TSG il y a plus de 5 ans

[Dérive de sujet incoming!]

Ben écoute ouais, si j'ai un pseudo, c'est pas pour qu'on m'appelle par mon prénom, et échanger des vidéos pour fap-fap-fap par MP, c'est par non-plus mon trip... Surtout avec quelqu'un dont je ne connais rien ou presque. Je veux dire, avec mon ami Whisperfrost, éventuellement on vas utiliser nos prénoms ou des pseudos plus récents, parce qu'on est pote depuis à peu près 4ans, on discute quotidiennement sur mon serveur mumble comme des gros geeks et on bosse sur nos univers fictifs. C'est du lourd quoi.

Après pour les passions et compagnie, c'est une question de point de vue, et je pense que ça dépend aussi de l'âge. Vu mon âge, m'être collé à l'idée de monter 20 personnages sur WoW au niveau max juste pour le challenge de la chose (à la façon du mec qui construit une tour Eiffel en allumettes), je trouve ça moins fumeux qu'un mec qui s'éclate encore avec des Lego à je ne sais pas exactement quel âge (mais je doute que tu sois plus jeune que moi). Je dis pas, j'aime les Lego, mais j'ai arrêté de faire quoique ce soit avec il y a bien 7 ou 8ans, et c'est déjà vachement. Du coup que tu me dise que mes persos c'est fumeux...


SpiceGuid il y a plus de 5 ans

Hé bien je veux dire qu'une voiturette en legos ça a quand même une certaine réalité ludique. Bien sûr ça ne consomme pas d'essence mais ça a un volant qui tourne et ça avance quand tu la pousses. Alors qu'une Nécromancienne de niveau 80 hé bien c'est plus fumeux, c'est du pur fantasme. C'est une remarque, pas désobligeante du tout, amicale même, une allusion à ton pseudo. Une façon de dire que je t'ai vu changé, qu'à ton arrivée tu étais The Shooted Gobelin et que maintenant tu es davantage Très Soigneux Graphiste.

Mais bon après si tu veux qu'on continue à s'échanger des mots doux on peut le faire par message privé. (Mais seulement si je peux t'appeler Quentin sinon c'est pas la peine, et j'ai cru comprendre que c'était pas négociable)


TSG il y a plus de 5 ans

Ah...
Tell me more, tell me more!


SpiceGuid il y a plus de 5 ans

Au niveau artistique.


TSG il y a plus de 5 ans

Pour savoir, la fumette, c'est à quel niveau?


Ertaï il y a plus de 5 ans

Peut-être devrait-t-on attendre la fin de nos déboires judiciaires, et de savoir si je pars aux Etats-Unis à la fin de l'année ?


SpiceGuid il y a plus de 5 ans

Bon alors cette assemblée générale c'est pour bientôt ou bien tu attends que TSG arrête la fumette ?


TSG il y a plus de 5 ans

Then it shall be AG Industries.

Contacter Ertaï

par message privé :

par Twitter : @MrPetovan

par Windows Live Messenger : ben.lort@tiscali.fr

par PlayStation Network : hypolite_petovan

par Steam : hypolite_petovan

Tout à propos d'Ertaï

Inscrit le: vendredi 19 juin 2009

Articles: 135

Posts: 3399

Site Web: Ma collection de tee-shirt

Date de naissance: 26/10/1984

Les derniers articles d'Ertaï

En voir plus

Ses articles préférés

Ertaï n'a pas encore marqué son appréciation pour un article !

© Copyright 2002-2017 Aeriesguard.com - Mentions légales
Aerie's Guard V 7.0
réalisé par Ertaï, designé par Ivaldir, illustré par Izual et Sophie Masure
Famfamfam